@assistant-ui/react 0.5.42 → 0.5.46
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.d.mts +36 -6
- package/dist/index.d.ts +36 -6
- package/dist/index.js +253 -67
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +208 -22
- package/dist/index.mjs.map +1 -1
- package/dist/styles/index.css +3 -0
- package/dist/styles/index.css.map +1 -1
- package/dist/styles/tailwindcss/thread.css +1 -1
- package/package.json +3 -3
package/dist/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/assistant-ui/assistant-ui/packages/react/dist/index.js","../src/context/providers/AssistantRuntimeProvider.tsx","../src/context/providers/AssistantProvider.tsx","../src/context/react/AssistantContext.ts","../src/context/stores/AssistantModelConfig.ts","../src/utils/ProxyConfigProvider.ts","../src/context/stores/AssistantToolUIs.ts","../src/context/providers/ThreadProvider.tsx","../src/context/react/ThreadContext.ts","../src/context/stores/Composer.ts","../src/context/stores/Thread.ts","../src/context/stores/ThreadViewport.tsx","../src/context/stores/ThreadActions.ts","../src/context/stores/ThreadMessages.ts","../src/context/stores/ThreadRuntime.tsx","../src/runtimes/core/subscribeToMainThread.ts","../src/runtimes/local/useLocalRuntime.tsx","../src/runtimes/core/BaseAssistantRuntime.tsx","../src/internal.ts","../src/utils/idUtils.tsx","../src/runtimes/edge/converters/fromCoreMessage.ts","../src/runtimes/utils/MessageRepository.tsx","../src/utils/smooth/useSmooth.tsx","../src/utils/smooth/SmoothContext.tsx","../src/ui/base/tooltip-icon-button.tsx","../src/ui/base/tooltip.tsx","../src/ui/utils/withDefaults.tsx","../src/ui/base/button.tsx","../src/runtimes/edge/converters/fromLanguageModelMessages.ts","../src/runtimes/edge/converters/fromLanguageModelTools.ts","../src/runtimes/edge/streams/utils/chunkByLineStream.ts","../src/runtimes/edge/streams/utils/streamPartDecoderStream.ts","../src/runtimes/edge/streams/utils/index.ts","../src/runtimes/edge/useEdgeRuntime.ts","../src/runtimes/edge/streams/assistantDecoderStream.ts","../src/runtimes/edge/EdgeChatAdapter.ts","../src/runtimes/local/shouldContinue.tsx","../src/runtimes/local/LocalThreadRuntime.tsx","../src/runtimes/local/LocalRuntime.tsx","../src/runtimes/external-store/getExternalStoreMessage.tsx","../src/runtimes/external-store/ThreadMessageConverter.ts","../src/runtimes/external-store/auto-status.tsx","../src/runtimes/external-store/ThreadMessageLike.tsx","../src/utils/getThreadMessageText.tsx","../src/runtimes/external-store/ExternalStoreThreadRuntime.tsx","../src/runtimes/external-store/ExternalStoreRuntime.tsx","../src/runtimes/external-store/useExternalStoreRuntime.tsx","../src/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.ts","../src/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.ts","../src/runtimes/speech/WebSpeechSynthesisAdapter.ts","../src/context/stores/AssistantActions.tsx","../src/context/stores/AssistantRuntime.tsx","../src/context/react/ComposerContext.ts","../src/context/react/MessageContext.ts","../src/context/react/ContentPartContext.ts","../src/hooks/useAppendMessage.tsx","../src/hooks/useSwitchToNewThread.tsx","../src/model-config/useAssistantTool.tsx","../src/model-config/makeAssistantTool.tsx","../src/model-config/useAssistantToolUI.tsx","../src/model-config/makeAssistantToolUI.tsx","../src/model-config/useAssistantInstructions.tsx","../src/primitive-hooks/actionBar/useActionBarCopy.tsx","../src/utils/combined/useCombinedStore.ts","../src/utils/combined/createCombinedStore.ts","../src/primitive-hooks/actionBar/useActionBarEdit.tsx","../src/primitive-hooks/actionBar/useActionBarReload.tsx","../src/primitive-hooks/actionBar/useActionBarSpeak.tsx","../src/primitive-hooks/actionBar/useActionBarStopSpeaking.tsx","../src/primitive-hooks/branchPicker/useBranchPickerCount.tsx","../src/primitive-hooks/branchPicker/useBranchPickerNext.tsx","../src/primitive-hooks/branchPicker/useBranchPickerNumber.tsx","../src/primitive-hooks/branchPicker/useBranchPickerPrevious.tsx","../src/primitive-hooks/composer/useComposerCancel.tsx","../src/primitive-hooks/composer/useComposerIf.tsx","../src/primitive-hooks/composer/useComposerSend.tsx","../src/primitive-hooks/contentPart/useContentPartDisplay.tsx","../src/primitive-hooks/contentPart/useContentPartImage.tsx","../src/primitive-hooks/contentPart/useContentPartText.tsx","../src/primitive-hooks/message/useMessageIf.tsx","../src/primitive-hooks/thread/useThreadIf.tsx","../src/primitive-hooks/thread/useThreadEmpty.tsx","../src/primitive-hooks/thread/useThreadScrollToBottom.tsx","../src/primitive-hooks/thread/useThreadSuggestion.tsx","../src/primitives/actionBar/index.ts","../src/primitives/actionBar/ActionBarRoot.tsx","../src/primitives/actionBar/useActionBarFloatStatus.tsx","../src/utils/createActionButton.tsx","../src/primitives/actionBar/ActionBarCopy.tsx","../src/primitives/actionBar/ActionBarReload.tsx","../src/primitives/actionBar/ActionBarEdit.tsx","../src/primitives/actionBar/ActionBarSpeak.tsx","../src/primitives/actionBar/ActionBarStopSpeaking.tsx","../src/primitives/assistantModal/index.ts","../src/primitives/assistantModal/AssistantModalRoot.tsx","../src/utils/hooks/useOnComposerFocus.tsx","../src/primitives/assistantModal/scope.tsx","../src/primitives/assistantModal/AssistantModalTrigger.tsx","../src/primitives/assistantModal/AssistantModalContent.tsx","../src/primitives/assistantModal/AssistantModalAnchor.tsx","../src/primitives/branchPicker/index.ts","../src/primitives/branchPicker/BranchPickerNext.tsx","../src/primitives/branchPicker/BranchPickerPrevious.tsx","../src/primitives/branchPicker/BranchPickerCount.tsx","../src/primitives/branchPicker/BranchPickerNumber.tsx","../src/primitives/branchPicker/BranchPickerRoot.tsx","../src/primitives/message/index.ts","../src/primitives/message/MessageRoot.tsx","../src/utils/hooks/useManagedRef.ts","../src/primitives/message/MessageIf.tsx","../src/primitives/message/MessageContent.tsx","../src/context/providers/ContentPartProvider.tsx","../src/primitives/contentPart/ContentPartText.tsx","../src/primitives/contentPart/ContentPartImage.tsx","../src/primitives/contentPart/ContentPartDisplay.tsx","../src/primitives/contentPart/ContentPartInProgress.tsx","../src/primitives/message/MessageInProgress.tsx","../src/primitives/composer/index.ts","../src/primitives/composer/ComposerRoot.tsx","../src/primitives/composer/ComposerInput.tsx","../src/primitives/composer/ComposerSend.tsx","../src/primitives/composer/ComposerCancel.tsx","../src/primitives/composer/ComposerIf.tsx","../src/primitives/contentPart/index.ts","../src/primitives/thread/index.ts","../src/primitives/thread/ThreadRoot.tsx","../src/primitives/thread/ThreadEmpty.tsx","../src/primitives/thread/ThreadIf.tsx","../src/primitives/thread/ThreadViewport.tsx","../src/primitive-hooks/thread/useThreadViewportAutoScroll.tsx","../src/utils/hooks/useOnResizeContent.tsx","../src/utils/hooks/useOnScrollToBottom.tsx","../src/primitives/thread/ThreadMessages.tsx","../src/context/providers/MessageProvider.tsx","../src/context/stores/EditComposer.ts","../src/context/stores/MessageUtils.ts","../src/primitives/thread/ThreadScrollToBottom.tsx","../src/primitives/thread/ThreadSuggestion.tsx","../src/ui/thread-config.tsx","../src/ui/assistant-action-bar.tsx","../src/ui/assistant-message.tsx","../src/ui/branch-picker.tsx","../src/ui/base/avatar.tsx","../src/ui/content-part.tsx","../src/ui/assistant-modal.tsx","../src/ui/thread.tsx","../src/ui/composer.tsx","../src/ui/base/CircleStopIcon.tsx","../src/ui/thread-welcome.tsx","../src/ui/user-message.tsx","../src/ui/user-action-bar.tsx","../src/ui/edit-composer.tsx"],"names":["create","createContext","useContext","runtime","message","useSmoothStatus","text","useState","forwardRef","jsx","jsxs","useInsertionEffect","useEffect","useMemo","useCallback","Primitive","composeEventHandlers","PopoverPrimitive","useCallbackRef","Fragment","useContentPartContext","memo","useComposedRefs","useRef","useEscapeKeydown","useMessageContext","UserMessage","BranchPickerPrevious","classNames","exports"],"mappings":"AAAA,spCAAY;AACZ;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,sDAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B;AACA;AChBA,8BAAqB;ADkBrB;AACA;AEjBA;AFmBA;AACA;AGrBA;AAcO,IAAM,iBAAA,EAAmB,kCAAA;AAAA,EAC9B;AACF,CAAA;AAMO,SAAS,mBAAA,CAAoB,OAAA,EAA8B;AAChE,EAAA,MAAM,QAAA,EAAU,+BAAA,gBAA2B,CAAA;AAC3C,EAAA,GAAA,CAAI,iBAAC,OAAA,6BAAS,WAAA,GAAY,CAAC,OAAA;AACzB,IAAA,MAAM,IAAI,KAAA;AAAA,MACR;AAAA,IACF,CAAA;AACF,EAAA,OAAO,OAAA;AACT;AHKA;AACA;AInCA,kCAAuB;AJqCvB;AACA;AKlCO,IAAM,oBAAA,YAAN,MAAyD;AAAA,iBACtD,WAAA,kBAAa,IAAI,GAAA,CAAyB,EAAA;AAAA,EAElD,cAAA,CAAA,EAAiB;AACf,IAAA,OAAO,gDAAA,IAAkB,CAAK,UAAU,CAAA;AAAA,EAC1C;AAAA,EAEA,2BAAA,CAA4B,QAAA,EAA+B;AACzD,IAAA,IAAA,CAAK,UAAA,CAAW,GAAA,CAAI,QAAQ,CAAA;AAC5B,IAAA,OAAO,CAAA,EAAA,GAAM;AACX,MAAA,IAAA,CAAK,UAAA,CAAW,MAAA,CAAO,QAAQ,CAAA;AAAA,IACjC,CAAA;AAAA,EACF;AACF,UAAA;ALkCA;AACA;AI1CO,IAAM,8BAAA,EAAgC,CAAA,EAAA,GAC3C,6BAAA,CAAkC,EAAA,GAAM;AACtC,EAAA,MAAM,MAAA,EAAQ,IAAI,mBAAA,CAAoB,CAAA;AAEtC,EAAA,OAAO,MAAA,CAAO,MAAA,CAAO;AAAA,IACnB,cAAA,EAAgB,CAAA,EAAA,GAAM;AACpB,MAAA,OAAO,KAAA,CAAM,cAAA,CAAe,CAAA;AAAA,IAC9B,CAAA;AAAA,IACA,2BAAA,EAA6B,CAAC,QAAA,EAAA,GAAkC;AAC9D,MAAA,OAAO,KAAA,CAAM,2BAAA,CAA4B,QAAQ,CAAA;AAAA,IACnD;AAAA,EACF,CAAC,CAAA;AACH,CAAC,CAAA;AJ0CH;AACA;AMjEA;AAWO,IAAM,0BAAA,EAA4B,CAAA,EAAA,GACvCA,6BAAAA,CAA+B,GAAA,EAAA,GAAQ;AACrC,EAAA,MAAM,UAAA,kBAAY,IAAI,GAAA,CAA4C,CAAA;AAElE,EAAA,OAAO,MAAA,CAAO,MAAA,CAAO;AAAA,IACnB,SAAA,EAAW,CAAC,IAAA,EAAA,GAAS;AACnB,MAAA,MAAM,IAAA,EAAM,SAAA,CAAU,GAAA,CAAI,IAAI,CAAA;AAC9B,MAAA,MAAM,KAAA,kBAAO,GAAA,6BAAK,EAAA,mBAAG,CAAA,CAAE,GAAA;AACvB,MAAA,GAAA,CAAI,IAAA,EAAM,OAAO,IAAA;AACjB,MAAA,OAAO,IAAA;AAAA,IACT,CAAA;AAAA,IACA,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,EAAA,GAAW;AAC3B,MAAA,IAAI,IAAA,EAAM,SAAA,CAAU,GAAA,CAAI,IAAI,CAAA;AAC5B,MAAA,GAAA,CAAI,CAAC,GAAA,EAAK;AACR,QAAA,IAAA,EAAM,CAAC,CAAA;AACP,QAAA,SAAA,CAAU,GAAA,CAAI,IAAA,EAAM,GAAG,CAAA;AAAA,MACzB;AACA,MAAA,GAAA,CAAI,IAAA,CAAK,MAAM,CAAA;AACf,MAAA,GAAA,CAAI,CAAC,CAAC,CAAA;AAEN,MAAA,OAAO,CAAA,EAAA,GAAM;AACX,QAAA,MAAM,MAAA,EAAQ,GAAA,CAAI,OAAA,CAAQ,MAAM,CAAA;AAChC,QAAA,GAAA,CAAI,MAAA,IAAU,CAAA,CAAA,EAAI;AAChB,UAAA,GAAA,CAAI,MAAA,CAAO,KAAA,EAAO,CAAC,CAAA;AAAA,QACrB;AACA,QAAA,GAAA,CAAI,MAAA,IAAU,GAAA,CAAI,MAAA,EAAQ;AACxB,UAAA,GAAA,CAAI,CAAC,CAAC,CAAA;AAAA,QACR;AAAA,MACF,CAAA;AAAA,IACF;AAAA,EACF,CAAC,CAAA;AACH,CAAC,CAAA;ANsDH;AACA;AOlGA;APoGA;AACA;AQpGA;AAkBO,IAAM,cAAA,EAAgBC,kCAAAA,IAA6C,CAAA;AAMnE,SAAS,gBAAA,CAAiB,OAAA,EAA8B;AAC7D,EAAA,MAAM,QAAA,EAAUC,+BAAAA,aAAwB,CAAA;AACxC,EAAA,GAAA,CAAI,iBAAC,OAAA,6BAAS,WAAA,GAAY,CAAC,OAAA;AACzB,IAAA,MAAM,IAAI,KAAA;AAAA,MACR;AAAA,IACF,CAAA;AACF,EAAA,OAAO,OAAA;AACT;ARgFA;AACA;ASlHA;AAuBO,IAAM,kBAAA,EAAoB,CAC/B,gBAAA,EAAA,GACiC;AACjC,EAAA,MAAM,eAAA,kBAAiB,IAAI,GAAA,CAAgB,CAAA;AAC3C,EAAA,OAAOF,6BAAAA,CAAsB,CAAE,CAAC,CAAA,EAAG,GAAA,EAAA,GAAQ;AACzC,IAAA,MAAM,QAAA,EAAU,gBAAA,CAAiB,QAAA,CAAS,CAAA;AAC1C,IAAA,OAAO;AAAA,MACL,IAAI,KAAA,CAAA,EAAQ;AACV,QAAA,OAAO,GAAA,CAAI,CAAA,CAAE,IAAA;AAAA,MACf,CAAA;AAAA,MACA,QAAA,CAAS,KAAA,EAAO;AACd,QAAA,GAAA,CAAI,CAAA,CAAE,OAAA,CAAQ,KAAK,CAAA;AAAA,MACrB,CAAA;AAAA,MAEA,IAAA,EAAM,OAAA,CAAQ,QAAA,CAAS,IAAA;AAAA,MACvB,OAAA,EAAS,CAAC,KAAA,EAAA,GAAU;AAClB,QAAA,gBAAA,CAAiB,QAAA,CAAS,CAAA,CAAE,QAAA,CAAS,OAAA,CAAQ,KAAK,CAAA;AAAA,MACpD,CAAA;AAAA,MAEA,SAAA,EAAW,OAAA,CAAQ,YAAA,CAAa,MAAA;AAAA,MAChC,SAAA,EAAW,IAAA;AAAA,MAEX,IAAA,EAAM,CAAA,EAAA,GAAM;AACV,QAAA,MAAMG,SAAAA,EAAU,gBAAA,CAAiB,QAAA,CAAS,CAAA;AAC1C,QAAA,MAAM,KAAA,EAAOA,QAAAA,CAAQ,QAAA,CAAS,IAAA;AAC9B,QAAAA,QAAAA,CAAQ,QAAA,CAAS,OAAA,CAAQ,EAAE,CAAA;AAE3B,QAAAA,QAAAA,CAAQ,MAAA,CAAO;AAAA,UACb,QAAA,mCAAUA,QAAAA,qBAAQ,QAAA,qBAAS,EAAA,mBAAG,CAAA,CAAE,CAAA,6BAAG,IAAA,UAAM,MAAA;AAAA,UACzC,IAAA,EAAM,MAAA;AAAA,UACN,OAAA,EAAS,CAAC,EAAE,IAAA,EAAM,MAAA,EAAQ,KAAK,CAAC;AAAA,QAClC,CAAC,CAAA;AAAA,MACH,CAAA;AAAA,MACA,MAAA,EAAQ,CAAA,EAAA,GAAM;AACZ,QAAA,gBAAA,CAAiB,QAAA,CAAS,CAAA,CAAE,SAAA,CAAU,CAAA;AAAA,MACxC,CAAA;AAAA,MACA,KAAA,EAAO,CAAA,EAAA,GAAM;AACX,QAAA,IAAA,CAAA,MAAW,SAAA,GAAY,cAAA,EAAgB;AACrC,UAAA,QAAA,CAAS,CAAA;AAAA,QACX;AAAA,MACF,CAAA;AAAA,MACA,OAAA,EAAS,CAAC,QAAA,EAAA,GAAa;AACrB,QAAA,cAAA,CAAe,GAAA,CAAI,QAAQ,CAAA;AAC3B,QAAA,OAAO,CAAA,EAAA,GAAM;AACX,UAAA,cAAA,CAAe,MAAA,CAAO,QAAQ,CAAA;AAAA,QAChC,CAAA;AAAA,MACF;AAAA,IACF,CAAA;AAAA,EACF,CAAC,CAAA;AACH,CAAA;ATwFA;AACA;AUjKA;AAmBO,IAAM,0BAAA,EAA4B,CACvC,OAAA,EAAA,GACgB;AAChB,EAAA,MAAM,YAAA,EAAc,OAAA,CAAQ,QAAA,CAAS,EAAA,CAAG,CAAA,CAAE,CAAA;AAC1C,EAAA,OAAO,MAAA,CAAO,MAAA,CAAO;AAAA,IACnB,YAAA,EAAc,OAAA,CAAQ,YAAA;AAAA,IACtB,UAAA,EAAY,OAAA,CAAQ,UAAA;AAAA,IACpB,SAAA,kBACE,WAAA,+BAAa,OAAA,IAAS,YAAA,EAClB,MAAA,EACA,WAAA,CAAY,MAAA,CAAO,KAAA,IAAS;AAAA,EACpC,CAAC,CAAA;AACH,CAAA;AAEO,IAAM,gBAAA,EAAkB,CAC7B,UAAA,EAAA,GACG;AACH,EAAA,MAAM,QAAA,EAAU,UAAA,CAAW,QAAA,CAAS,CAAA;AACpC,EAAA,OAAOH,6BAAAA,CAAoB,EAAA,GAAM,yBAAA,CAA0B,OAAO,CAAC,CAAA;AACrE,CAAA;AVyIA;AACA;AW/KA;AASO,IAAM,wBAAA,EAA0B,CAAA,EAAA,GAAM;AAC3C,EAAA,MAAM,wBAAA,kBAA0B,IAAI,GAAA,CAAgB,CAAA;AAEpD,EAAA,OAAOA,6BAAAA,CAA4B,EAAA,GAAA,CAAO;AAAA,IACxC,UAAA,EAAY,IAAA;AAAA,IACZ,cAAA,EAAgB,CAAA,EAAA,GAAM;AACpB,MAAA,IAAA,CAAA,MAAW,SAAA,GAAY,uBAAA,EAAyB;AAC9C,QAAA,QAAA,CAAS,CAAA;AAAA,MACX;AAAA,IACF,CAAA;AAAA,IACA,gBAAA,EAAkB,CAAC,QAAA,EAAA,GAAa;AAC9B,MAAA,uBAAA,CAAwB,GAAA,CAAI,QAAQ,CAAA;AACpC,MAAA,OAAO,CAAA,EAAA,GAAM;AACX,QAAA,uBAAA,CAAwB,MAAA,CAAO,QAAQ,CAAA;AAAA,MACzC,CAAA;AAAA,IACF;AAAA,EACF,CAAA,CAAE,CAAA;AACJ,CAAA;AXwKA;AACA;AYpMA;AAyBO,IAAM,sBAAA,EAAwB,CACnC,YAAA,EAAA,GACG;AACH,EAAA,OAAOA,6BAAAA;AAAA,IAA2B,CAAA,EAAA,GAChC,MAAA,CAAO,MAAA,CAAO;AAAA,MACZ,WAAA,EAAa,CAAC,SAAA,EAAA,GACZ,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,WAAA,CAAY,SAAS,CAAA;AAAA,MAC/C,cAAA,EAAgB,CAAC,QAAA,EAAA,GACf,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,cAAA,CAAe,QAAQ,CAAA;AAAA,MAEjD,QAAA,EAAU,CAAC,QAAA,EAAA,GAAa,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,QAAA,CAAS,QAAQ,CAAA;AAAA,MACjE,MAAA,EAAQ,CAAC,OAAA,EAAA,GAAY,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,MAAA,CAAO,OAAO,CAAA;AAAA,MAC3D,SAAA,EAAW,CAAA,EAAA,GAAM,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,SAAA,CAAU,CAAA;AAAA,MAEnD,aAAA,EAAe,CAAC,OAAA,EAAA,GACd,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,aAAA,CAAc,OAAO,CAAA;AAAA,MAE/C,KAAA,EAAO,CAAC,SAAA,EAAA,GAAc,YAAA,CAAa,QAAA,CAAS,CAAA,CAAE,KAAA,CAAM,SAAS;AAAA,IAC/D,CAAC;AAAA,EACH,CAAA;AACF,CAAA;AZsKA;AACA;AapNA;AAOO,IAAM,wBAAA,EAA0B,CACrC,UAAA,EAAA,GACG;AACH,EAAA,OAAOA,6BAAAA,CAA4B,EAAA,GAAM,UAAA,CAAW,QAAA,CAAS,CAAA,CAAE,QAAQ,CAAA;AACzE,CAAA;Ab8MA;AACA;Ac1NA;AAKO,IAAM,uBAAA,EAAyB,CAAC,OAAA,EAAA,GAA2B;AAChE,EAAA,OAAOA,6BAAAA,CAA2B,EAAA,GAAM,OAAO,CAAA;AACjD,CAAA;AdwNA;AACA;Ae7NO,IAAM,sBAAA,EAAwB,CACnC,OAAA,EACA,QAAA,EAAA,GACG;AACH,EAAA,IAAI,MAAA,EAAQ,IAAA;AACZ,EAAA,IAAI,OAAA;AACJ,EAAA,MAAM,MAAA,EAAQ,CAAA,EAAA,GAAM;AAClB,oBAAA,OAAA,4BAAA,CAAU,GAAA;AACV,IAAA,QAAA,EAAU,OAAA,CAAQ,MAAA,CAAO,SAAA,CAAU,QAAQ,CAAA;AAE3C,IAAA,GAAA,CAAI,CAAC,KAAA,EAAO;AACV,MAAA,QAAA,CAAS,CAAA;AAAA,IACX;AACA,IAAA,MAAA,EAAQ,KAAA;AAAA,EACV,CAAA;AAEA,EAAA,MAAM,YAAA,EAAc,OAAA,CAAQ,SAAA,CAAU,KAAK,CAAA;AAC3C,EAAA,KAAA,CAAM,CAAA;AAEN,EAAA,OAAO,CAAA,EAAA,GAAM;AACX,IAAA,WAAA,CAAY,CAAA;AACZ,oBAAA,OAAA,4BAAA,CAAU,GAAA;AAAA,EACZ,CAAA;AACF,CAAA;AfyNA;AACA;AgBlPA;AhBoPA;AACA;AiBlPO,IAAe,qBAAA,aAAf,MAGP;AAAA,EACE,WAAA,CAAoB,OAAA,EAAyB;AAAzB,IAAA,IAAA,CAAA,QAAA,EAAA,OAAA;AAClB,IAAA,IAAA,CAAK,QAAA,EAAU,OAAA;AAAA,EACjB;AAAA,EAEA,IAAI,MAAA,CAAA,EAAS;AACX,IAAA,OAAO,IAAA,CAAK,OAAA;AAAA,EACd;AAAA,EAEA,IAAI,MAAA,CAAO,MAAA,EAAwB;AACjC,IAAA,IAAA,CAAK,QAAA,EAAU,MAAA;AACf,IAAA,IAAA,CAAK,mBAAA,CAAoB,CAAA;AAAA,EAC3B;AAAA,kBAOQ,eAAA,kBAAiB,IAAI,GAAA,CAAgB,EAAA;AAAA,EAEtC,SAAA,CAAU,QAAA,EAAmC;AAClD,IAAA,IAAA,CAAK,cAAA,CAAe,GAAA,CAAI,QAAQ,CAAA;AAChC,IAAA,OAAO,CAAA,EAAA,GAAM,IAAA,CAAK,cAAA,CAAe,MAAA,CAAO,QAAQ,CAAA;AAAA,EAClD;AAAA,kBAEQ,oBAAA,EAAsB,CAAA,EAAA,GAAM;AAClC,IAAA,IAAA,CAAA,MAAW,SAAA,GAAY,IAAA,CAAK,cAAA,EAAgB,QAAA,CAAS,CAAA;AAAA,EACvD,EAAA;AACF,WAAA;AjBwOA;AACA;AkB9QA,IAAA,iBAAA,EAAA,CAAA,CAAA;AAAA,uCAAA,gBAAA,EAAA;AAAA,EAAA,oBAAA,EAAA,CAAA,EAAA,GAAA,oBAAA;AAAA,EAAA,iBAAA,EAAA,CAAA,EAAA,GAAA,iBAAA;AAAA,EAAA,mBAAA,EAAA,CAAA,EAAA,GAAA,mBAAA;AAAA,EAAA,iBAAA,EAAA,CAAA,EAAA,GAAA,iBAAA;AAAA,EAAA,UAAA,EAAA,CAAA,EAAA,GAAA,UAAA;AAAA,EAAA,SAAA,EAAA,CAAA,EAAA,GAAA,SAAA;AAAA,EAAA,eAAA,EAAA,CAAA,EAAA,GAAA,eAAA;AAAA,EAAA,yBAAA,EAAA,CAAA,EAAA,GAAA;AAAA,CAAA,CAAA;AlB0RA;AACA;AmB3RA,8CAA+B;AAExB,IAAM,WAAA,EAAa,uCAAA;AAAA,EACxB,gEAAA;AAAA,EACA;AACF,CAAA;AAEA,IAAM,iBAAA,EAAmB,gBAAA;AAClB,IAAM,qBAAA,EAAuB,CAAA,EAAA,GAAM,CAAA,EAAA;AnB2RR;AACA;AoB3RhC;AAEoBI,EAAAA;AACtB;AAIE;AACkB,EAAA;AACa,EAAA;AAEb;AACE,EAAA;AAClB,IAAA;AACW,IAAA;AACb,EAAA;AAEqB,EAAA;AACP,EAAA;AACP,IAAA;AACI,MAAA;AACF,QAAA;AACH,QAAA;AACyB,QAAA;AACL,UAAA;AACT,YAAA;AACF,cAAA;AACY,cAAA;AACjB,YAAA;AACF,UAAA;AACO,UAAA;AACR,QAAA;AACD,QAAA;AACF,MAAA;AAEG,IAAA;AACI,MAAA;AACF,QAAA;AACH,QAAA;AACiB,QAAA;AACnB,MAAA;AAEG,IAAA;AACI,MAAA;AACF,QAAA;AACH,QAAA;AACiB,QAAA;AACnB,MAAA;AAEO,IAAA;AACwB,MAAA;AACf,MAAA;AAClB,IAAA;AACF,EAAA;AACF;ApBoRkC;AACA;AqB3TH;AACJ,EAAA;AACC,EAAA;AACnB,EAAA;AACT;AAE+B;AACN,kBAAA;AAA+B;AACb,kBAAA;AACR,kBAAA;AACpB,IAAA;AACL,IAAA;AACR,EAAA;AAKE,EAAA;AAE2B,IAAA;AACH,IAAA;AAEM,IAAA;AAGJ,IAAA;AAEA,MAAA;AACH,QAAA;AACrB,MAAA;AAG0B,MAAA;AACL,QAAA;AACF,QAAA;AACW,QAAA;AAChB,UAAA;AACR,YAAA;AACF,UAAA;AACF,QAAA;AACoB,QAAA;AACtB,MAAA;AACF,IAAA;AAGyB,IAAA;AAGmB,MAAA;AAIpB,QAAA;AACR,UAAA;AACR,YAAA;AACF,UAAA;AACF,QAAA;AACF,MAAA;AAG2B,MAAA;AACN,QAAA;AACL,QAAA;AAChB,MAAA;AAGwB,MAAA;AACC,QAAA;AACzB,MAAA;AAEa,MAAA;AACf,IAAA;AACF,EAAA;AACc,EAAA;AAC8B,IAAA;AACZ,IAAA;AACF,MAAA;AAC5B,IAAA;AACO,IAAA;AACT,EAAA;AAE4C,EAAA;AAChB,IAAA;AACG,IAAA;AAChB,IAAA;AACD,MAAA;AACR,QAAA;AACF,MAAA;AAGgB,IAAA;AACO,MAAA;AACF,MAAA;AACrB,MAAA;AACF,IAAA;AAGmC,IAAA;AACjC,MAAA;AACS,MAAA;AACH,MAAA;AACK,MAAA;AACgB,MAAA;AAC7B,IAAA;AAE8B,IAAA;AACA,IAAA;AAEN,IAAA;AACV,MAAA;AACd,IAAA;AACF,EAAA;AAE8B,EAAA;AACE,IAAA;AACzB,IAAA;AACO,MAAA;AACR,QAAA;AACF,MAAA;AAEK,IAAA;AACmB,MAAA;AACP,MAAA;AACnB,IAAA;AACF,EAAA;AAEwB,EAAA;AAClB,IAAA;AACD,IAAA;AACc,MAAA;AACU,IAAA;AAEtB,IAAA;AACH,MAAA;AACyB,MAAA;AACnB,QAAA;AACsB,QAAA;AAC3B,MAAA;AACH,IAAA;AAEO,IAAA;AACT,EAAA;AAEiC,EAAA;AACD,IAAA;AAEzB,IAAA;AACO,MAAA;AACR,QAAA;AACF,MAAA;AAGA,IAAA;AAKkB,IAAA;AACR,MAAA;AACR,QAAA;AACF,MAAA;AAE0B,IAAA;AACA,MAAA;AACrB,MAAA;AACO,QAAA;AACR,UAAA;AACF,QAAA;AAC0B,MAAA;AAC9B,IAAA;AAE8B,IAAA;AACA,IAAA;AAEH,IAAA;AACJ,MAAA;AACvB,IAAA;AACF,EAAA;AAE+B,EAAA;AACC,IAAA;AACzB,IAAA;AACO,MAAA;AACR,QAAA;AACF,MAAA;AAE2B,IAAA;AACtB,IAAA;AACT,EAAA;AAEkC,EAAA;AACF,IAAA;AACzB,IAAA;AACO,MAAA;AACR,QAAA;AACF,MAAA;AAEyB,IAAA;AACT,IAAA;AAEU,IAAA;AAC9B,EAAA;AAEoC,EAAA;AACV,IAAA;AACV,MAAA;AACZ,MAAA;AACF,IAAA;AAE8B,IAAA;AACzB,IAAA;AACO,MAAA;AACR,QAAA;AACF,MAAA;AAEU,IAAA;AAGV,IAAA;AAGkB,MAAA;AACI,QAAA;AACtB,MAAA;AACF,IAAA;AACF,EAAA;AAEoC,EAAA;AAC0B,IAAA;AAIlC,IAAA;AACP,MAAA;AACE,QAAA;AACO,QAAA;AACzB,MAAA;AACH,IAAA;AAEO,IAAA;AACsB,MAAA;AACjB,MAAA;AACZ,IAAA;AACF,EAAA;AAEwD,EAAA;AAChC,IAAA;AACI,MAAA;AAC1B,IAAA;AAGyB,IAAA;AAC3B,EAAA;AACF;ArB2PkC;AACA;AsBhhBL;AtBkhBK;AACA;AuBrhBlC;AACEH;AAEA;AAEAC;AACA;AACK;AAGgB;AA+BnB;AArBkBD;AAGpB;AAEwBD,EAAAA;AACfK,EAAAA;AACX;AAE+D;AAC9B,EAAA;AACJ,EAAA;AAET,EAAA;AACE,IAAA;AACpB,EAAA;AAGkB,EAAA;AAGf,EAAA;AAEL;AAGE;AAE4B,EAAA;AAEvB,IAAA;AAIJ,EAAA;AAC+B,EAAA;AACzB,EAAA;AACT;AAMiC;AACJ,EAAA;AACA,EAAA;AACf,IAAA;AACR,MAAA;AACF,IAAA;AACK,EAAA;AACT;AAEqC;AAC3BA,EAAAA;AACe,EAAA;AACzB;AvBofkC;AACA;AsBrjBH;AAEN;AAQb,EAAA;AADD,IAAA;AACC,IAAA;AACP,EAAA;AARuC,kBAAA;AACA,kBAAA;AAEd,kBAAA;AAOpB,EAAA;AACwB,IAAA;AACH,IAAA;AACd,IAAA;AACf,EAAA;AAEO,EAAA;AACyB,IAAA;AACF,MAAA;AACF,MAAA;AAC1B,IAAA;AACF,EAAA;AAEwB,mBAAA;AACO,IAAA;AACX,IAAA;AACE,IAAA;AAEQ,IAAA;AACC,IAAA;AAEZ,IAAA;AACO,IAAA;AACtB,MAAA;AACiB,MAAA;AACnB,IAAA;AAEmB,IAAA;AACO,MAAA;AACnB,IAAA;AACmB,MAAA;AAC1B,IAAA;AACsB,IAAA;AAEE,IAAA;AACtB,MAAA;AAC0B,MAAA;AAC5B,IAAA;AACsB,IAAA;AACO,IAAA;AAC/B,EAAA;AACF;AAEuD;AAC/C,EAAA;AACP;AAImB;AAEVA,EAAAA;AAEF,EAAA;AACS,IAAA;AACX,EAAA;AACmB,EAAA;AACQ,EAAA;AAER,EAAA;AACD,EAAA;AAEUC,EAAAA;AACT,IAAA;AAKTA,oBAAAA;AACb,EAAA;AAEqBC,EAAAA;AACS,IAAA;AAC/B,EAAA;AAEgB,EAAA;AACD,IAAA;AACM,MAAA;AACjB,MAAA;AACF,IAAA;AAE6B,IAAA;AACX,MAAA;AACJ,MAAA;AAEc,MAAA;AACD,MAAA;AACR,MAAA;AAEjB,MAAA;AACF,IAAA;AAEyB,IAAA;AACP,IAAA;AACU,EAAA;AAEd,EAAA;AACD,IAAA;AACM,MAAA;AACnB,IAAA;AACc,EAAA;AAET,EAAA;AAGC,IAAA;AAC8B,MAAA;AACX,MAAA;AAEnB,IAAA;AACkB,IAAA;AAC1B,EAAA;AACF;AtBshBkC;AACA;AwB7pBzBC;AxB+pByB;AACA;AyBhqBA;AzBkqBA;AACA;A0BrqBlC;AAIEA;AACK;AACgB;AAwBV;AArB6B;AACtC,EAAA;AACG,EAAA;AAES;AACL,EAAA;AACiB,IAAA;AACnB,IAAA;AACA,IAAA;AACL,EAAA;AACF;AAIA;AAGiB,EAAA;AACIA,EAAAA;AACH,IAAA;AACS,MAAA;AACf,MAAA;AACV,IAAA;AACF,EAAA;AAEE,EAAA;AAGK,EAAA;AACT;A1B0pBkC;AACA;AyBxrB5B;AAH+D;AAE/C,EAAA;AAItB;AAEsB;AAEyB;AAEa;AAC9C,EAAA;AACD,EAAA;AACZ;AAE4B;AzBsrBK;AACA;A2B9sBK;AACb;AACLA;AA8Bf;AA5BqB;AACf,EAAA;AACC,IAAA;AACE,MAAA;AACA,MAAA;AACF,MAAA;AACT,IAAA;AACM,IAAA;AACK,MAAA;AACH,MAAA;AACR,IAAA;AACF,EAAA;AACiB,EAAA;AACN,IAAA;AACH,IAAA;AACR,EAAA;AACD;AAScA;AACmB,EAAA;AAE5BC,IAAAA;AAAW,MAAA;AAAV,MAAA;AAC2B,QAAA;AACtB,QAAA;AACJ,QAAA;AAAA,MAAA;AACF,IAAA;AAEJ,EAAA;AACF;AAEqB;A3BwsBa;AACA;AwBhuB1B;AAPyBD;AAK5B,EAAA;AACE,oBAAA;AAEI,MAAA;AACA,sBAAA;AAEL,IAAA;AACC,oBAAA;AACH,EAAA;AAEH;AAE+B;AxBkuBE;AACA;A4BvvBhC;AAGiC,EAAA;AAEL,EAAA;AACH,IAAA;AACT,IAAA;AACG,MAAA;AACC,QAAA;AACN,UAAA;AACG,UAAA;AACP,YAAA;AACQ,cAAA;AACU,cAAA;AAClB,YAAA;AACF,UAAA;AACD,QAAA;AACD,QAAA;AACF,MAAA;AACa,MAAA;AACG,QAAA;AACN,UAAA;AACa,UAAA;AACC,YAAA;AACJ,YAAA;AACC,cAAA;AACJ,gBAAA;AACC,kBAAA;AACK,kBAAA;AACb,gBAAA;AACF,cAAA;AACc,cAAA;AACH,gBAAA;AACA,kBAAA;AACC,oBAAA;AACM,oBAAA;AACd,kBAAA;AACF,gBAAA;AACgB,gBAAA;AAClB,cAAA;AACS,cAAA;AACD,gBAAA;AACU,gBAAA;AAClB,cAAA;AACF,YAAA;AACD,UAAA;AACF,QAAA;AACD,QAAA;AACF,MAAA;AACkB,MAAA;AACG,QAAA;AACC,UAAA;AACT,YAAA;AACC,cAAA;AACW,cAAA;AACF,cAAA;AACA,cAAA;AACJ,cAAA;AACb,YAAA;AACF,UAAA;AACO,UAAA;AACR,QAAA;AAEoB,QAAA;AACK,UAAA;AACH,UAAA;AACH,YAAA;AAChB,YAAA;AACF,UAAA;AACF,QAAA;AAEc,QAAA;AACN,UAAA;AACG,UAAA;AACV,QAAA;AACD,QAAA;AACF,MAAA;AACa,MAAA;AACa,QAAA;AACH,QAAA;AACT,UAAA;AACR,YAAA;AACF,UAAA;AAEiB,QAAA;AACA,UAAA;AAEF,YAAA;AACf,UAAA;AACK,UAAA;AACa,YAAA;AACL,UAAA;AACK,YAAA;AAEK,UAAA;AACL,UAAA;AACG,YAAA;AACrB,UAAA;AACF,QAAA;AAEA,QAAA;AACF,MAAA;AAES,MAAA;AACsB,QAAA;AACb,QAAA;AAClB,MAAA;AACF,IAAA;AACF,EAAA;AAEO,EAAA;AACT;A5B8uBkC;AACA;A6Bn2BhC;AAEc,EAAA;AACQ,IAAA;AACb,MAAA;AACL,MAAA;AACoB,QAAA;AACD,QAAA;AACnB,MAAA;AACD,IAAA;AACH,EAAA;AACF;A7Bo2BkC;AACA;A8Bp3BE;AACrB,EAAA;AAEc,EAAA;AACI,IAAA;AACjB,MAAA;AACiB,MAAA;AAGD,MAAA;AACE,QAAA;AAC5B,MAAA;AAGqB,MAAA;AACvB,IAAA;AACkB,IAAA;AAEJ,MAAA;AACe,QAAA;AAC3B,MAAA;AACF,IAAA;AACD,EAAA;AACH;A9Bg3BkC;AACA;A+Bl4Bd;AACY,EAAA;AACF,EAAA;AACrB,EAAA;AACoB,IAAA;AACI,IAAA;AAC/B,EAAA;AACF;AAEgB;AACW,EAAA;AACM,IAAA;AACR,MAAA;AACrB,IAAA;AACD,EAAA;AAEU,EAAA;AAEM,IAAA;AAGhB,EAAA;AACH;A/B+3BkC;AACA;AgCp5BP;AACzB,EAAA;AACA,EAAA;AACF;AhCs5BkC;AACA;AiCj6BzBD;AjCm6ByB;AACA;AkC95BO;AACjB,EAAA;AAClB,EAAA;AAOF,EAAA;AAC2B,IAAA;AAGvB,MAAA;AAGmB,QAAA;AACX,UAAA;AACQ,UAAA;AACF,UAAA;AACF,UAAA;AACY,UAAA;AACvB,QAAA;AACiB,QAAA;AACpB,MAAA;AAEc,MAAA;AAC6B,QAAA;AACpB,UAAA;AACX,YAAA;AACK,YAAA;AACZ,UAAA;AACD,UAAA;AACF,QAAA;AACA,QAAA;AACuB,UAAA;AACC,UAAA;AACE,UAAA;AACxB,UAAA;AACF,QAAA;AACA,QAAA;AACgB,UAAA;AACG,UAAA;AACE,UAAA;AACX,YAAA;AACQ,YAAA;AACF,YAAA;AACF,YAAA;AACK,YAAA;AAChB,UAAA;AACD,UAAA;AACF,QAAA;AACA,QAAA;AACqB,UAAA;AACX,YAAA;AACQ,YAAA;AACI,YAAA;AACR,YAAA;AACI,YAAA;AACf,UAAA;AACD,UAAA;AACF,QAAA;AACsC,QAAA;AACjB,UAAA;AACX,YAAA;AACH,YAAA;AACJ,UAAA;AACD,UAAA;AACF,QAAA;AACqC,QAAA;AAChB,UAAA;AACX,YAAA;AACC,YAAA;AACR,UAAA;AACD,UAAA;AACF,QAAA;AACS,QAAA;AACsB,UAAA;AACb,UAAA;AAClB,QAAA;AACF,MAAA;AACF,IAAA;AACD,EAAA;AACH;AlCq5BkC;AACA;AmCp+Bd;AACX,EAAA;AACyB,IAAA;AACN,MAAA;AACf,MAAA;AAC+C,QAAA;AAC1B,UAAA;AAEZ,UAAA;AAEd,QAAA;AACF,MAAA;AACF,IAAA;AACF,EAAA;AACF;AASyD;AACF,EAAA;AAAjC,IAAA;AAAkC,EAAA;AAE/B,EAAA;AACO,IAAA;AACA,IAAA;AAED,IAAA;AACjB,MAAA;AACR,MAAA;AAC0B,MAAA;AACL,MAAA;AACJ,QAAA;AACU,QAAA;AACH,QAAA;AACZ,QAAA;AACA,QAAA;AAEM,QAAA;AACmB,MAAA;AAC7B,MAAA;AACT,IAAA;AAE0B,IAAA;AACC,MAAA;AAC5B,IAAA;AAGS,IAAA;AAKL,IAAA;AACiB,IAAA;AACb,MAAA;AACR,IAAA;AAEe,IAAA;AACG,MAAA;AACpB,EAAA;AACF;AnCm9BkC;AACA;AiC1hCH;AAC7B,EAAA;AACA,EAAA;AACA,EAAA;AACG,EAAA;AACqB;AACG,EAAA;AACK,EAAA;AAC9B,IAAA;AACA,IAAA;AACA,IAAA;AACD,EAAA;AACH;AjC4hCkC;AACA;AoC5iChC;ApC8iCgC;AACA;AqC9hCuB;AA+B9C,EAAA;AADC,IAAA;AACD,IAAA;AAGQ,IAAA;AACM,IAAA;AACW,MAAA;AACb,MAAA;AACK,MAAA;AACJ,QAAA;AACG,QAAA;AACrB,MAAA;AACF,IAAA;AACF,EAAA;AA1CyB,mBAAA;AAEyB,mBAAA;AAChB,mBAAA;AAEH,mBAAA;AACb,IAAA;AACV,IAAA;AACE,IAAA;AACA,IAAA;AACO,IAAA;AACR,IAAA;AACT,EAAA;AAE6B,mBAAA;AAEP,EAAA;AACG,IAAA;AACzB,EAAA;AAE2B,mBAAA;AACnB,IAAA;AACsB,IAAA;AACL,MAAA;AACE,MAAA;AACzB,IAAA;AACF,EAAA;AAkBQ,EAAA;AAEa,EAAA;AACP,IAAA;AACd,EAAA;AAEsC,EAAA;AACpB,IAAA;AAES,IAAA;AACH,IAAA;AACM,MAAA;AACH,MAAA;AACzB,IAAA;AACF,EAAA;AAEgD,EAAA;AACvB,IAAA;AACzB,EAAA;AAE8C,EAAA;AAC5B,IAAA;AACO,IAAA;AACzB,EAAA;AAE2D,EAAA;AACpC,IAAA;AACT,MAAA;AACR,QAAA;AACF,MAAA;AAGoB,IAAA;AACiB,IAAA;AACjC,MAAA;AACE,MAAA;AACW,MAAA;AACN,MAAA;AACb,IAAA;AACgB,IAAA;AAEI,IAAA;AACtB,EAAA;AAE8D,EAAA;AAClC,IAAA;AAGJ,IAAA;AACgB,IAAA;AACpC,MAAA;AACM,MAAA;AACoB,MAAA;AAChB,MAAA;AACC,MAAA;AACb,IAAA;AAEG,IAAA;AACoB,MAAA;AACC,IAAA;AAC1B,EAAA;AAGE,EAAA;AAGsB,IAAA;AAGM,oBAAA;AACD,IAAA;AAEJ,IAAA;AACG,IAAA;AACG,IAAA;AAC6B,IAAA;AAC9C,MAAA;AACL,QAAA;AAEY,QAAA;AAEK,QAAA;AAAQ;AAEZ,QAAA;AAEE,UAAA;AACN,YAAA;AACU,YAAA;AAChB,UAAA;AAEF,QAAA;AAEA,QAAA;AACY,UAAA;AACG,YAAA;AACI,YAAA;AAEG,cAAA;AACN,gBAAA;AACU,gBAAA;AAChB,cAAA;AAEF,YAAA;AACY,YAAA;AAEI,cAAA;AAEhB,YAAA;AACN,UAAA;AAEF,QAAA;AACN,MAAA;AACgB,MAAA;AACO,MAAA;AACzB,IAAA;AAE0B,IAAA;AACH,IAAA;AACF,IAAA;AAEL,MAAA;AACJ,QAAA;AACA,UAAA;AACE,UAAA;AACV,QAAA;AACD,MAAA;AACM,MAAA;AACF,IAAA;AACS,MAAA;AACJ,QAAA;AACA,UAAA;AACR,QAAA;AACD,MAAA;AACH,IAAA;AAEI,IAAA;AACyB,MAAA;AACzB,QAAA;AACkB,QAAA;AACL,QAAA;AACH,QAAA;AACX,MAAA;AAG2B,MAAA;AACJ,QAAA;AACL,UAAA;AACjB,QAAA;AACK,MAAA;AACe,QAAA;AACtB,MAAA;AAEuB,MAAA;AAEK,MAAA;AACZ,QAAA;AACI,UAAA;AACjB,QAAA;AACH,MAAA;AACU,IAAA;AACa,MAAA;AAGK,MAAA;AACZ,QAAA;AACI,UAAA;AACjB,QAAA;AACI,MAAA;AACS,QAAA;AACI,UAAA;AACjB,QAAA;AAEK,QAAA;AACR,MAAA;AACF,IAAA;AACO,IAAA;AACT,EAAA;AAEkB,EAAA;AACW,IAAA;AAEA,IAAA;AACJ,IAAA;AACzB,EAAA;AAE4B,EAAA;AACE,IAAA;AAC9B,EAAA;AAEoD,EAAA;AAC1B,IAAA;AACN,IAAA;AACpB,EAAA;AAEqB,EAAA;AACnB,IAAA;AACA,IAAA;AACA,IAAA;AACuB,EAAA;AACK,IAAA;AAEP,IAAA;AACH,MAAA;AAEN,IAAA;AACA,IAAA;AACe,IAAA;AACG,MAAA;AACP,MAAA;AACb,MAAA;AACe,MAAA;AAChB,MAAA;AACF,QAAA;AACH,QAAA;AACF,MAAA;AACD,IAAA;AAEI,IAAA;AACa,MAAA;AAER,IAAA;AACL,MAAA;AACM,MAAA;AACX,IAAA;AACgB,IAAA;AAEY,IAAA;AACJ,MAAA;AACxB,IAAA;AACF,EAAA;AAAA;AAGQ,EAAA;AAEwB,EAAA;AACD,IAAA;AACC,IAAA;AAEL,IAAA;AAEJ,IAAA;AACI,MAAA;AACL,MAAA;AACpB,IAAA;AAE0B,IAAA;AACJ,IAAA;AACI,MAAA;AACJ,QAAA;AACpB,MAAA;AACD,IAAA;AACiB,IAAA;AAEN,IAAA;AACd,EAAA;AAEgB,EAAA;AACgB,IAAA;AAChC,EAAA;AAE+C,EAAA;AAClB,IAAA;AACJ,IAAA;AACzB,EAAA;AACF;ArC69BkC;AACA;AsC9xCA;AACf,EAAA;AAEoD,EAAA;AACvC,IAAA;AACC,IAAA;AACD,IAAA;AAC9B,EAAA;AAE8C,EAAA;AACtB,IAAA;AACxB,EAAA;AAEiD,EAAA;AACzB,IAAA;AACxB,EAAA;AAE4B,EAAA;AACd,IAAA;AACd,EAAA;AAE+C,EAAA;AAC/B,IAAA;AACI,MAAA;AAClB,IAAA;AAE4B,IAAA;AAEF,IAAA;AACnB,MAAA;AACO,MAAA;AACZ,MAAA;AACF,IAAA;AACF,EAAA;AAEa,EAAA;AACX,IAAA;AAGM,EAAA;AACkB,IAAA;AACF,IAAA;AAEL,IAAA;AACE,IAAA;AACU,MAAA;AACC,QAAA;AACjB,QAAA;AACT,MAAA;AACH,IAAA;AACH,EAAA;AACF;AtCqxCkC;AACA;AgBz0ChC;AAE2B,EAAA;AAEF,EAAA;AACL,IAAA;AACA,IAAA;AACnB,EAAA;AAEM,EAAA;AACT;AhBw0CkC;AACA;AuC11CO;AAMG;AACQ,EAAA;AACpD;AvCu1CkC;AACA;AwC11C3B;AACwB,mBAAA;AAI3B,EAAA;AAEwB,IAAA;AACI,MAAA;AACP,MAAA;AACS,MAAA;AACrB,MAAA;AACR,IAAA;AACH,EAAA;AACF;AxCw1CkC;AACA;AyC72CC;AACC;AAC5B,EAAA;AACE,EAAA;AACT;AAGC;AAE6C;AzC42Cb;AACA;A0C11ChC;AAI2B,EAAA;AACZ,EAAA;AACH,IAAA;AACc,IAAA;AAC1B,EAAA;AACc,EAAA;AACP,IAAA;AACI,MAAA;AACF,QAAA;AACH,QAAA;AACsB,QAAA;AACF,UAAA;AACJ,UAAA;AACP,YAAA;AACA,YAAA;AACI,cAAA;AAES,YAAA;AACE,cAAA;AACX,cAAA;AACF,gBAAA;AACY,gBAAA;AACjB,cAAA;AACF,YAAA;AAES,YAAA;AACD,cAAA;AACU,cAAA;AAClB,YAAA;AACF,UAAA;AACD,QAAA;AACiB,QAAA;AACpB,MAAA;AAEG,IAAA;AACI,MAAA;AACF,QAAA;AACH,QAAA;AACsB,QAAA;AACF,UAAA;AACJ,UAAA;AACP,YAAA;AACA,YAAA;AACA,YAAA;AACI,cAAA;AAEA,YAAA;AACD,cAAA;AACU,cAAA;AAClB,YAAA;AACF,UAAA;AACD,QAAA;AACH,MAAA;AAEG,IAAA;AACyB,MAAA;AAChB,QAAA;AACR,UAAA;AACF,QAAA;AAEK,MAAA;AACF,QAAA;AACH,QAAA;AACA,QAAA;AACF,MAAA;AAEO,IAAA;AACwB,MAAA;AACf,MAAA;AAClB,IAAA;AACF,EAAA;AACF;A1Ck1CkC;AACA;A2C17CG;AACT,EAAA;AACA,IAAA;AAC1B,EAAA;AAE+B,EAAA;AACjC;A3C27CkC;AACA;A4Cp7ChC;AAG6B,EAAA;AAC/B;AAEO;AACoB,mBAAA;AACA,mBAAA;AACsB,mBAAA;AAEF,mBAAA;AAC3B,IAAA;AACV,IAAA;AACE,IAAA;AACA,IAAA;AACO,IAAA;AACR,IAAA;AACT,EAAA;AAE0B,EAAA;AACZ,IAAA;AACd,EAAA;AAEoC,mBAAA;AAChB,mBAAA;AACG,mBAAA;AAEf,EAAA;AAEmB,mBAAA;AACnB,IAAA;AACsB,IAAA;AACL,MAAA;AACE,MAAA;AACzB,IAAA;AACF,EAAA;AAE8C,EAAA;AAC/B,IAAA;AACf,EAAA;AAEmD,EAAA;AACtB,IAAA;AAEH,IAAA;AACA,IAAA;AAEF,IAAA;AACR,IAAA;AACO,IAAA;AACS,MAAA;AACV,MAAA;AACE,MAAA;AACA,MAAA;AACO,MAAA;AACR,MAAA;AACrB,IAAA;AAEc,IAAA;AAEC,MAAA;AACU,QAAA;AAEZ,MAAA;AAGc,QAAA;AAEvB,QAAA;AACF,MAAA;AACF,IAAA;AAEwB,IAAA;AAGS,MAAA;AAEJ,MAAA;AACJ,MAAA;AAIV,MAAA;AAIA,QAAA;AAEU,MAAA;AACO,QAAA;AACX,QAAA;AACb,QAAA;AACF,MAAA;AACoB,MAAA;AACb,MAAA;AACR,IAAA;AAEwB,IAAA;AACD,MAAA;AACE,MAAA;AACZ,MAAA;AAClB,IAAA;AAES,IAAA;AACS,MAAA;AACX,MAAA;AACP,IAAA;AAEuB,IAAA;AAChB,MAAA;AACoB,yCAAA;AACvB,QAAA;AACQ,UAAA;AACI,UAAA;AACZ,QAAA;AACF,MAAA;AACF,IAAA;AAEgB,IAAA;AACT,wCAAA;AACP,IAAA;AAEqB,IAAA;AACE,IAAA;AACzB,EAAA;AAE4B,EAAA;AACE,IAAA;AAC9B,EAAA;AAEgD,EAAA;AACvB,IAAA;AACzB,EAAA;AAE8C,EAAA;AAC3B,IAAA;AACC,MAAA;AAEF,IAAA;AACS,IAAA;AAC3B,EAAA;AAE2D,EAAA;AAC/B,IAAA;AACP,MAAA;AACC,QAAA;AACO,MAAA;AACpB,IAAA;AACmB,MAAA;AAC1B,IAAA;AACF,EAAA;AAE8D,EAAA;AAC3C,IAAA;AACC,MAAA;AAES,IAAA;AAC7B,EAAA;AAEyB,EAAA;AACN,IAAA;AACC,MAAA;AAEG,IAAA;AAEZ,IAAA;AACS,MAAA;AACX,MAAA;AACP,IAAA;AAEoB,IAAA;AACI,IAAA;AAEI,IAAA;AAGV,MAAA;AACQ,MAAA;AACA,QAAA;AACxB,MAAA;AAE2B,MAAA;AACtB,IAAA;AACkB,MAAA;AACzB,IAAA;AAGiB,IAAA;AACa,MAAA;AAC1B,IAAA;AACN,EAAA;AAEoD,EAAA;AACjC,IAAA;AACC,MAAA;AACU,IAAA;AAC9B,EAAA;AAEgC,EAAA;AACb,IAAA;AACC,MAAA;AAEO,IAAA;AACE,IAAA;AAC7B,EAAA;AAEoD,EAAA;AAC1B,IAAA;AACN,IAAA;AACpB,EAAA;AAEwD,mBAAA;AAC1C,oBAAA;AACO,MAAA;AACnB,IAAA;AACF,EAAA;AACF;A5C83CkC;AACA;A6CnmD3B;AACuC,mBAAA;AAEE,EAAA;AAClC,IAAA;AACZ,EAAA;AAEmD,EAAA;AAC7B,IAAA;AACtB,EAAA;AAEwB,EAAA;AACV,IAAA;AACd,EAAA;AAEmC,EAAA;AACrB,IAAA;AACd,EAAA;AAEqD,EAAA;AACrC,IAAA;AACI,MAAA;AACE,QAAA;AAEA,MAAA;AACL,QAAA;AACO,QAAA;AACnB,MAAA;AACyB,MAAA;AACrB,IAAA;AACW,MAAA;AACE,QAAA;AAEA,MAAA;AACL,QAAA;AACO,QAAA;AACnB,MAAA;AACgB,MAAA;AACnB,IAAA;AACF,EAAA;AACF;A7C8lDkC;AACA;A8C5oDd;AAIwB;AACf,EAAA;AAEX,EAAA;AACE,IAAA;AACjB,EAAA;AAEM,EAAA;AACT;A9CyoDkC;AACA;A+CrpDzBA;A/CupDyB;AACA;AgD3oD3B;AAC0D,EAAA;AAA3C,IAAA;AAA4C,EAAA;AAEzC,EAAA;AACH,IAAA;AACF,MAAA;AACd,MAAA;AACa,MAAA;AACI,QAAA;AACU,QAAA;AACH,QAAA;AACZ,QAAA;AACA,QAAA;AACZ,MAAA;AACD,IAAA;AAGE,IAAA;AAGwB,IAAA;AACnB,MAAA;AACR,IAAA;AACF,EAAA;AACF;AhD0oDkC;AACA;A+CvqDrB;AACX,EAAA;AACG,EAAA;AACmC;AACX,EAAA;AACK,EAAA;AAClC;A/CyqDkC;AACA;AiDtrD3B;AAC2D,EAAA;AACjD,IAAA;AACS,IAAA;AAEF,IAAA;AAGlB,IAAA;AAEwB,MAAA;AAEH,MAAA;AACA,MAAA;AACvB,IAAA;AAE2B,IAAA;AACA,IAAA;AAEE,IAAA;AAEiB,IAAA;AAClB,MAAA;AACZ,MAAA;AACW,QAAA;AACF,QAAA;AACvB,MAAA;AACqB,MAAA;AACK,QAAA;AACN,UAAA;AACK,UAAA;AACH,YAAA;AACjB,UAAA;AACY,UAAA;AACC,YAAA;AACd,UAAA;AACK,QAAA;AACmB,UAAA;AACX,UAAA;AACQ,YAAA;AACrB,UAAA;AACF,QAAA;AACF,MAAA;AACF,IAAA;AACO,IAAA;AACT,EAAA;AACF;AjDgrDkC;AACA;AOvnD9BG;AA/EuE;AACzE,EAAA;AACA,EAAA;AACI;AAC2C,EAAA;AACpB,IAAA;AACP,IAAA;AACQ,IAAA;AACD,IAAA;AACL,IAAA;AACA,IAAA;AAEb,IAAA;AACL,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACF,IAAA;AACD,EAAA;AAGe,EAAA;AACe,IAAA;AACH,MAAA;AAEC,MAAA;AACX,MAAA;AAEY,MAAA;AAGE,MAAA;AAE8B,QAAA;AACtD,UAAA;AACA,UAAA;AACF,QAAA;AACF,MAAA;AAEwB,MAAA;AAGpB,QAAA;AACJ,MAAA;AAEsB,MAAA;AAEJ,MAAA;AAG4C,QAAA;AACpC,UAAA;AACL,UAAA;AAClB,QAAA;AACH,MAAA;AACF,IAAA;AAEe,IAAA;AACc,IAAA;AACT,EAAA;AAEtBC,EAAAA;AAEuB,IAAA;AAGf,MAAA;AACH,IAAA;AACe,IAAA;AACpB,EAAA;AAG6B,EAAA;AACM,IAAA;AACnC,EAAA;AAGG,EAAA;AACkB,IAAA;AAChB,IAAA;AACH,EAAA;AAEJ;APgrDkC;AACA;AkDlyDzBX;AAUP;AAGgB,EAAA;AACU,IAAA;AACO,IAAA;AAC9B,EAAA;AACH;AlDyxDgC;AACA;AmD3yDzBA;AAKiC;AACU,EAAA;AACpD;AnDyyDkC;AACA;AExvD5B;AAnCC;AACqB,EAAA;AACD,EAAA;AACF,IAAA;AACtB,EAAA;AAE0B,EAAA;AACG,IAAA;AACL,IAAA;AACJ,IAAA;AACS,IAAA;AAErB,IAAA;AACL,MAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACF,IAAA;AACD,EAAA;AAE8B,EAAA;AACf,EAAA;AACC,IAAA;AACW,EAAA;AAE5BY,EAAAA;AAGc,IAAA;AAEK,IAAA;AACnB,EAAA;AAGG,EAAA;AAIL;AFkxDkC;AACA;ACn0DzB;AAHH;AAGI,EAAA;AACV;AAEwC;ADs0DN;AACA;AoDt1DzBC;ApDw1DyB;AACA;AqDv1DzBZ;AAYqBA;AAMI;AACL,EAAA;AACA,EAAA;AACf,IAAA;AACR,MAAA;AACF,IAAA;AACK,EAAA;AACT;ArDy0DkC;AACA;AoDz1D4B;AACpC,EAAA;AACI,EAAA;AACrBY,EAAAA;AACE,IAAA;AACS,MAAA;AAGW,MAAA;AAC3B,IAAA;AAC6B,IAAA;AAC/B,EAAA;AACF;ApDy1DkC;AACA;AsDh3DzBZ;AAQyBA;AAChC,EAAA;AACF;AAMsC;AACT,EAAA;AACA,EAAA;AACf,IAAA;AACR,MAAA;AACF,IAAA;AACK,EAAA;AACT;AtDs2DkC;AACA;AuDh4DN;AAa1B;AAGuB,EAAA;AACd,IAAA;AACuB,MAAA;AACtB,MAAA;AACoB,MAAA;AAC5B,IAAA;AACF,EAAA;AAEO,EAAA;AAEiB,IAAA;AACA,IAAA;AACL,IAAA;AACnB,EAAA;AACF;AAEsC;AACT,EAAA;AAGZ,EAAA;AACqB,IAAA;AACV,MAAA;AACM,MAAA;AAEL,MAAA;AACA,MAAA;AACzB,IAAA;AACoB,IAAA;AACtB,EAAA;AAEO,EAAA;AACT;AvD62DkC;AACA;AwD95DzBa;AAGiC;AACR,EAAA;AACR,EAAA;AAEEA,EAAAA;AACK,IAAA;AACA,IAAA;AACN,EAAA;AAElB,EAAA;AACT;AxD45DkC;AACA;AyDx6DzBF;AAkBJ;AACqB,EAAA;AAClB,EAAA;AACK,IAAA;AACX,EAAA;AAC8B,EAAA;AACd,EAAA;AACe,IAAA;AACd,IAAA;AACN,MAAA;AACY,QAAA;AACnB,MAAA;AACF,IAAA;AACe,IAAA;AACS,MAAA;AACvB,IAAA;AACuB,IAAA;AACX,IAAA;AACJ,MAAA;AACE,sBAAA;AACX,IAAA;AACE,EAAA;AACN;AzDy5DkC;AACA;A0D57D7B;AACgB,EAAA;AACI,IAAA;AACd,IAAA;AACT,EAAA;AACO,EAAA;AACT;A1D87DkC;AACA;A2D38DzBA;AAaP;AAEuB,EAAA;AACO,EAAA;AACd,EAAA;AACH,IAAA;AACkB,IAAA;AACF,IAAA;AACT,EAAA;AACtB;A3Dg8DkC;AACA;A4D/8DhC;AAEqB,EAAA;AACI,IAAA;AAChB,IAAA;AACT,EAAA;AACO,EAAA;AACT;A5Dg9DkC;AACA;A6Dh+DzBA;AAGgC;AACZ,EAAA;AACrB,EAAA;AACK,IAAA;AACX,EAAA;AACgB,EAAA;AACC,IAAA;AACL,MAAA;AACV,IAAA;AACO,IAAA;AACL,EAAA;AACN;A7Dg+DkC;AACA;A8Dj/DzBE;A9Dm/DyB;AACA;A+Dp/DzBD;A/Ds/DyB;AACA;AgEr/DzB;AAMwD;AAGN,EAAA;AAC3B,IAAA;AACf,IAAA;AACS,MAAA;AACZ,QAAA;AACR,MAAA;AACF,IAAA;AACF,EAAA;AAEgD,EAAA;AAE5C,IAAA;AAE0B,IAAA;AAC9B,EAAA;AACF;AhE6+DkC;AACA;A+D//DhC;AAG4B,EAAA;AACD,EAAA;AAC7B;A/D+/DkC;AACA;A8DrgED;AACd,EAAA;AACe;AACZ,EAAA;AAEO,EAAA;AACG,IAAA;AACR,IAAA;AAGf,MAAA;AAGL,IAAA;AACF,EAAA;AAE6B,EAAA;AACP,IAAA;AACI,IAAA;AACC,IAAA;AAEL,IAAA;AAIU,IAAA;AACZ,MAAA;AACC,MAAA;AAClB,IAAA;AACa,EAAA;AAEgB,EAAA;AACzB,EAAA;AACT;A9D4/DkC;AACA;AiEviEzBC;AAI6B;AAChB,EAAA;AAEH,EAAA;AACa,IAAA;AACC,IAAA;AAC/B,EAAA;AAE6B,EAAA;AACV,IAAA;AACZ,IAAA;AACa,EAAA;AAEC,EAAA;AACd,EAAA;AACT;AjEmiEkC;AACA;AkEvjEzBA;AAK+B;AACnB,EAAA;AAEI,EAAA;AAEN,EAAA;AACO,IAAA;AACK,IAAA;AAC7B,EAAA;AAE6B,EAAA;AACN,IAAA;AACO,IAAA;AACL,IAAA;AACM,IAAA;AACT,EAAA;AAED,EAAA;AACd,EAAA;AACT;AlEijEkC;AACA;AmE1kEzBA;AAK8B;AACR,EAAA;AACT,EAAA;AAEQ,EAAA;AACE,IAAA;AACR,IAAA;AAGf,MAAA;AAGL,IAAA;AACF,EAAA;AAE6B,EAAA;AACP,IAAA;AACS,IAAA;AACF,IAAA;AACP,EAAA;AAEI,EAAA;AACnB,EAAA;AACT;AnEikEkC;AACA;AoE9lEzBA;AAG+B;AACV,EAAA;AAET,EAAA;AAEU,EAAA;AACA,IAAA;AACT,EAAA;AAEI,EAAA;AAEjB,EAAA;AACT;ApE0lEkC;AACA;AqEvmEQ;AACjB,EAAA;AACS,EAAA;AACzB,EAAA;AACT;ArEymEkC;AACA;AsEjnEzBA;AAKgC;AACV,EAAA;AACT,EAAA;AAEH,EAAA;AACa,IAAA;AAET,IAAA;AACrB,EAAA;AAE6B,EAAA;AACG,IAAA;AAG3B,IAAA;AAC2B,EAAA;AAEX,EAAA;AACd,EAAA;AACT;AtEymEkC;AACA;AuE/nES;AAClB,EAAA;AACO,EAAA;AACX,EAAA;AACrB;AvEioEkC;AACA;AwEzoEzBA;AAK8B;AACR,EAAA;AACT,EAAA;AAEH,EAAA;AACa,IAAA;AACD,IAAA;AAC7B,EAAA;AAE6B,EAAA;AACG,IAAA;AAG3B,IAAA;AAC2B,EAAA;AAEX,EAAA;AACd,EAAA;AACT;AxEkoEkC;AACA;AyE1pEzBA;AAG8B;AACb,EAAA;AAEM,EAAA;AAED,EAAA;AACR,IAAA;AACZ,IAAA;AACO,EAAA;AAEK,EAAA;AACd,EAAA;AACT;AzEupEkC;AACA;A0E7pE0B;AAClC,EAAA;AACJ,EAAA;AACY,IAAA;AACR,IAAA;AAEf,IAAA;AACR,EAAA;AACH;A1E8pEkC;AACA;A2EjrEzBA;AAI4B;AAC7B,EAAA;AACJ,IAAA;AACA,IAAA;AACa,IAAA;AACM,EAAA;AACG,EAAA;AAEP,EAAA;AACQ,IAAA;AACK,IAAA;AAC9B,EAAA;AAE6B,EAAA;AACL,IAAA;AACQ,IAAA;AAEX,IAAA;AAEI,IAAA;AACG,IAAA;AACR,EAAA;AAEC,EAAA;AACd,EAAA;AACT;A3E2qEkC;AACA;A4EtsES;AACd,EAAA;AAEK,EAAA;AACV,IAAA;AACR,MAAA;AACR,QAAA;AACF,MAAA;AAEK,IAAA;AACR,EAAA;AAEM,EAAA;AACT;A5EqsEkC;AACA;A6EntEO;AACZ,EAAA;AAEG,EAAA;AACR,IAAA;AACR,MAAA;AACR,QAAA;AACF,MAAA;AAEK,IAAA;AACR,EAAA;AAEM,EAAA;AACT;A7EktEkC;AACA;A8EhuEM;AACX,EAAA;AAEE,EAAA;AACP,IAAA;AACR,MAAA;AACR,QAAA;AACF,MAAA;AAEK,IAAA;AACR,EAAA;AAEM,EAAA;AACT;A9E+tEkC;AACA;A+EhuEwB;AACpC,EAAA;AAEb,EAAA;AACuB,IAAA;AACC,IAAA;AACD,MAAA;AAEA,MAAA;AACH,MAAA;AACK,MAAA;AAEF,MAAA;AAEL,MAAA;AACA,MAAA;AAEE,MAAA;AACA,MAAA;AAEhB,MAAA;AACT,IAAA;AACF,EAAA;AACF;A/E4tEkC;AACA;AgFtvEsB;AACnC,EAAA;AACZ,EAAA;AACwB,IAAA;AACP,IAAA;AACQ,MAAA;AACR,MAAA;AACE,MAAA;AACA,MAAA;AACC,MAAA;AACA,MAAA;AAEhB,MAAA;AACT,IAAA;AACF,EAAA;AACF;AhFuvEkC;AACA;AiFnxEE;AACN,EAAA;AAC9B;AjFqxEkC;AACA;AkF1xEzBA;AAG8B;AAChB,EAAA;AAEW,EAAA;AAEHA,EAAAA;AACJ,IAAA;AACM,IAAA;AACF,EAAA;AAEN,EAAA;AAChB,EAAA;AACT;AlFuxEkC;AACA;AmFvyEzBA;AAU2B;AAClC,EAAA;AACA,EAAA;AACmC;AACJ,EAAA;AAEC,EAAA;AACJ,EAAA;AACC,EAAA;AACF,IAAA;AACI,IAAA;AACL,IAAA;AACT,MAAA;AACM,MAAA;AACd,IAAA;AACkB,MAAA;AACzB,IAAA;AAC0B,EAAA;AAEP,EAAA;AACd,EAAA;AACT;AnF8xEkC;AACA;AoF9zElC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;ApFw0EkC;AACA;AqFv0EzBC;AACiBP;ArFy0EQ;AACA;AsF5zEM;AACtC,EAAA;AACA,EAAA;AACA,EAAA;AACkC;AACZ,EAAA;AACF,EAAA;AAEb,EAAA;AACmB,IAAA;AACV,IAAA;AACa,MAAA;AAGvB,MAAA;AAGoB,MAAA;AAGK,MAAA;AAIP,MAAA;AAGX,QAAA;AAEF,MAAA;AACT,IAAA;AACF,EAAA;AACF;AtFizEkC;AACA;AqFt0E9B;AAbkCA;AAIT,EAAA;AACzB,IAAA;AACA,IAAA;AACA,IAAA;AACD,EAAA;AAEG,EAAA;AAGFC,EAAAA;AAAW,IAAA;AAAV,IAAA;AACM,MAAA;AAGD,MAAA;AACJ,MAAA;AAAA,IAAA;AACF,EAAA;AAEH;AAEsB;ArF+0EW;AACA;AuFr3EbD;AACZO;AACA;AAgCH;AArBJ;AAIqBP,EAAAA;AAIK,IAAA;AACA,IAAA;AAEmC,IAAA;AAC/B,MAAA;AACO,QAAA;AAC1B,MAAA;AAC0B,QAAA;AACjC,MAAA;AACD,IAAA;AAEgB,IAAA;AAEfC,IAAAA;AAAW,MAAA;AAAV,MAAA;AACM,QAAA;AACM,QAAA;AACP,QAAA;AACC,QAAA;AACI,QAAA;AACI,0BAAA;AACZ,QAAA;AAAA,MAAA;AACH,IAAA;AAEH,EAAA;AAE0B,EAAA;AAEpB,EAAA;AACT;AvFq2EkC;AACA;AwF74EI;AACpC,EAAA;AACA,EAAA;AACiB,EAAA;AACnB;AxF+4EkC;AACA;AyFp5EM;AACtC,EAAA;AACA,EAAA;AACF;AzFs5EkC;AACA;A0F15EI;AACpC,EAAA;AACA,EAAA;AACF;A1F45EkC;AACA;A2Fh6EK;AACrC,EAAA;AACA,EAAA;AACF;A3Fk6EkC;AACA;A4Fh7EzBD;AAGwB;AACxBO;AACAC;AAqBL;AAfS;AAIM,EAAA;AAGO,EAAA;AACR,IAAA;AACK,MAAA;AACR,MAAA;AACX,IAAA;AACD,EAAA;AAGCP,EAAAA;AAAW,IAAA;AAAV,IAAA;AACM,MAAA;AACM,MAAA;AACP,MAAA;AACJ,MAAA;AACSO,MAAAA;AACI,wBAAA;AACZ,MAAA;AAAA,IAAA;AACH,EAAA;AAEH;A5Fu6EiC;AACA;A6F98ElC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;A7Fs9EkC;AACA;A8Fr9ErBT;AACDU;AACHD;A9Fu9EyB;AACA;A+F59EzBE;AACAN;AAG0B;AACbM,EAAAA;AAEI,EAAA;AACR,EAAA;AACgB,IAAA;AAChB,MAAA;AACb,IAAA;AAC0B,EAAA;AAC/B;A/F29EkC;AACA;AgGz+EA;AAIc;AhGw+Ed;AACA;A8F18E9B;AAzBgC;AACX,EAAA;AAEH,EAAA;AACK,EAAA;AACX,IAAA;AACb,EAAA;AAEM,EAAA;AACT;AAII;AACF,EAAA;AACA,EAAA;AACA,EAAA;AACA,EAAA;AACG,EAAA;AACgD;AACrB,EAAA;AAED,EAAA;AAG3BT,EAAAA;AAAkB,IAAA;AAAjB,IAAA;AACK,MAAA;AACuB,MAAA;AACbO,MAAAA;AACV,MAAA;AAAA,IAAA;AACN,EAAA;AAEJ;AAE4B;A9F+9EM;AACA;AiG1gFaR;AACnCS;AAuBD;AAbE;AAKT,EAAA;AACE,IAAA;AACG,IAAA;AAGF,EAAA;AAC2B,IAAA;AAEL,IAAA;AAC3B,EAAA;AACF;AAE+B;AjG4/EG;AACA;AkGzhFaT;AACnCS;AAEHD;AA8BD;AAnBK;AAKT,EAAA;AACE,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AAC4B,IAAA;AACzB,IAAA;AAGF,EAAA;AAC2B,IAAA;AAGV,IAAA;AACE,MAAA;AAAjB,MAAA;AACK,QAAA;AACA,QAAA;AACC,QAAA;AACS,QAAA;AACE,QAAA;AACGA,QAAAA;AACjB,UAAA;AACA,UAAA;AACF,QAAA;AAAA,MAAA;AAEJ,IAAA;AAEJ,EAAA;AACF;AAE+B;AlGwgFG;AACA;AmG3jFaR;AACnCS;AAuBD;AAbE;AAKT,EAAA;AACE,IAAA;AACG,IAAA;AAGF,EAAA;AAC2B,IAAA;AAEL,IAAA;AAC3B,EAAA;AACF;AAC8B;AnG8iFI;AACA;AoG3kFlC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;ApGolFkC;AACA;AqGzkFO;AACvC,EAAA;AACA,EAAA;AACF;ArG2kFkC;AACA;AsG/kFE;AAClC,EAAA;AACA,EAAA;AACF;AtGilFkC;AACA;AuGtlFzBR;AAFL;AACkB,EAAA;AACb,EAAA;AACT;AAE2B;AvG0lFO;AACA;AwG9lFzB;AAFL;AACmB,EAAA;AACdU,EAAAA;AACT;AAE4B;AxGkmFM;AACA;AyG/mFzBJ;AACiBP;AzGinFQ;AACA;A0GrnFlC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;A1G6nFkC;AACA;A2G5nFzBO;AACT;AAEEP;AAEAM;AACK;A3G4nF2B;AACA;A4GroFzBA;AAIJ;AAC4C,EAAA;AAEnCA,EAAAA;AACY,IAAA;AAEI,MAAA;AACH,QAAA;AACrB,MAAA;AAGQ,MAAA;AACe,QAAA;AACvB,MAAA;AACF,IAAA;AACS,IAAA;AACX,EAAA;AAEO,EAAA;AACT;A5G+nFkC;AACA;A2G5oFF;AA2CvB;AAtCsB;AACD,EAAA;AAERA,EAAAA;AACG,IAAA;AACG,MAAA;AAEG,MAAA;AACL,QAAA;AACpB,MAAA;AACyB,MAAA;AACJ,QAAA;AACrB,MAAA;AAEoB,MAAA;AACA,MAAA;AAEP,MAAA;AACY,QAAA;AACA,QAAA;AACJ,QAAA;AACrB,MAAA;AACF,IAAA;AACgB,IAAA;AAClB,EAAA;AAEgC,EAAA;AAClC;AAIoCN;AAIZ,EAAA;AACsBA,EAAAA;AAEpCO,EAAAA;AACT;AAEoB;A3G8nFa;AACA;A6G9qF8B;AAC9D,EAAA;AACG,EAAA;AACC;AACwB,EAAA;AACD,EAAA;AAC7B;AAEiC;A7G+qFC;AACA;A8GhsFgB;A9GksFhB;AACA;A+GnsFmB;AAClCf;AAqHf;AAnGuC;AACnC,EAAA;AACR;AAGE;AAIqB,EAAA;AAEF,EAAA;AACY,EAAA;AAEP,IAAA;AAIV,MAAA;AACR,QAAA;AACF,MAAA;AAE2B,IAAA;AAC/B,EAAA;AAEmB,EAAA;AACV,IAAA;AACT,EAAA;AAEe,EAAA;AACjB;AAE2C;AAGvC;AAIyB,EAAA;AAChB,EAAA;AAEW,IAAA;AACX,MAAA;AACF,IAAA;AACE,MAAA;AACT,IAAA;AACF,EAAA;AAGe,EAAA;AACM,EAAA;AAGnB,EAAA;AAGO,IAAA;AAEoB,EAAA;AAC/B;AAE+B;AACN,EAAA;AAC6B,EAAA;AAC3BA,IAAAA;AACK,MAAA;AAC5B,IAAA;AAEwB,IAAA;AACzB,EAAA;AAEe,EAAA;AACW,IAAA;AACN,MAAA;AACf,QAAA;AACQ,QAAA;AACR,QAAA;AACF,MAAA;AACe,MAAA;AAGb,MAAA;AACJ,IAAA;AAE2B,IAAA;AACC,IAAA;AACL,EAAA;AAElB,EAAA;AACT;AAEkE;AAChE,EAAA;AACA,EAAA;AACI;AACYoB,EAAAA;AAGb,EAAA;AAIL;A/G6oFkC;AACA;AgHvwFlC;AAEEZ;AAGK;AAyBH;AAVoCA;AAIhC,EAAA;AACS,IAAA;AACb,IAAA;AACY,EAAA;AAGX,EAAA;AAIJ;AAEwB;AhHgvFS;AACA;AiHxxFzBO;AACiBP;AAejB;AAPgCA;AAIjC,EAAA;AACU,IAAA;AACQ,EAAA;AAChBO,EAAAA;AACT;AAEyB;AjHgxFQ;AACA;AkH7xF9B;AACI,EAAA;AACY,IAAA;AACQ,EAAA;AACR,EAAA;AACpB;AAE4B;AlH8xFM;AACA;AmHvyFrB;AAGgB,EAAA;AACN,EAAA;AAEC,EAAA;AACxB;AAE+B;AnHqyFG;AACA;A8GzwF9BL;AAFsB;AAEtBA,EAAAA;AACG,oBAAA;AACA,oBAAA;AAGH,EAAA;AAEWD,EAAAA;AACF,EAAA;AACJ,EAAA;AACgB,IAAA;AACI,MAAA;AACI,MAAA;AACP,MAAA;AACbA,MAAAA;AACT,IAAA;AACF,EAAA;AACF;AAM0E;AAC5D,EAAA;AACgB,IAAA;AACnB,IAAA;AACC,IAAA;AACe,IAAA;AACA,IAAA;AACpB,EAAA;AACD;AACyB,EAAA;AACN,EAAA;AACD,EAAA;AAEK,EAAA;AACF,EAAA;AAEP,EAAA;AACJ,EAAA;AACP,IAAA;AACiB,MAAA;AACF,QAAA;AACU,MAAA;AAErBA,MAAAA;AAEJ,IAAA;AACiB,MAAA;AACF,QAAA;AAEXA,MAAAA;AAEJ,IAAA;AACiB,MAAA;AACF,QAAA;AACXA,MAAAA;AAES,IAAA;AACU,MAAA;AACP,MAAA;AAEO,QAAA;AACL,QAAA;AACjB,QAAA;AACD,MAAA;AACIA,MAAAA;AACT,IAAA;AACA,IAAA;AAC+B,MAAA;AACb,MAAA;AACpB,EAAA;AACF;AAO6D;AAC3D,EAAA;AACA,EAAA;AACI;AAED,EAAA;AAIL;AAE2BY;AACzB,EAAA;AAEO,EAAA;AAKT;AAE0E;AACxE,EAAA;AACI;AACmB,EAAA;AAED,EAAA;AAEU,EAAA;AACZ,IAAA;AAEhBZ,IAAAA;AAAC,MAAA;AAAA,MAAA;AAEC,QAAA;AACA,QAAA;AAAA,MAAA;AAFK,MAAA;AAGP,IAAA;AAEH,EAAA;AACH;AAEwB;A9G0uFU;AACA;AoHj4F9B;AACK,EAAA;AACT;AAE2B;ApHk4FO;AACA;AyGl4F5B;AANmCD;AAKpC,EAAA;AAIJ;AAEyB;AzGm4FQ;AACA;AqH55FlC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;ArHq6FkC;AACA;AsHp6FzBQ;AACAD;AACT;AAGEP;AAEK;AAsBH;AAdiCA;AAIN,EAAA;AAEU,EAAA;AACpB,IAAA;AAEN,IAAA;AACN,IAAA;AACP,EAAA;AAGEC,EAAAA;AAAW,IAAA;AAAV,IAAA;AACK,MAAA;AACC,MAAA;AACKO,MAAAA;AAA2C,IAAA;AACvD,EAAA;AAEH;AAEqB;AtHu5FY;AACA;AuH77FzBA;AACAM;AACY;AACrB;AAEEd;AACAM;AACAF;AACAW;AACK;AAGA;AAGEC;AAkFH;AA3EgChB;AAKlC,EAAA;AACc,IAAA;AACZ,IAAA;AACU,IAAA;AACV,IAAA;AACA,IAAA;AACG,IAAA;AAGF,EAAA;AACmB,IAAA;AACQ,IAAA;AAEH,IAAA;AACA,MAAA;AAChB,MAAA;AACV,IAAA;AAE2B,IAAA;AAEE,IAAA;AACkB,IAAA;AACpB,IAAA;AAEJ,IAAA;AACL,MAAA;AACO,MAAA;AACN,QAAA;AACC,QAAA;AACnB,MAAA;AACD,IAAA;AAE4C,IAAA;AAC3B,MAAA;AAGE,MAAA;AAES,MAAA;AACH,QAAA;AAEN,QAAA;AACG,UAAA;AAEI,0BAAA;AACvB,QAAA;AACF,MAAA;AACF,IAAA;AAEyB,IAAA;AACC,IAAA;AACP,MAAA;AACC,MAAA;AAED,MAAA;AACR,MAAA;AACmB,QAAA;AACA,QAAA;AAC5B,MAAA;AACmB,IAAA;AAEK,IAAA;AAED,IAAA;AACH,MAAA;AACZ,QAAA;AACR,MAAA;AACD,IAAA;AAGCC,IAAAA;AAAC,MAAA;AAAA,MAAA;AACM,QAAA;AACL,QAAA;AACI,QAAA;AACJ,QAAA;AACU,QAAA;AACAO,QAAAA;AACc,UAAA;AACH,UAAA;AACE,UAAA;AACtB,QAAA;AACUA,QAAAA;AAA8C,MAAA;AAC3D,IAAA;AAEJ,EAAA;AACF;AAEuB;AvHg6FW;AACA;AwHnhGaR;AAEtCO;AAeL;AARiCP;AAIX,EAAA;AACM,EAAA;AAG5BC,EAAAA;AAAW,IAAA;AAAV,IAAA;AACM,MAAA;AACD,MAAA;AACJ,MAAA;AACuB,MAAA;AAAA,IAAA;AACzB,EAAA;AAEH;AAEqB;AxH2gGY;AACA;AyH5hGK;AACrC,EAAA;AACA,EAAA;AACF;AzH8hGkC;AACA;A0HpiGgC;AAChE,EAAA;AACG,EAAA;AACC;AACyB,EAAA;AACF,EAAA;AAC7B;AAEkC;A1HqiGA;AACA;A2HxjGlC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;A3HgkGkC;AACA;A4HjkGlC;AAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA,EAAA;AAAA;A5H4kGkC;AACA;A6H3kGzBM;AACiBP;AAWjB;AAJ0BA;AAIzBO,EAAAA;AACT;AAEiC;A7HokGA;AACA;A8H7kGkC;AAClE,EAAA;AACI;AACyB,EAAA;AACH,EAAA;AAC5B;AAEqB;A9H8kGa;AACA;A+HrlG4B;AAC5D,EAAA;AACG,EAAA;AACC;AAC4B,EAAA;AACL,EAAA;AAC7B;AAEgC;A/HslGE;AACA;AgIvmGzBO;AACAP;AACiBP;AhIymGQ;AACA;AiI7mGzBc;AACc;AjI+mGW;AACA;AkIlnGzBJ;AACAJ;AAG0B;AACbI,EAAAA;AAEAJ,EAAAA;AACG,IAAA;AACQ,MAAA;AACb,QAAA;AACb,MAAA;AAEwB,MAAA;AACA,QAAA;AACF,UAAA;AACG,YAAA;AACH,cAAA;AACjB,YAAA;AACF,UAAA;AAEmB,UAAA;AACG,YAAA;AACH,cAAA;AACjB,YAAA;AACF,UAAA;AACF,QAAA;AAEY,QAAA;AACb,MAAA;AAEwB,MAAA;AACA,MAAA;AAGF,MAAA;AACE,QAAA;AACzB,MAAA;AAEa,MAAA;AACe,QAAA;AACT,QAAA;AACnB,MAAA;AACF,IAAA;AACY,IAAA;AACd,EAAA;AAEgC,EAAA;AAClC;AlIymGkC;AACA;AmI1pGzBI;AACAN;AAG2B;AACdM,EAAAA;AAEI,EAAA;AACR,EAAA;AACgB,IAAA;AAChB,MAAA;AACb,IAAA;AAC0B,EAAA;AAC/B;AnIypGkC;AACA;AiIzpGS;AAC5B,EAAA;AACyB;AACF,EAAA;AAEZ,EAAA;AAEc,EAAA;AAIPK,EAAAA;AAEP,EAAA;AACH,IAAA;AACM,IAAA;AAEF,IAAA;AACC,IAAA;AAC1B,EAAA;AAE2B,EAAA;AACN,IAAA;AACT,IAAA;AAES,IAAA;AAEb,IAAA;AAEgB,IAAA;AAEf,IAAA;AACc,MAAA;AACM,QAAA;AACzB,MAAA;AAEsB,MAAA;AAC+C,QAAA;AACrD,UAAA;AACb,QAAA;AACH,MAAA;AACF,IAAA;AAE4B,IAAA;AAC9B,EAAA;AAEkB,EAAA;AACW,IAAA;AACD,MAAA;AAC1B,IAAA;AAEa,IAAA;AACd,EAAA;AAE4C,EAAA;AACb,IAAA;AACjB,IAAA;AACY,MAAA;AACzB,IAAA;AACD,EAAA;AAEqBD,EAAAA;AAEI,EAAA;AACH,IAAA;AACtB,EAAA;AAEM,EAAA;AACT;AjIuoGkC;AACA;AgI/rG9B;AAXmCd;AAIf,EAAA;AACpB,IAAA;AACD,EAAA;AAE2B,EAAA;AAGzBO,EAAAA;AAIJ;AAEuB;AhImsGU;AACA;AoInuGgB;ApIquGhB;AACA;AqItuGQH;AACvBZ;ArIwuGe;AACA;AsI5uGzBA;AAqB6B;AACpC,EAAA;AACA,EAAA;AAK2C;AAC7B,EAAA;AACG,IAAA;AACf,EAAA;AACgB,EAAA;AACK,IAAA;AACrB,EAAA;AAEM,EAAA;AACa,EAAA;AACL,IAAA;AACd,EAAA;AAEW,EAAA;AACA,EAAA;AAEC,EAAA;AACU,IAAA;AACG,IAAA;AACzB,EAAA;AACY,EAAA;AACS,IAAA;AACK,IAAA;AACb,IAAA;AACb,EAAA;AACc,EAAA;AACY,IAAA;AAC1B,EAAA;AACA;AtImtG8B;AACA;AuI5wGzBA;AAePA;AAC2D,EAAA;AAClD,EAAA;AACK,IAAA;AACc,IAAA;AACC,MAAA;AACzB,IAAA;AACY,IAAA;AACc,IAAA;AACC,MAAA;AAC3B,IAAA;AACY,IAAA;AACQ,IAAA;AACA,sBAAA;AACpB,IAAA;AACuB,IAAA;AACT,MAAA;AACY,MAAA;AACR,MAAA;AACW,QAAA;AAC1B,MAAA;AACH,IAAA;AACF,EAAA;AACD;AvIgwG+B;AACA;AqIhqG9B;AAlH8C;AACvB,EAAA;AAC3B;AAIE;AAI0B,EAAA;AACD,EAAA;AACJ,EAAA;AAEI,EAAA;AACI,EAAA;AAGR,EAAA;AAGnB,EAAA;AAKO,IAAA;AAEY,EAAA;AACnB,IAAA;AACA,IAAA;AACA,IAAA;AACA,IAAA;AACD,EAAA;AACH;AAE2B;AACE,EAAA;AAEqB,EAAA;AAC3BA,IAAAA;AAEf,MAAA;AACoB,QAAA;AACQ,QAAA;AAC1B,QAAA;AACA,QAAA;AACF,MAAA;AACJ,IAAA;AACwB,IAAA;AACA,IAAA;AACR,MAAA;AACI,QAAA;AACK,QAAA;AACT,UAAA;AACR,YAAA;AACF,UAAA;AAEW,QAAA;AAEN,QAAA;AACT,MAAA;AACkB,MAAA;AACU,QAAA;AACL,QAAA;AACT,UAAA;AACR,YAAA;AACF,UAAA;AAEmB,QAAA;AAEH,UAAA;AAClB,QAAA;AAC0B,QAAA;AACxB,UAAA;AACM,UAAA;AACY,UAAA;AACnB,QAAA;AACH,MAAA;AACD,IAAA;AAEoB,IAAA;AACtB,EAAA;AAEe,EAAA;AACO,IAAA;AACF,MAAA;AACf,QAAA;AAC0B,QAAA;AAClB,QAAA;AACR,QAAA;AACF,MAAA;AACe,MAAA;AAC2C,MAAA;AACxD,QAAA;AACA,QAAA;AACF,MAAA;AACF,IAAA;AAE8B,IAAA;AAEL,IAAA;AACJ,EAAA;AAEhB,EAAA;AACT;AAE0D;AACxD,EAAA;AACA,EAAA;AACI;AACYyB,EAAAA;AAGb,EAAA;AAIL;ArImvGkC;AACA;AoIt0G5Bf;AA/ByB;AAG7B;AAEO,EAAA;AAEQ,IAAA;AAIA,IAAA;AAEA,IAAA;AACa,IAAA;AAC5B,EAAA;AACF;AAOmD;AACjD,EAAA;AACA,EAAA;AACI;AACIgB,EAAAA;AAGL,EAAA;AACE,oBAAA;AACE,sBAAA;AAGA,sBAAA;AAGH,IAAA;AACC,oBAAA;AAGA,oBAAA;AAGH,EAAA;AAEJ;AAEsBL;AACpB,EAAA;AAEO,EAAA;AAMT;AAE6E;AAC3E,EAAA;AACI;AAC0B,EAAA;AAEP,EAAA;AACG,EAAA;AAEK,EAAA;AACR,IAAA;AAEnBZ,IAAAA;AAAC,MAAA;AAAA,MAAA;AAEC,QAAA;AACA,QAAA;AAAA,MAAA;AAFK,MAAA;AAGP,IAAA;AAEH,EAAA;AACH;AAE4B;AAEWY;AACrC,EAAA;AAEO,EAAA;AAKT;ApI+zGkC;AACA;AwIx6GrB;AACX,EAAA;AACA,EAAA;AACF;AxI06GkC;AACA;AyI96GO;AACvC,EAAA;AACA,EAAA;AAC+B,EAAA;AACjC;AzIg7GkC;AACA;A0I/7GlC;AAIEpB;AACAC;AACK;AAiJD;AAhCsBD;AAgBwC;AAChD,EAAA;AACpB;AAMoE;AAClE,EAAA;AACA,EAAA;AACI;AACc,EAAA;AAGhB,EAAA;AAO2B,EAAA;AAEd,EAAA;AACH,IAAA;AACR,MAAA;AACF,IAAA;AACF,EAAA;AAEG,EAAA;AAIL;AAEqB;A1I6yGa;AACA;A2Iz9GzBO;AACT;AACE;AACA;AACA;AACA;AACA;AACK;AA0Cc;AAhCC;AACQ,EAAA;AACN,EAAA;AACU,EAAA;AACV,EAAA;AACxB;AAEuB;AACO,EAAA;AACN,EAAA;AACC,EAAA;AACA,EAAA;AACzB;AAEwB;AACM,EAAA;AACN,EAAA;AACE,EAAA;AACA,EAAA;AAC1B;AAEqC;AACJ,EAAA;AACX,EAAA;AACD,EAAA;AACA,EAAA;AAEjBE,EAAAA;AAAC,IAAA;AAAA,IAAA;AACgB,MAAA;AACN,MAAA;AACK,MAAA;AAEb,MAAA;AAAc,QAAA;AACD,QAAA;AACE,QAAA;AAA0B,MAAA;AAAA,IAAA;AAC5C,EAAA;AAEJ;AAEiC;AAEF;AAClB,EAAA;AACZ;AAEsB;AAEQF;AAIvB,EAAA;AACK,IAAA;AACqB,MAAA;AACzB,IAAA;AACa,EAAA;AAGjB,EAAA;AAIQ,oBAAA;AAGA,oBAAA;AAMT,EAAA;AAEH;AAEsB;AAEjB;AAEFW,EAAAA;AACG,oBAAA;AAGA,oBAAA;AAGH,EAAA;AAEJ;AAEgCX;AAIxB,EAAA;AACK,IAAA;AACoB,MAAA;AACxB,IAAA;AACa,EAAA;AACD,EAAA;AACK,EAAA;AAErB,EAAA;AAMJ;AAEuB;AAElB;AAIE,EAAA;AACK,IAAA;AACW,MAAA;AACU,QAAA;AACvB,MAAA;AACF,IAAA;AACa,EAAA;AACD,EAAA;AACK,EAAA;AAErB,EAAA;AAMJ;AAE8B;AAEEA;AAIzB,EAAA;AACK,IAAA;AACqB,MAAA;AACzB,IAAA;AACa,EAAA;AACA,EAAA;AACK,EAAA;AAEtB,EAAA;AAMJ;AAEwB;AAET;AACR,EAAA;AACE,EAAA;AACF,EAAA;AACC,EAAA;AACO,EAAA;AACC,EAAA;AACjB;AAEO;AACL,EAAA;AACA,EAAA;AACF;A3Im5GkC;AACA;A4I/kHCA;A5IilHD;AACA;A6IllHCA;AACT;AAsBtBE;AAX+B;AACT,EAAA;AACF,EAAA;AACQ,EAAA;AACE,EAAA;AAClC;AAE+B;AACH,EAAA;AACK,EAAA;AAE5B,EAAA;AACEiB,oBAAAA;AACA,oBAAA;AACA,oBAAA;AACH,EAAA;AAEJ;AAE2B;AAEF;AACZ,EAAA;AACZ;AAE8B;AAEFnB;AAIrB,EAAA;AACK,IAAA;AACqB,MAAA;AACzB,IAAA;AACa,EAAA;AAEjB,EAAA;AAMJ;AAEoB;AAEY;AACpB,EAAA;AACZ;AAEyBA;AAKrB,EAAA;AACE,oBAAA;AAA+B,IAAA;AAAI,oBAAA;AACtC,EAAA;AAEH;AAE+B;AAEPA;AAIjB,EAAA;AACuB,IAAA;AACT,EAAA;AAEjB,EAAA;AAMJ;AAE8B;AAEf;AACR,EAAA;AACImB,EAAAA;AACJ,EAAA;AACR;AAEe;A7IuiHmB;AACA;A8I3oHD;AAc7BjB;AAJgD;AACnB,EAAA;AAG5B,EAAA;AACiB,IAAA;AACK,IAAA;AACvB,EAAA;AAEJ;AAEqB;AAEkC;AAC1C,EAAA;AACZ;AAEwB;AAE+B;AAC3C,EAAA;AACZ;AAEyB;AAEiC;AAC9C,EAAA;AACZ;AAE4B;A9I2nHK;AACA;A+InqHX;AAKnB;AAH0B;AACG,EAAA;AAE7BD,EAAAA;AAAsB,IAAA;AAArB,IAAA;AACYmB,MAAAA;AACT,QAAA;AACgB,QAAA;AAClB,MAAA;AACU,MAAA;AAAA,IAAA;AACZ,EAAA;AAEJ;AAEwB;AAETC;A/IoqHmB;AACA;A4I5qH9BnB;AAF+B;AAE9B,EAAA;AACE,oBAAA;AACA,oBAAA;AACA,oBAAA;AACA,oBAAA;AACH,EAAA;AAEJ;AAE+B;AAEI;AACR,EAAA;AACjB,EAAA;AACV;AAE6B;AAChB,EAAA;AACZ;AAEoB;AAEf;AACO,EAAA;AACZ;AAK+BF;AAIF,EAAA;AAEzB,EAAA;AACmB,IAAA;AAAjB,IAAA;AACa,MAAA;AACP,QAAA;AACmB,QAAA;AACxB,MAAA;AAAA,IAAA;AAEJ,EAAA;AAEH;AAEuB;AAER;AACR,EAAA;AACE,EAAA;AACC,EAAA;AACX;AAEe;AACb,EAAA;AACAqB,EAAAA;AACF;A5I+pHkC;AACA;AgJpuHhBrB;AACA;AhJsuHgB;AACA;AiJxuHVA;AACM;AjJ0uHI;AACA;AkJ5uHCA;AAE1B;AlJ6uHyB;AACA;AmJvuH5B;AATkC;AAEpCC,EAAAA;AAAC,IAAA;AAAA,IAAA;AACO,MAAA;AACE,MAAA;AACH,MAAA;AACC,MAAA;AACC,MAAA;AAEPA,MAAAA;AAAgD,IAAA;AAClD,EAAA;AAEJ;AAE6B;AnJkvHK;AACA;AkJjvH5B;AAHqB;AAEtB,EAAA;AACE,oBAAA;AACA,oBAAA;AACH,EAAA;AAEJ;AAEuB;AAEW;AACrB,EAAA;AACZ;AAE0B;AAEC;AACpB,EAAA;AACK,EAAA;AACA,EAAA;AACZ;AAKqBD;AACJ,EAAA;AACR,IAAA;AACK,MAAA;AACc,QAAA;AAClB,MAAA;AACa,IAAA;AAEjB,IAAA;AAEL,EAAA;AACF;AAE4B;AAEC;AACL,EAAA;AACE,EAAA;AACjB,EAAA;AACT;AAEiC;AACX,EAAA;AACK,EAAA;AAEvBW,EAAAA;AACG,oBAAA;AAGA,oBAAA;AAGH,EAAA;AAEJ;AAE6B;AAEF;AAChB,EAAA;AACE,EAAA;AACZ;AAKE;AACK,EAAA;AACyB,IAAA;AACX,EAAA;AAEjB,EAAA;AAMJ;AAE0B;AAEE;AAClB,EAAA;AACE,EAAA;AACZ;AAKC;AACM,EAAA;AACmB,IAAA;AACL,EAAA;AAEjB,EAAA;AAMJ;AAE4B;AAEb;AACR,EAAA;AACC,EAAA;AACC,EAAA;AACF,EAAA;AACE,EAAA;AACV;AAEsB;AlJusHY;AACA;AoJ30HCX;AAS7BE;AAH0B;AAE3B,EAAA;AACE,oBAAA;AACE,sBAAA;AACA,sBAAA;AACH,IAAA;AACC,oBAAA;AACH,EAAA;AAEJ;AAE4B;AAEI;AACnB,EAAA;AACZ;AAE2B;AACf,EAAA;AACZ;AAIyBF;AACR,EAAA;AAEX,IAAA;AAIL,EAAA;AACF;AAEgC;AAEM;AACX,EAAA;AACjB,EAAA;AACV;AAEmC;AACtB,EAAA;AACZ;AAO4BA;AAIE,EAAA;AAG1B,EAAA;AAIJ;AAEoB;AAEf;AACO,EAAA;AACZ;AAEK;AACO,EAAA;AACZ;AAMkE;AACtC,EAAA;AACvB;AAEFC,EAAAA;AAAC,IAAA;AAAA,IAAA;AACC,MAAA;AACO,MAAA;AACC,MAAA;AAERA,MAAAA;AAAqE,IAAA;AACvE,EAAA;AAEJ;AAEqC;AACJ,EAAA;AAE5B,EAAA;AAE6B,IAAA;AAClB,IAAA;AAEZ,EAAA;AAEJ;AAEyB;AAET;AACR,EAAA;AACE,EAAA;AACA,EAAA;AACC,EAAA;AACI,EAAA;AACD,EAAA;AACd;AAEe;ApJ4xHmB;AACA;AqJr5HCD;ArJu5HD;AACA;AsJx5HzBA;AACkB;AAuBrB;AAZgB;AACG,EAAA;AACD,EAAA;AACU,EAAA;AACV,EAAA;AACxB;AAEgC;AACC,EAAA;AACR,EAAA;AAEpB,EAAA;AAIL;AAE4B;AAEF;AACb,EAAA;AACZ;AAE+B;AAENA;AAIlB,EAAA;AACsB,IAAA;AACR,EAAA;AACW,EAAA;AACR,EAAA;AAEpB,EAAA;AAMJ;AAE+B;AAEhB;AACR,EAAA;AACA,EAAA;AACR;AAEe;AtJ43HmB;AACA;AqJj7H9BE;AAF0B;AAEzB,EAAA;AACE,oBAAA;AACA,oBAAA;AACA,oBAAA;AACH,EAAA;AAEJ;AAE0B;AAEF;AACX,EAAA;AACZ;AAE6B;AAEI;AACrB,EAAA;AACZ;AAK0BF;AACE,EAAA;AAEtB,IAAA;AACmB,MAAA;AAAjB,MAAA;AACa,QAAA;AACP,UAAA;AACe,UAAA;AACpB,QAAA;AAAA,MAAA;AAEJ,IAAA;AAEJ,EAAA;AACF;AAEiC;AAEjB;AACR,EAAA;AACG,EAAA;AACX;AAEsB;ArJw6HY;AACA;AuJh+HzBA;AAYHE;AALyB;AAE1B,EAAA;AACE,oBAAA;AAEA,oBAAA;AACE,sBAAA;AACA,sBAAA;AACH,IAAA;AACF,EAAA;AAEJ;AAE2B;AAEF;AACZ,EAAA;AACZ;AAE8B;AAEL;AACb,EAAA;AACZ;AAE+B;AAEL;AACd,EAAA;AACZ;AAEgC;AAENF;AACT,EAAA;AACR,IAAA;AACK,MAAA;AACmB,QAAA;AACvB,MAAA;AACa,IAAA;AAEjB,IAAA;AAML,EAAA;AACF;AAEiC;AAERA;AACP,EAAA;AACR,IAAA;AACuB,MAAA;AACT,IAAA;AAEjB,IAAA;AAML,EAAA;AACF;AAE+B;AAEf;AACR,EAAA;AACC,EAAA;AACC,EAAA;AACA,EAAA;AACF,EAAA;AACR;AAEe;AvJi8HmB;AACA;AiJ3/H1BE;AANqC;AAExC,EAAA;AAEI,oBAAA;AACA,oBAAA;AACA,oBAAA;AACE,sBAAA;AACA,sBAAA;AACH,IAAA;AAEJ,EAAA;AAEJ;AAKyB;AACZ,EAAA;AACZ;AAEkBF;AACc,EAAA;AAE1B,IAAA;AAIL,EAAA;AACF;AAEyB;AAEW;AACvB,EAAA;AACZ;AAE4B;AAEA;AAChB,EAAA;AACZ;AAEoB;AAEO;AASpB;AAEJC,EAAAA;AAAiB,IAAA;AAAhB,IAAA;AACa,MAAA;AACe,QAAA;AACC,QAAA;AACR,QAAA;AACH,QAAA;AACjB,MAAA;AACI,MAAA;AAAA,IAAA;AACN,EAAA;AAEJ;AAE6B;AAEvB;AACK,EAAA;AACE,EAAA;AACZ;AAE4BD;AAIrB,EAAA;AACK,IAAA;AACqB,MAAA;AACzB,IAAA;AACa,EAAA;AAEjB,EAAA;AAMJ;AAEoB;AAEL;AACR,EAAA;AACI,EAAA;AACA,EAAA;AACM,EAAA;AACA,EAAA;AAClB;AAEsB;AjJ29HY;AACA;AgJlkI5B;AAH+C;AAEhD,EAAA;AACE,oBAAA;AACA,oBAAA;AAGH,EAAA;AAEJ;AAE6B;AAItB;AAEF,EAAA;AAIL;AAEiC;AAEHA;AAKzB,EAAA;AAMJ;AAEqB;AAEO;AAChB,EAAA;AACZ;AAEoB;AAEK;AACf,EAAA;AACE,EAAA;AACZ;AAM4BA;AAIrB,EAAA;AACK,IAAA;AACS,MAAA;AACR,QAAA;AACe,UAAA;AAChB,QAAA;AACG,QAAA;AACa,UAAA;AAChB,QAAA;AACF,MAAA;AACF,IAAA;AACa,EAAA;AACM,EAAA;AAGxBC,EAAAA;AAAC,IAAA;AAAA,IAAA;AACM,MAAA;AACL,MAAA;AACY,MAAA;AACR,MAAA;AACJ,MAAA;AAGE,MAAA;AACEA,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACa,YAAA;AACF,YAAA;AAAA,UAAA;AACZ,QAAA;AACAA,wBAAAA;AAAC,UAAA;AAAA,UAAA;AACa,YAAA;AACF,YAAA;AAAA,UAAA;AACZ,QAAA;AACF,MAAA;AAAA,IAAA;AAEJ,EAAA;AAEH;AAEoB;AAES;AACjB,EAAA;AACC,EAAA;AACb;AAEqB;AAEN;AACR,EAAA;AACG,EAAA;AACA,EAAA;AACD,EAAA;AACA,EAAA;AACV;AAEe;AhJmiImB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"/home/runner/work/assistant-ui/assistant-ui/packages/react/dist/index.js","sourcesContent":[null,"import type { FC, PropsWithChildren } from \"react\";\nimport { memo } from \"react\";\nimport type { AssistantRuntime } from \"../../runtimes/core/AssistantRuntime\";\nimport { AssistantProvider } from \"./AssistantProvider\";\n\ntype AssistantRuntimeProviderProps = {\n runtime: AssistantRuntime;\n};\n\nconst AssistantRuntimeProviderImpl: FC<\n PropsWithChildren<AssistantRuntimeProviderProps>\n> = ({ children, runtime }) => {\n return <AssistantProvider runtime={runtime}>{children}</AssistantProvider>;\n};\n\nexport const AssistantRuntimeProvider = memo(AssistantRuntimeProviderImpl);\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport { useEffect, useInsertionEffect, useRef, useState } from \"react\";\nimport type { AssistantRuntime } from \"../../runtimes\";\nimport { AssistantContext } from \"../react/AssistantContext\";\nimport { makeAssistantModelConfigStore } from \"../stores/AssistantModelConfig\";\nimport { makeAssistantToolUIsStore } from \"../stores/AssistantToolUIs\";\nimport { ThreadProvider } from \"./ThreadProvider\";\nimport { makeAssistantActionsStore } from \"../stores/AssistantActions\";\nimport {\n AssistantRuntimeStore,\n makeAssistantRuntimeStore,\n} from \"../stores/AssistantRuntime\";\nimport { StoreApi } from \"zustand\";\n\ntype AssistantProviderProps = {\n runtime: AssistantRuntime;\n};\n\nexport const AssistantProvider: FC<\n PropsWithChildren<AssistantProviderProps>\n> = ({ children, runtime }) => {\n const runtimeRef = useRef(runtime);\n useInsertionEffect(() => {\n runtimeRef.current = runtime;\n });\n\n const [context] = useState(() => {\n const useAssistantRuntime = makeAssistantRuntimeStore(runtime);\n const useModelConfig = makeAssistantModelConfigStore();\n const useToolUIs = makeAssistantToolUIsStore();\n const useAssistantActions = makeAssistantActionsStore(runtimeRef);\n\n return {\n useModelConfig,\n useToolUIs,\n useAssistantRuntime,\n useAssistantActions,\n };\n });\n\n const getModelConfig = context.useModelConfig();\n useEffect(() => {\n return runtime.registerModelConfigProvider(getModelConfig);\n }, [runtime, getModelConfig]);\n\n useEffect(\n () =>\n (\n context.useAssistantRuntime as unknown as StoreApi<AssistantRuntimeStore>\n ).setState(runtime, true),\n [runtime, context],\n );\n\n return (\n <AssistantContext.Provider value={context}>\n <ThreadProvider provider={runtime}>{children}</ThreadProvider>\n </AssistantContext.Provider>\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { AssistantModelConfigState } from \"../stores/AssistantModelConfig\";\nimport type { AssistantToolUIsState } from \"../stores/AssistantToolUIs\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { AssistantActionsState } from \"../stores/AssistantActions\";\nimport { AssistantRuntime } from \"../../runtimes\";\n\nexport type AssistantContextValue = {\n useModelConfig: ReadonlyStore<AssistantModelConfigState>;\n useToolUIs: ReadonlyStore<AssistantToolUIsState>;\n useAssistantRuntime: ReadonlyStore<AssistantRuntime>;\n useAssistantActions: ReadonlyStore<AssistantActionsState>;\n};\n\nexport const AssistantContext = createContext<AssistantContextValue | null>(\n null,\n);\n\nexport function useAssistantContext(): AssistantContextValue;\nexport function useAssistantContext(options: {\n optional: true;\n}): AssistantContextValue | null;\nexport function useAssistantContext(options?: { optional: true }) {\n const context = useContext(AssistantContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within an AssistantRuntimeProvider.\",\n );\n return context;\n}\n","\"use client\";\n\nimport { create } from \"zustand\";\nimport type { ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport { ProxyConfigProvider } from \"../../utils/ProxyConfigProvider\";\n\nexport type AssistantModelConfigState = Readonly<\n ModelConfigProvider & {\n registerModelConfigProvider: (provider: ModelConfigProvider) => () => void;\n }\n>;\n\nexport const makeAssistantModelConfigStore = () =>\n create<AssistantModelConfigState>(() => {\n const proxy = new ProxyConfigProvider();\n\n return Object.freeze({\n getModelConfig: () => {\n return proxy.getModelConfig();\n },\n registerModelConfigProvider: (provider: ModelConfigProvider) => {\n return proxy.registerModelConfigProvider(provider);\n },\n }) satisfies AssistantModelConfigState;\n });\n","\"use client\";\nimport {\n type ModelConfigProvider,\n mergeModelConfigs,\n} from \"../types/ModelConfigTypes\";\n\nexport class ProxyConfigProvider implements ModelConfigProvider {\n private _providers = new Set<ModelConfigProvider>();\n\n getModelConfig() {\n return mergeModelConfigs(this._providers);\n }\n\n registerModelConfigProvider(provider: ModelConfigProvider) {\n this._providers.add(provider);\n return () => {\n this._providers.delete(provider);\n };\n }\n}\n","\"use client\";\n\nimport { create } from \"zustand\";\nimport type { ToolCallContentPartComponent } from \"../../types/ContentPartComponentTypes\";\n\nexport type AssistantToolUIsState = Readonly<{\n getToolUI: (toolName: string) => ToolCallContentPartComponent | null;\n setToolUI: (\n toolName: string,\n render: ToolCallContentPartComponent,\n ) => () => void;\n}>;\n\nexport const makeAssistantToolUIsStore = () =>\n create<AssistantToolUIsState>((set) => {\n const renderers = new Map<string, ToolCallContentPartComponent[]>();\n\n return Object.freeze({\n getToolUI: (name) => {\n const arr = renderers.get(name);\n const last = arr?.at(-1);\n if (last) return last;\n return null;\n },\n setToolUI: (name, render) => {\n let arr = renderers.get(name);\n if (!arr) {\n arr = [];\n renderers.set(name, arr);\n }\n arr.push(render);\n set({}); // notify the store listeners\n\n return () => {\n const index = arr.indexOf(render);\n if (index !== -1) {\n arr.splice(index, 1);\n }\n if (index === arr.length) {\n set({}); // notify the store listeners\n }\n };\n },\n }) satisfies AssistantToolUIsState;\n });\n","import type { FC, PropsWithChildren } from \"react\";\nimport { useEffect, useInsertionEffect, useState } from \"react\";\nimport type { ReactThreadRuntime } from \"../../runtimes/core/ReactThreadRuntime\";\nimport type { ThreadContextValue } from \"../react/ThreadContext\";\nimport { ThreadContext } from \"../react/ThreadContext\";\nimport { ComposerState, makeComposerStore } from \"../stores/Composer\";\nimport {\n ThreadState,\n getThreadStateFromRuntime,\n makeThreadStore,\n} from \"../stores/Thread\";\nimport { makeThreadViewportStore } from \"../stores/ThreadViewport\";\nimport { makeThreadActionStore } from \"../stores/ThreadActions\";\nimport { StoreApi } from \"zustand\";\nimport {\n ThreadMessagesState,\n makeThreadMessagesStore,\n} from \"../stores/ThreadMessages\";\nimport { ThreadRuntimeWithSubscribe } from \"../../runtimes/core/AssistantRuntime\";\nimport {\n makeThreadRuntimeStore,\n ThreadRuntimeStore,\n} from \"../stores/ThreadRuntime\";\nimport { subscribeToMainThread } from \"../../runtimes\";\n\ntype ThreadProviderProps = {\n provider: ThreadRuntimeWithSubscribe;\n};\n\nexport const ThreadProvider: FC<PropsWithChildren<ThreadProviderProps>> = ({\n children,\n provider,\n}) => {\n const [context] = useState<ThreadContextValue>(() => {\n const useThreadRuntime = makeThreadRuntimeStore(provider.thread);\n const useThread = makeThreadStore(useThreadRuntime);\n const useThreadMessages = makeThreadMessagesStore(useThreadRuntime);\n const useThreadActions = makeThreadActionStore(useThreadRuntime);\n const useViewport = makeThreadViewportStore();\n const useComposer = makeComposerStore(useThreadRuntime);\n\n return {\n useThread,\n useThreadRuntime,\n useThreadMessages,\n useThreadActions,\n useComposer,\n useViewport,\n };\n });\n\n // TODO it might make sense to move this into the make* functions\n useEffect(() => {\n const onThreadUpdate = () => {\n const thread = provider.thread;\n\n const oldState = context.useThread.getState();\n const state = getThreadStateFromRuntime(thread);\n if (\n oldState.isDisabled !== state.isDisabled ||\n oldState.isRunning !== state.isRunning ||\n // TODO ensure capabilities is memoized\n oldState.capabilities !== state.capabilities\n ) {\n (context.useThread as unknown as StoreApi<ThreadState>).setState(\n state,\n true,\n );\n }\n\n if (thread.messages !== context.useThreadMessages.getState()) {\n (\n context.useThreadMessages as unknown as StoreApi<ThreadMessagesState>\n ).setState(thread.messages, true);\n }\n\n const composerState = context.useComposer.getState();\n if (\n thread.composer.text !== composerState.text ||\n state.capabilities.cancel !== composerState.canCancel\n ) {\n (context.useComposer as unknown as StoreApi<ComposerState>).setState({\n text: thread.composer.text,\n canCancel: state.capabilities.cancel,\n });\n }\n };\n\n onThreadUpdate();\n return subscribeToMainThread(provider, onThreadUpdate);\n }, [provider, context]);\n\n useInsertionEffect(\n () =>\n provider.subscribe(() => {\n (\n context.useThreadRuntime as unknown as StoreApi<ThreadRuntimeStore>\n ).setState(provider.thread, true);\n }),\n [provider, context],\n );\n\n // subscribe to thread updates\n const Synchronizer = context.useThreadRuntime(\n (t) => (t as ReactThreadRuntime).unstable_synchronizer,\n );\n\n return (\n <ThreadContext.Provider value={context}>\n {Synchronizer && <Synchronizer />}\n {children}\n </ThreadContext.Provider>\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { ComposerState } from \"../stores/Composer\";\nimport type { ThreadState } from \"../stores/Thread\";\nimport type { ThreadViewportState } from \"../stores/ThreadViewport\";\nimport { ThreadActionsState } from \"../stores/ThreadActions\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadMessagesState } from \"../stores/ThreadMessages\";\nimport { ThreadRuntimeStore } from \"../stores/ThreadRuntime\";\n\nexport type ThreadContextValue = {\n useThread: ReadonlyStore<ThreadState>;\n useThreadRuntime: ReadonlyStore<ThreadRuntimeStore>;\n useThreadMessages: ReadonlyStore<ThreadMessagesState>;\n useThreadActions: ReadonlyStore<ThreadActionsState>;\n useComposer: ReadonlyStore<ComposerState>;\n useViewport: ReadonlyStore<ThreadViewportState>;\n};\n\nexport const ThreadContext = createContext<ThreadContextValue | null>(null);\n\nexport function useThreadContext(): ThreadContextValue;\nexport function useThreadContext(options: {\n optional: true;\n}): ThreadContextValue | null;\nexport function useThreadContext(options?: { optional: true }) {\n const context = useContext(ThreadContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within an AssistantRuntimeProvider.\",\n );\n return context;\n}\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { Unsubscribe } from \"../../types/Unsubscribe\";\nimport { ThreadContextValue } from \"../react\";\n\nexport type ComposerState = Readonly<{\n /** @deprecated Use `text` instead. */\n value: string;\n /** @deprecated Use `setText` instead. */\n setValue: (value: string) => void;\n\n text: string;\n setText: (value: string) => void;\n\n canCancel: boolean;\n isEditing: true;\n\n send: () => void;\n cancel: () => void;\n focus: () => void;\n onFocus: (listener: () => void) => Unsubscribe;\n}>;\n\nexport const makeComposerStore = (\n useThreadRuntime: ThreadContextValue[\"useThreadRuntime\"],\n): ReadonlyStore<ComposerState> => {\n const focusListeners = new Set<() => void>();\n return create<ComposerState>()((_, get) => {\n const runtime = useThreadRuntime.getState();\n return {\n get value() {\n return get().text;\n },\n setValue(value) {\n get().setText(value);\n },\n\n text: runtime.composer.text,\n setText: (value) => {\n useThreadRuntime.getState().composer.setText(value);\n },\n\n canCancel: runtime.capabilities.cancel,\n isEditing: true,\n\n send: () => {\n const runtime = useThreadRuntime.getState();\n const text = runtime.composer.text;\n runtime.composer.setText(\"\");\n\n runtime.append({\n parentId: runtime.messages.at(-1)?.id ?? null,\n role: \"user\",\n content: [{ type: \"text\", text }],\n });\n },\n cancel: () => {\n useThreadRuntime.getState().cancelRun();\n },\n focus: () => {\n for (const listener of focusListeners) {\n listener();\n }\n },\n onFocus: (listener) => {\n focusListeners.add(listener);\n return () => {\n focusListeners.delete(listener);\n };\n },\n };\n });\n};\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\n\nexport type ThreadState = Readonly<{\n capabilities: Readonly<RuntimeCapabilities>;\n isRunning: boolean;\n isDisabled: boolean;\n}>;\n\nexport type RuntimeCapabilities = {\n switchToBranch: boolean;\n edit: boolean;\n reload: boolean;\n cancel: boolean;\n unstable_copy: boolean;\n speak: boolean;\n};\n\nexport const getThreadStateFromRuntime = (\n runtime: ThreadRuntimeStore,\n): ThreadState => {\n const lastMessage = runtime.messages.at(-1);\n return Object.freeze({\n capabilities: runtime.capabilities,\n isDisabled: runtime.isDisabled,\n isRunning:\n lastMessage?.role !== \"assistant\"\n ? false\n : lastMessage.status.type === \"running\",\n });\n};\n\nexport const makeThreadStore = (\n runtimeRef: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n const runtime = runtimeRef.getState();\n return create<ThreadState>(() => getThreadStateFromRuntime(runtime));\n};\n","\"use client\";\nimport { create } from \"zustand\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\n\nexport type ThreadViewportState = Readonly<{\n isAtBottom: boolean;\n scrollToBottom: () => void;\n onScrollToBottom: (callback: () => void) => Unsubscribe;\n}>;\n\nexport const makeThreadViewportStore = () => {\n const scrollToBottomListeners = new Set<() => void>();\n\n return create<ThreadViewportState>(() => ({\n isAtBottom: true,\n scrollToBottom: () => {\n for (const listener of scrollToBottomListeners) {\n listener();\n }\n },\n onScrollToBottom: (callback) => {\n scrollToBottomListeners.add(callback);\n return () => {\n scrollToBottomListeners.delete(callback);\n };\n },\n }));\n};\n","import { create } from \"zustand\";\nimport type { AppendMessage } from \"../../types/AssistantTypes\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\nimport { SpeechSynthesisAdapter } from \"../../runtimes/speech/SpeechAdapterTypes\";\n\nexport type AddToolResultOptions = {\n messageId: string;\n toolCallId: string;\n result: any;\n};\n\nexport type ThreadActionsState = Readonly<{\n getBranches: (messageId: string) => readonly string[];\n switchToBranch: (branchId: string) => void;\n\n append: (message: AppendMessage) => void;\n startRun: (parentId: string | null) => void;\n cancelRun: () => void;\n\n addToolResult: (options: AddToolResultOptions) => void;\n\n speak: (messageId: string) => SpeechSynthesisAdapter.Utterance;\n}>;\n\nexport const makeThreadActionStore = (\n runtimeStore: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n return create<ThreadActionsState>(() =>\n Object.freeze({\n getBranches: (messageId) =>\n runtimeStore.getState().getBranches(messageId),\n switchToBranch: (branchId) =>\n runtimeStore.getState().switchToBranch(branchId),\n\n startRun: (parentId) => runtimeStore.getState().startRun(parentId),\n append: (message) => runtimeStore.getState().append(message),\n cancelRun: () => runtimeStore.getState().cancelRun(),\n\n addToolResult: (options) =>\n runtimeStore.getState().addToolResult(options),\n\n speak: (messageId) => runtimeStore.getState().speak(messageId),\n }),\n );\n};\n","import { create } from \"zustand\";\nimport type { ThreadMessage } from \"../../types/AssistantTypes\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\n\nexport type ThreadMessagesState = readonly ThreadMessage[];\n\nexport const makeThreadMessagesStore = (\n runtimeRef: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n return create<ThreadMessagesState>(() => runtimeRef.getState().messages);\n};\n","import { create } from \"zustand\";\nimport { ThreadRuntime } from \"../../runtimes\";\n\nexport type ThreadRuntimeStore = ThreadRuntime;\n\nexport const makeThreadRuntimeStore = (runtime: ThreadRuntime) => {\n return create<ThreadRuntimeStore>(() => runtime);\n};\n","import { Unsubscribe } from \"../../types\";\nimport { ThreadRuntimeWithSubscribe } from \"./AssistantRuntime\";\n\nexport const subscribeToMainThread = (\n runtime: ThreadRuntimeWithSubscribe,\n callback: () => void,\n) => {\n let first = true;\n let cleanup: Unsubscribe | undefined;\n const inner = () => {\n cleanup?.();\n cleanup = runtime.thread.subscribe(callback);\n\n if (!first) {\n callback();\n }\n first = false;\n };\n\n const unsubscribe = runtime.subscribe(inner);\n inner();\n\n return () => {\n unsubscribe();\n cleanup?.();\n };\n};\n","\"use client\";\n\nimport { useInsertionEffect, useState } from \"react\";\nimport type { ChatModelAdapter } from \"./ChatModelAdapter\";\nimport { LocalRuntime } from \"./LocalRuntime\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\n\nexport const useLocalRuntime = (\n adapter: ChatModelAdapter,\n options: LocalRuntimeOptions = {},\n) => {\n const [runtime] = useState(() => new LocalRuntime(adapter, options));\n\n useInsertionEffect(() => {\n runtime.adapter = adapter;\n runtime.options = options;\n });\n\n return runtime;\n};\n","import { type ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\nimport type { AssistantRuntime } from \"./AssistantRuntime\";\nimport { ReactThreadRuntime } from \"./ReactThreadRuntime\";\n\nexport abstract class BaseAssistantRuntime<\n TThreadRuntime extends ReactThreadRuntime,\n> implements AssistantRuntime\n{\n constructor(private _thread: TThreadRuntime) {\n this._thread = _thread;\n }\n\n get thread() {\n return this._thread;\n }\n\n set thread(thread: TThreadRuntime) {\n this._thread = thread;\n this.subscriptionHandler();\n }\n\n public abstract registerModelConfigProvider(\n provider: ModelConfigProvider,\n ): Unsubscribe;\n public abstract switchToThread(threadId: string | null): void;\n\n private _subscriptions = new Set<() => void>();\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n private subscriptionHandler = () => {\n for (const callback of this._subscriptions) callback();\n };\n}\n","export { ProxyConfigProvider } from \"./utils/ProxyConfigProvider\";\nexport { MessageRepository } from \"./runtimes/utils/MessageRepository\";\nexport { BaseAssistantRuntime } from \"./runtimes/core/BaseAssistantRuntime\";\nexport * from \"./utils/smooth\";\nexport { TooltipIconButton } from \"./ui/base/tooltip-icon-button\";\nexport { generateId } from \"./utils/idUtils\";\n","import { customAlphabet } from \"nanoid/non-secure\";\n\nexport const generateId = customAlphabet(\n \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\",\n 7,\n);\n\nconst optimisticPrefix = \"__optimistic__\";\nexport const generateOptimisticId = () => `${optimisticPrefix}${generateId()}`;\nexport const isOptimisticId = (id: string) => id.startsWith(optimisticPrefix);\n","import { generateId } from \"../../../internal\";\nimport {\n ThreadMessage,\n CoreMessage,\n ToolCallContentPart,\n MessageStatus,\n} from \"../../../types\";\n\nexport const fromCoreMessages = (\n message: readonly CoreMessage[],\n): ThreadMessage[] => {\n return message.map((message) => fromCoreMessage(message));\n};\n\nexport const fromCoreMessage = (\n message: CoreMessage,\n {\n id = generateId(),\n status = { type: \"complete\", reason: \"unknown\" } as MessageStatus,\n } = {},\n): ThreadMessage => {\n const commonProps = {\n id,\n createdAt: new Date(),\n };\n\n const role = message.role;\n switch (role) {\n case \"assistant\":\n return {\n ...commonProps,\n role,\n content: message.content.map((part) => {\n if (part.type === \"tool-call\") {\n return {\n ...part,\n argsText: JSON.stringify(part.args),\n } satisfies ToolCallContentPart;\n }\n return part;\n }),\n status,\n } satisfies ThreadMessage;\n\n case \"user\":\n return {\n ...commonProps,\n role,\n content: message.content,\n } satisfies ThreadMessage;\n\n case \"system\":\n return {\n ...commonProps,\n role,\n content: message.content,\n } satisfies ThreadMessage;\n\n default: {\n const unsupportedRole: never = role;\n throw new Error(`Unknown message role: ${unsupportedRole}`);\n }\n }\n};\n","import type { CoreMessage, ThreadMessage } from \"../../types/AssistantTypes\";\nimport { generateOptimisticId } from \"../../utils/idUtils\";\nimport { fromCoreMessage } from \"../edge/converters/fromCoreMessage\";\n\ntype RepositoryParent = {\n children: string[];\n next: RepositoryMessage | null;\n};\n\ntype RepositoryMessage = RepositoryParent & {\n prev: RepositoryMessage | null;\n current: ThreadMessage;\n level: number;\n};\n\nexport interface ExportedMessageRepository {\n headId?: string | null;\n messages: Array<{\n message: ThreadMessage;\n parentId: string | null;\n }>;\n}\n\nconst findHead = (\n message: RepositoryMessage | RepositoryParent,\n): RepositoryMessage | null => {\n if (message.next) return findHead(message.next);\n if (\"current\" in message) return message;\n return null;\n};\n\nexport class MessageRepository {\n private messages = new Map<string, RepositoryMessage>(); // message_id -> item\n private head: RepositoryMessage | null = null;\n private root: RepositoryParent = {\n children: [],\n next: null,\n };\n\n private performOp(\n newParent: RepositoryMessage | null,\n child: RepositoryMessage,\n operation: \"cut\" | \"link\" | \"relink\",\n ) {\n const parentOrRoot = child.prev ?? this.root;\n const newParentOrRoot = newParent ?? this.root;\n\n if (operation === \"relink\" && parentOrRoot === newParentOrRoot) return;\n\n // cut\n if (operation !== \"link\") {\n // remove from parentOrRoot.children\n parentOrRoot.children = parentOrRoot.children.filter(\n (m) => m !== child.current.id,\n );\n\n // update parentOrRoot.next\n if (parentOrRoot.next === child) {\n const fallbackId = parentOrRoot.children.at(-1);\n const fallback = fallbackId ? this.messages.get(fallbackId) : null;\n if (fallback === undefined) {\n throw new Error(\n \"MessageRepository(performOp/cut): Fallback sibling message not found. This is likely an internal bug in assistant-ui.\",\n );\n }\n parentOrRoot.next = fallback;\n }\n }\n\n // link\n if (operation !== \"cut\") {\n // ensure the child is not part of parent tree\n for (\n let current: RepositoryMessage | null = newParent;\n current;\n current = current.prev\n ) {\n if (current.current.id === child.current.id) {\n throw new Error(\n \"MessageRepository(performOp/link): A message with the same id already exists in the parent tree. This error occurs if the same message id is found multiple times. This is likely an internal bug in assistant-ui.\",\n );\n }\n }\n\n // add to parentOrRoot.children\n newParentOrRoot.children = [\n ...newParentOrRoot.children,\n child.current.id,\n ];\n\n // update parentOrRoot.next\n if (findHead(child) === this.head || newParentOrRoot.next === null) {\n newParentOrRoot.next = child;\n }\n\n child.prev = newParent;\n }\n }\n getMessages() {\n const messages = new Array<ThreadMessage>(this.head?.level ?? 0);\n for (let current = this.head; current; current = current.prev) {\n messages[current.level] = current.current;\n }\n return messages;\n }\n\n addOrUpdateMessage(parentId: string | null, message: ThreadMessage) {\n const existingItem = this.messages.get(message.id);\n const prev = parentId ? this.messages.get(parentId) : null;\n if (prev === undefined)\n throw new Error(\n \"MessageRepository(addOrUpdateMessage): Parent message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n // update existing message\n if (existingItem) {\n existingItem.current = message;\n this.performOp(prev, existingItem, \"relink\");\n return;\n }\n\n // create a new message\n const newItem: RepositoryMessage = {\n prev,\n current: message,\n next: null,\n children: [],\n level: prev ? prev.level + 1 : 0,\n };\n\n this.messages.set(message.id, newItem);\n this.performOp(prev, newItem, \"link\");\n\n if (this.head === prev) {\n this.head = newItem;\n }\n }\n\n getMessage(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(updateMessage): Message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n return {\n parentId: message.prev?.current.id ?? null,\n message: message.current,\n };\n }\n\n appendOptimisticMessage(parentId: string | null, message: CoreMessage) {\n let optimisticId: string;\n do {\n optimisticId = generateOptimisticId();\n } while (this.messages.has(optimisticId));\n\n this.addOrUpdateMessage(\n parentId,\n fromCoreMessage(message, {\n id: optimisticId,\n status: { type: \"running\" },\n }),\n );\n\n return optimisticId;\n }\n\n deleteMessage(messageId: string, replacementId?: string | null | undefined) {\n const message = this.messages.get(messageId);\n\n if (!message)\n throw new Error(\n \"MessageRepository(deleteMessage): Optimistic message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const replacement =\n replacementId === undefined\n ? message.prev // if no replacementId is provided, use the parent\n : replacementId === null\n ? null\n : this.messages.get(replacementId);\n if (replacement === undefined)\n throw new Error(\n \"MessageRepository(deleteMessage): Replacement not found. This is likely an internal bug in assistant-ui.\",\n );\n\n for (const child of message.children) {\n const childMessage = this.messages.get(child);\n if (!childMessage)\n throw new Error(\n \"MessageRepository(deleteMessage): Child message not found. This is likely an internal bug in assistant-ui.\",\n );\n this.performOp(replacement, childMessage, \"relink\");\n }\n\n this.performOp(null, message, \"cut\");\n this.messages.delete(messageId);\n\n if (this.head === message) {\n this.head = findHead(replacement ?? this.root);\n }\n }\n\n getBranches(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(getBranches): Message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const { children } = message.prev ?? this.root;\n return children;\n }\n\n switchToBranch(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(switchToBranch): Branch not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const prevOrRoot = message.prev ?? this.root;\n prevOrRoot.next = message;\n\n this.head = findHead(message);\n }\n\n resetHead(messageId: string | null) {\n if (messageId === null) {\n this.head = null;\n return;\n }\n\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(resetHead): Branch not found. This is likely an internal bug in assistant-ui.\",\n );\n\n this.head = message;\n for (\n let current: RepositoryMessage | null = message;\n current;\n current = current.prev\n ) {\n if (current.prev) {\n current.prev.next = current;\n }\n }\n }\n\n export(): ExportedMessageRepository {\n const exportItems: ExportedMessageRepository[\"messages\"] = [];\n\n // hint: we are relying on the insertion order of the messages\n // this is important for the import function to properly link the messages\n for (const [, message] of this.messages) {\n exportItems.push({\n message: message.current,\n parentId: message.prev?.current.id ?? null,\n });\n }\n\n return {\n headId: this.head?.current.id ?? null,\n messages: exportItems,\n };\n }\n\n import({ headId, messages }: ExportedMessageRepository) {\n for (const { message, parentId } of messages) {\n this.addOrUpdateMessage(parentId, message);\n }\n\n // switch to the saved head id if it is not the most recent message\n this.resetHead(headId ?? messages.at(-1)?.message.id ?? null);\n }\n}\n","\"use client\";\n\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useMessageContext } from \"../../context\";\nimport {\n ContentPartStatus,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\nimport { TextContentPartState } from \"../../context/stores/ContentPart\";\nimport { useSmoothContext } from \"./SmoothContext\";\nimport { StoreApi } from \"zustand\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\n\nclass TextStreamAnimator {\n private animationFrameId: number | null = null;\n private lastUpdateTime: number = Date.now();\n\n public targetText: string = \"\";\n\n constructor(\n public currentText: string,\n private setText: (newText: string) => void,\n ) {}\n\n start() {\n if (this.animationFrameId !== null) return;\n this.lastUpdateTime = Date.now();\n this.animate();\n }\n\n stop() {\n if (this.animationFrameId !== null) {\n cancelAnimationFrame(this.animationFrameId);\n this.animationFrameId = null;\n }\n }\n\n private animate = () => {\n const currentTime = Date.now();\n const deltaTime = currentTime - this.lastUpdateTime;\n let timeToConsume = deltaTime;\n\n const remainingChars = this.targetText.length - this.currentText.length;\n const baseTimePerChar = Math.min(5, 250 / remainingChars);\n\n let charsToAdd = 0;\n while (timeToConsume >= baseTimePerChar && charsToAdd < remainingChars) {\n charsToAdd++;\n timeToConsume -= baseTimePerChar;\n }\n\n if (charsToAdd !== remainingChars) {\n this.animationFrameId = requestAnimationFrame(this.animate);\n } else {\n this.animationFrameId = null;\n }\n if (charsToAdd === 0) return;\n\n this.currentText = this.targetText.slice(\n 0,\n this.currentText.length + charsToAdd,\n );\n this.lastUpdateTime = currentTime - timeToConsume;\n this.setText(this.currentText);\n };\n}\n\nconst SMOOTH_STATUS: ContentPartStatus = Object.freeze({\n type: \"running\",\n});\n\nexport const useSmooth = (\n state: TextContentPartState,\n smooth: boolean = false,\n): TextContentPartState => {\n const { useSmoothStatus } = useSmoothContext({ optional: true }) ?? {};\n\n const {\n part: { text },\n } = state;\n const { useMessage } = useMessageContext();\n const id = useMessage((m) => m.message.id);\n\n const idRef = useRef(id);\n const [displayedText, setDisplayedText] = useState(text);\n\n const setText = useCallbackRef((text: string) => {\n setDisplayedText(text);\n (\n useSmoothStatus as unknown as\n | StoreApi<ToolCallContentPartStatus>\n | undefined\n )?.setState(text !== state.part.text ? SMOOTH_STATUS : state.status);\n });\n\n const [animatorRef] = useState<TextStreamAnimator>(\n new TextStreamAnimator(text, setText),\n );\n\n useEffect(() => {\n if (!smooth) {\n animatorRef.stop();\n return;\n }\n\n if (idRef.current !== id || !text.startsWith(animatorRef.targetText)) {\n idRef.current = id;\n setText(text);\n\n animatorRef.currentText = text;\n animatorRef.targetText = text;\n animatorRef.stop();\n\n return;\n }\n\n animatorRef.targetText = text;\n animatorRef.start();\n }, [setText, animatorRef, id, smooth, text]);\n\n useEffect(() => {\n return () => {\n animatorRef.stop();\n };\n }, [animatorRef]);\n\n return useMemo(\n () =>\n smooth\n ? {\n part: { type: \"text\", text: displayedText },\n status: text === displayedText ? state.status : SMOOTH_STATUS,\n }\n : state,\n [smooth, displayedText, state, text],\n );\n};\n","import {\n createContext,\n FC,\n forwardRef,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useContentPartContext } from \"../../context\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\nimport { create } from \"zustand\";\nimport {\n ContentPartStatus,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\n\ntype SmoothContextValue = {\n useSmoothStatus: ReadonlyStore<ToolCallContentPartStatus | ContentPartStatus>;\n};\n\nconst SmoothContext = createContext<SmoothContextValue | null>(null);\n\nconst makeSmoothContext = (\n initialState: ContentPartStatus | ToolCallContentPartStatus,\n) => {\n const useSmoothStatus = create(() => initialState);\n return { useSmoothStatus };\n};\n\nexport const SmoothContextProvider: FC<PropsWithChildren> = ({ children }) => {\n const outer = useSmoothContext({ optional: true });\n const { useContentPart } = useContentPartContext();\n\n const [context] = useState(() =>\n makeSmoothContext(useContentPart.getState().status),\n );\n\n // do not wrap if there is an outer SmoothContextProvider\n if (outer) return children;\n\n return (\n <SmoothContext.Provider value={context}>{children}</SmoothContext.Provider>\n );\n};\n\nexport const withSmoothContextProvider = <C extends React.ComponentType<any>>(\n Component: C,\n): C => {\n const Wrapped = forwardRef((props, ref) => {\n return (\n <SmoothContextProvider>\n <Component {...(props as any)} ref={ref} />\n </SmoothContextProvider>\n );\n });\n Wrapped.displayName = Component.displayName;\n return Wrapped as any;\n};\n\nexport function useSmoothContext(): SmoothContextValue;\nexport function useSmoothContext(options: {\n optional: true;\n}): SmoothContextValue | null;\nexport function useSmoothContext(options?: { optional: true }) {\n const context = useContext(SmoothContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within a SmoothContextProvider.\",\n );\n return context;\n}\n\nexport const useSmoothStatus = () => {\n const { useSmoothStatus } = useSmoothContext();\n return useSmoothStatus();\n};\n","\"use client\";\n\nimport { forwardRef } from \"react\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"./tooltip\";\nimport { Button, ButtonProps } from \"./button\";\n\nexport type TooltipIconButtonProps = ButtonProps & {\n tooltip: string;\n side?: \"top\" | \"bottom\" | \"left\" | \"right\";\n};\n\nexport const TooltipIconButton = forwardRef<\n HTMLButtonElement,\n TooltipIconButtonProps\n>(({ children, tooltip, side = \"bottom\", ...rest }, ref) => {\n return (\n <Tooltip>\n <TooltipTrigger asChild>\n <Button variant=\"ghost\" size=\"icon\" {...rest} ref={ref}>\n {children}\n <span className=\"aui-sr-only\">{tooltip}</span>\n </Button>\n </TooltipTrigger>\n <TooltipContent side={side}>{tooltip}</TooltipContent>\n </Tooltip>\n );\n});\n\nTooltipIconButton.displayName = \"TooltipIconButton\";\n","\"use client\";\n\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\nimport { withDefaults } from \"../utils/withDefaults\";\nimport { FC } from \"react\";\n\nexport const Tooltip: FC<TooltipPrimitive.TooltipProps> = (props) => {\n return (\n <TooltipPrimitive.Provider>\n <TooltipPrimitive.Root {...props} />\n </TooltipPrimitive.Provider>\n );\n};\n\nTooltip.displayName = \"Tooltip\";\n\nexport const TooltipTrigger = TooltipPrimitive.Trigger;\n\nexport const TooltipContent = withDefaults(TooltipPrimitive.Content, {\n sideOffset: 4,\n className: \"aui-tooltip-content\",\n});\n\nTooltipContent.displayName = \"TooltipContent\";\n","import {\n ComponentPropsWithoutRef,\n ElementRef,\n ElementType,\n forwardRef,\n} from \"react\";\nimport classNames from \"classnames\";\n\nexport const withDefaultProps =\n <TProps extends { className?: string }>({\n className,\n ...defaultProps\n }: Partial<TProps>) =>\n ({ className: classNameProp, ...props }: TProps) => {\n return {\n className: classNames(className, classNameProp),\n ...defaultProps,\n ...props,\n } as TProps;\n };\n\nexport const withDefaults = <TComponent extends ElementType>(\n Component: TComponent,\n defaultProps: Partial<ComponentPropsWithoutRef<TComponent>>,\n) => {\n type TComponentProps = typeof defaultProps;\n const getProps = withDefaultProps<TComponentProps>(defaultProps);\n const WithDefaults = forwardRef<ElementRef<TComponent>, TComponentProps>(\n (props, ref) => {\n const ComponentAsAny = Component as any;\n return <ComponentAsAny {...getProps(props as any)} ref={ref} />;\n },\n );\n WithDefaults.displayName =\n \"withDefaults(\" +\n (typeof Component === \"string\" ? Component : Component.displayName) +\n \")\";\n return WithDefaults;\n};\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { ElementRef, forwardRef } from \"react\";\n\nconst buttonVariants = cva(\"aui-button\", {\n variants: {\n variant: {\n default: \"aui-button-primary\",\n outline: \"aui-button-outline\",\n ghost: \"aui-button-ghost\",\n },\n size: {\n default: \"aui-button-medium\",\n icon: \"aui-button-icon\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n});\n\ntype ButtonElement = ElementRef<typeof Primitive.button>;\n\nexport type ButtonProps = React.ComponentPropsWithoutRef<\n typeof Primitive.button\n> &\n VariantProps<typeof buttonVariants>;\n\nconst Button = forwardRef<ButtonElement, ButtonProps>(\n ({ className, variant, size, ...props }, ref) => {\n return (\n <Primitive.button\n className={buttonVariants({ variant, size, className })}\n {...props}\n ref={ref}\n />\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","import { LanguageModelV1Message } from \"@ai-sdk/provider\";\nimport { CoreMessage, ToolCallContentPart } from \"../../../types\";\n\ntype fromLanguageModelMessagesOptions = {\n mergeRoundtrips: boolean;\n};\n\nexport const fromLanguageModelMessages = (\n lm: LanguageModelV1Message[],\n { mergeRoundtrips }: fromLanguageModelMessagesOptions,\n): CoreMessage[] => {\n const messages: CoreMessage[] = [];\n\n for (const lmMessage of lm) {\n const role = lmMessage.role;\n switch (role) {\n case \"system\": {\n messages.push({\n role: \"system\",\n content: [\n {\n type: \"text\",\n text: lmMessage.content,\n },\n ],\n });\n break;\n }\n case \"user\": {\n messages.push({\n role: \"user\",\n content: lmMessage.content.map((part) => {\n const type = part.type;\n switch (type) {\n case \"text\": {\n return {\n type: \"text\",\n text: part.text,\n };\n }\n case \"image\": {\n if (part.image instanceof URL) {\n return {\n type: \"image\",\n image: part.image.href,\n };\n }\n throw new Error(\"Only images with URL data are supported\");\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n }),\n });\n break;\n }\n case \"assistant\": {\n const newContent = lmMessage.content.map((part) => {\n if (part.type === \"tool-call\") {\n return {\n type: \"tool-call\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n argsText: JSON.stringify(part.args),\n args: part.args as Record<string, unknown>,\n } satisfies ToolCallContentPart;\n }\n return part;\n });\n\n if (mergeRoundtrips) {\n const previousMessage = messages[messages.length - 1];\n if (previousMessage?.role === \"assistant\") {\n previousMessage.content.push(...newContent);\n break;\n }\n }\n\n messages.push({\n role: \"assistant\",\n content: newContent,\n });\n break;\n }\n case \"tool\": {\n const previousMessage = messages[messages.length - 1];\n if (previousMessage?.role !== \"assistant\")\n throw new Error(\n \"A tool message must be preceded by an assistant message.\",\n );\n\n for (const tool of lmMessage.content) {\n const toolCall = previousMessage.content.find(\n (c): c is ToolCallContentPart =>\n c.type === \"tool-call\" && c.toolCallId === tool.toolCallId,\n );\n if (!toolCall)\n throw new Error(\"Received tool result for an unknown tool call.\");\n if (toolCall.toolName !== tool.toolName)\n throw new Error(\"Tool call name mismatch.\");\n\n toolCall.result = tool.result;\n if (tool.isError) {\n toolCall.isError = true;\n }\n }\n\n break;\n }\n\n default: {\n const unhandledRole: never = role;\n throw new Error(`Unknown message role: ${unhandledRole}`);\n }\n }\n }\n\n return messages;\n};\n","import { LanguageModelV1FunctionTool } from \"@ai-sdk/provider\";\nimport { Tool } from \"../../../types/ModelConfigTypes\";\n\nexport const fromLanguageModelTools = (\n tools: LanguageModelV1FunctionTool[],\n): Record<string, Tool<any, any>> => {\n return Object.fromEntries(\n tools.map((tool) => [\n tool.name,\n {\n description: tool.description,\n parameters: tool.parameters,\n },\n ]),\n );\n};\n","export function chunkByLineStream() {\n let buffer = \"\";\n\n return new TransformStream({\n transform(chunk, controller) {\n buffer += chunk;\n const lines = buffer.split(\"\\n\");\n\n // Process all complete lines\n for (let i = 0; i < lines.length - 1; i++) {\n controller.enqueue(lines[i]);\n }\n\n // Keep the last incomplete line in the buffer\n buffer = lines[lines.length - 1]!;\n },\n flush(controller) {\n // flush any remaining content in the buffer\n if (buffer) {\n controller.enqueue(buffer);\n }\n },\n });\n}\n","import { chunkByLineStream } from \"./chunkByLineStream\";\nimport { PipeableTransformStream } from \"./PipeableTransformStream\";\nimport { StreamPart } from \"./StreamPart\";\n\nconst decodeStreamPart = <T extends Record<string, unknown>>(\n part: string,\n): StreamPart<T> => {\n const index = part.indexOf(\":\");\n if (index === -1) throw new Error(\"Invalid stream part\");\n return {\n type: part.slice(0, index),\n value: JSON.parse(part.slice(index + 1)),\n };\n};\n\nexport function streamPartDecoderStream<T extends Record<string, unknown>>() {\n const decodeStream = new TransformStream<string, StreamPart<T>>({\n transform(chunk, controller) {\n controller.enqueue(decodeStreamPart<T>(chunk));\n },\n });\n\n return new PipeableTransformStream((readable) => {\n return readable\n .pipeThrough(new TextDecoderStream())\n .pipeThrough(chunkByLineStream())\n .pipeThrough(decodeStream);\n });\n}\n","import { streamPartDecoderStream } from \"./streamPartDecoderStream\";\nimport { streamPartEncoderStream } from \"./streamPartEncoderStream\";\nimport { StreamPart } from \"./StreamPart\";\n\nexport declare namespace StreamUtils {\n export { StreamPart };\n}\n\nexport const streamUtils = {\n streamPartEncoderStream,\n streamPartDecoderStream,\n};\n","import { LocalRuntimeOptions, useLocalRuntime } from \"..\";\nimport { useState } from \"react\";\nimport { EdgeChatAdapterOptions, EdgeChatAdapter } from \"./EdgeChatAdapter\";\n\nexport type EdgeRuntimeOptions = EdgeChatAdapterOptions & LocalRuntimeOptions;\n\nexport const useEdgeRuntime = ({\n initialMessages,\n maxToolRoundtrips,\n adapters,\n ...options\n}: EdgeRuntimeOptions) => {\n const [adapter] = useState(() => new EdgeChatAdapter(options));\n return useLocalRuntime(adapter, {\n initialMessages,\n maxToolRoundtrips,\n adapters,\n });\n};\n","import {\n AssistantStreamChunk,\n AssistantStreamChunkType,\n} from \"./AssistantStreamChunkType\";\nimport { StreamPart } from \"./utils/StreamPart\";\nimport { ToolResultStreamPart } from \"./toolResultStream\";\n\nexport function assistantDecoderStream() {\n const toolCallNames = new Map<string, string>();\n let currentToolCall:\n | { id: string; name: string; argsText: string }\n | undefined;\n\n return new TransformStream<\n StreamPart<AssistantStreamChunk>,\n ToolResultStreamPart\n >({\n transform({ type, value }, controller) {\n if (\n currentToolCall &&\n type !== AssistantStreamChunkType.ToolCallArgsTextDelta &&\n type !== AssistantStreamChunkType.Error\n ) {\n controller.enqueue({\n type: \"tool-call\",\n toolCallType: \"function\",\n toolCallId: currentToolCall.id,\n toolName: currentToolCall.name,\n args: currentToolCall.argsText,\n });\n currentToolCall = undefined;\n }\n\n switch (type) {\n case AssistantStreamChunkType.TextDelta: {\n controller.enqueue({\n type: \"text-delta\",\n textDelta: value,\n });\n break;\n }\n case AssistantStreamChunkType.ToolCallBegin: {\n const { id, name } = value;\n toolCallNames.set(id, name);\n currentToolCall = { id, name, argsText: \"\" };\n break;\n }\n case AssistantStreamChunkType.ToolCallArgsTextDelta: {\n const delta = value;\n currentToolCall!.argsText += delta;\n controller.enqueue({\n type: \"tool-call-delta\",\n toolCallType: \"function\",\n toolCallId: currentToolCall!.id,\n toolName: currentToolCall!.name,\n argsTextDelta: delta,\n });\n break;\n }\n case AssistantStreamChunkType.ToolCallResult: {\n controller.enqueue({\n type: \"tool-result\",\n toolCallType: \"function\",\n toolCallId: value.id,\n toolName: toolCallNames.get(value.id)!,\n result: value.result,\n });\n break;\n }\n case AssistantStreamChunkType.Finish: {\n controller.enqueue({\n type: \"finish\",\n ...value,\n });\n break;\n }\n case AssistantStreamChunkType.Error: {\n controller.enqueue({\n type: \"error\",\n error: value,\n });\n break;\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unhandled chunk type: ${unhandledType}`);\n }\n }\n },\n });\n}\n","import { ChatModelAdapter, ChatModelRunOptions } from \"../local\";\nimport { ChatModelRunResult } from \"../local/ChatModelAdapter\";\nimport { toCoreMessages } from \"./converters/toCoreMessages\";\nimport { toLanguageModelTools } from \"./converters/toLanguageModelTools\";\nimport { EdgeRuntimeRequestOptions } from \"./EdgeRuntimeRequestOptions\";\nimport { assistantDecoderStream } from \"./streams/assistantDecoderStream\";\nimport { streamPartDecoderStream } from \"./streams/utils/streamPartDecoderStream\";\nimport { runResultStream } from \"./streams/runResultStream\";\nimport { toolResultStream } from \"./streams/toolResultStream\";\n\nexport function asAsyncIterable<T>(\n source: ReadableStream<T>,\n): AsyncIterable<T> {\n return {\n [Symbol.asyncIterator]: () => {\n const reader = source.getReader();\n return {\n async next(): Promise<IteratorResult<T, undefined>> {\n const { done, value } = await reader.read();\n return done\n ? { done: true, value: undefined }\n : { done: false, value };\n },\n };\n },\n };\n}\nexport type EdgeChatAdapterOptions = {\n api: string;\n\n credentials?: RequestCredentials;\n headers?: Record<string, string> | Headers;\n body?: object;\n};\n\nexport class EdgeChatAdapter implements ChatModelAdapter {\n constructor(private options: EdgeChatAdapterOptions) {}\n\n async *run({ messages, abortSignal, config }: ChatModelRunOptions) {\n const headers = new Headers(this.options.headers);\n headers.set(\"Content-Type\", \"application/json\");\n\n const result = await fetch(this.options.api, {\n method: \"POST\",\n headers,\n credentials: this.options.credentials ?? \"same-origin\",\n body: JSON.stringify({\n system: config.system,\n messages: toCoreMessages(messages),\n tools: config.tools ? toLanguageModelTools(config.tools) : [],\n ...config.callSettings,\n ...config.config,\n\n ...this.options.body,\n } satisfies EdgeRuntimeRequestOptions),\n signal: abortSignal,\n });\n\n if (result.status !== 200) {\n throw new Error(`Status ${result.status}: ${await result.text()}`);\n }\n\n const stream = result\n .body!.pipeThrough(streamPartDecoderStream())\n .pipeThrough(assistantDecoderStream())\n .pipeThrough(toolResultStream(config.tools, abortSignal))\n .pipeThrough(runResultStream());\n\n let update: ChatModelRunResult | undefined;\n for await (update of asAsyncIterable(stream)) {\n yield update;\n }\n\n if (update === undefined)\n throw new Error(\"No data received from Edge Runtime\");\n }\n}\n","import type { ThreadAssistantMessage } from \"../../types\";\n\nexport const shouldContinue = (result: ThreadAssistantMessage) =>\n result.status?.type === \"requires-action\" &&\n result.status.reason === \"tool-calls\" &&\n result.content.every((c) => c.type !== \"tool-call\" || !!c.result);\n","import { AddToolResultOptions } from \"../../context\";\nimport { generateId } from \"../../internal\";\nimport type {\n ModelConfigProvider,\n AppendMessage,\n ThreadUserMessage,\n ThreadAssistantMessage,\n Unsubscribe,\n} from \"../../types\";\nimport { fromCoreMessages } from \"../edge\";\nimport {\n ExportedMessageRepository,\n MessageRepository,\n} from \"../utils/MessageRepository\";\nimport type { ChatModelAdapter, ChatModelRunResult } from \"./ChatModelAdapter\";\nimport { shouldContinue } from \"./shouldContinue\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\nimport { ThreadRuntime } from \"../core\";\nimport { SpeechSynthesisAdapter } from \"../speech\";\n\nexport class LocalThreadRuntime implements ThreadRuntime {\n private _subscriptions = new Set<() => void>();\n\n private abortController: AbortController | null = null;\n private readonly repository = new MessageRepository();\n\n public readonly capabilities = {\n switchToBranch: true,\n edit: true,\n reload: true,\n cancel: true,\n unstable_copy: true,\n speak: false,\n };\n\n public readonly isDisabled = false;\n\n public get messages() {\n return this.repository.getMessages();\n }\n\n public readonly composer = {\n text: \"\",\n setText: (value: string) => {\n this.composer.text = value;\n this.notifySubscribers();\n },\n };\n\n constructor(\n private configProvider: ModelConfigProvider,\n public adapter: ChatModelAdapter,\n { initialMessages, ...options }: LocalRuntimeOptions,\n ) {\n this.options = options;\n if (initialMessages) {\n let parentId: string | null = null;\n const messages = fromCoreMessages(initialMessages);\n for (const message of messages) {\n this.repository.addOrUpdateMessage(parentId, message);\n parentId = message.id;\n }\n }\n }\n\n private _options!: LocalRuntimeOptions;\n\n public get options() {\n return this._options;\n }\n\n public set options({ initialMessages, ...options }: LocalRuntimeOptions) {\n this._options = options;\n\n const canSpeak = options.adapters?.speech !== undefined;\n if (this.capabilities.speak !== canSpeak) {\n this.capabilities.speak = canSpeak;\n this.notifySubscribers();\n }\n }\n\n public getBranches(messageId: string): string[] {\n return this.repository.getBranches(messageId);\n }\n\n public switchToBranch(branchId: string): void {\n this.repository.switchToBranch(branchId);\n this.notifySubscribers();\n }\n\n public async append(message: AppendMessage): Promise<void> {\n if (message.role !== \"user\")\n throw new Error(\n \"Only appending user messages are supported in LocalRuntime. This is likely an internal bug in assistant-ui.\",\n );\n\n // add user message\n const userMessageId = generateId();\n const userMessage: ThreadUserMessage = {\n id: userMessageId,\n role: \"user\",\n content: message.content,\n createdAt: new Date(),\n };\n this.repository.addOrUpdateMessage(message.parentId, userMessage);\n\n await this.startRun(userMessageId);\n }\n\n public async startRun(parentId: string | null): Promise<void> {\n this.repository.resetHead(parentId);\n\n // add assistant message\n const id = generateId();\n let message: ThreadAssistantMessage = {\n id,\n role: \"assistant\",\n status: { type: \"running\" },\n content: [],\n createdAt: new Date(),\n };\n\n do {\n message = await this.performRoundtrip(parentId, message);\n } while (shouldContinue(message));\n }\n\n private async performRoundtrip(\n parentId: string | null,\n message: ThreadAssistantMessage,\n ) {\n const messages = this.repository.getMessages();\n\n // abort existing run\n this.abortController?.abort();\n this.abortController = new AbortController();\n\n const initialContent = message.content;\n const initialRoundtrips = message.metadata?.roundtrips;\n const initalCustom = message.metadata?.custom;\n const updateMessage = (m: Partial<ChatModelRunResult>) => {\n message = {\n ...message,\n ...(m.content\n ? { content: [...initialContent, ...(m.content ?? [])] }\n : undefined),\n status: m.status ?? message.status,\n // TODO deprecated, remove in v0.6\n ...(m.metadata?.roundtrips\n ? {\n roundtrips: [\n ...(initialRoundtrips ?? []),\n ...m.metadata.roundtrips,\n ],\n }\n : undefined),\n ...(m.metadata\n ? {\n metadata: {\n ...message.metadata,\n ...(m.metadata.roundtrips\n ? {\n roundtrips: [\n ...(initialRoundtrips ?? []),\n ...m.metadata.roundtrips,\n ],\n }\n : undefined),\n ...(m.metadata?.custom\n ? {\n custom: { ...(initalCustom ?? {}), ...m.metadata.custom },\n }\n : undefined),\n },\n }\n : undefined),\n };\n this.repository.addOrUpdateMessage(parentId, message);\n this.notifySubscribers();\n };\n\n const maxToolRoundtrips = this.options.maxToolRoundtrips ?? 1;\n const toolRoundtrips = message.metadata?.roundtrips?.length ?? 0;\n if (toolRoundtrips > maxToolRoundtrips) {\n // reached max tool roundtrips\n updateMessage({\n status: {\n type: \"incomplete\",\n reason: \"tool-calls\",\n },\n });\n return message;\n } else {\n updateMessage({\n status: {\n type: \"running\",\n },\n });\n }\n\n try {\n const promiseOrGenerator = this.adapter.run({\n messages,\n abortSignal: this.abortController.signal,\n config: this.configProvider.getModelConfig(),\n onUpdate: updateMessage,\n });\n\n // handle async iterator for streaming results\n if (Symbol.asyncIterator in promiseOrGenerator) {\n for await (const r of promiseOrGenerator) {\n updateMessage(r);\n }\n } else {\n updateMessage(await promiseOrGenerator);\n }\n\n this.abortController = null;\n\n if (message.status.type === \"running\") {\n updateMessage({\n status: { type: \"complete\", reason: \"unknown\" },\n });\n }\n } catch (e) {\n this.abortController = null;\n\n // TODO this should be handled by the run result stream\n if (e instanceof Error && e.name === \"AbortError\") {\n updateMessage({\n status: { type: \"incomplete\", reason: \"cancelled\" },\n });\n } else {\n updateMessage({\n status: { type: \"incomplete\", reason: \"error\", error: e },\n });\n\n throw e;\n }\n }\n return message;\n }\n\n cancelRun(): void {\n if (!this.abortController) return;\n\n this.abortController.abort();\n this.abortController = null;\n }\n\n private notifySubscribers() {\n for (const callback of this._subscriptions) callback();\n }\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n public addToolResult({\n messageId,\n toolCallId,\n result,\n }: AddToolResultOptions) {\n let { parentId, message } = this.repository.getMessage(messageId);\n\n if (message.role !== \"assistant\")\n throw new Error(\"Tried to add tool result to non-assistant message\");\n\n let added = false;\n let found = false;\n const newContent = message.content.map((c) => {\n if (c.type !== \"tool-call\") return c;\n if (c.toolCallId !== toolCallId) return c;\n found = true;\n if (!c.result) added = true;\n return {\n ...c,\n result,\n };\n });\n\n if (!found)\n throw new Error(\"Tried to add tool result to non-existing tool call\");\n\n message = {\n ...message,\n content: newContent,\n };\n this.repository.addOrUpdateMessage(parentId, message);\n\n if (added && shouldContinue(message)) {\n this.performRoundtrip(parentId, message);\n }\n }\n\n // TODO lift utterance state to thread runtime\n private _utterance: SpeechSynthesisAdapter.Utterance | undefined;\n\n public speak(messageId: string) {\n const adapter = this.options.adapters?.speech;\n if (!adapter) throw new Error(\"Speech adapter not configured\");\n\n const { message } = this.repository.getMessage(messageId);\n\n if (this._utterance) {\n this._utterance.cancel();\n this._utterance = undefined;\n }\n\n const utterance = adapter.speak(message);\n utterance.onEnd(() => {\n if (this._utterance === utterance) {\n this._utterance = undefined;\n }\n });\n this._utterance = utterance;\n\n return this._utterance;\n }\n\n public export() {\n return this.repository.export();\n }\n\n public import(data: ExportedMessageRepository) {\n this.repository.import(data);\n this.notifySubscribers();\n }\n}\n","import { type ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport type { CoreMessage } from \"../../types/AssistantTypes\";\nimport { BaseAssistantRuntime } from \"../core/BaseAssistantRuntime\";\nimport type { ChatModelAdapter } from \"./ChatModelAdapter\";\nimport { ProxyConfigProvider } from \"../../internal\";\nimport { LocalThreadRuntime } from \"./LocalThreadRuntime\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\nimport { fromCoreMessages } from \"../edge/converters/fromCoreMessage\";\n\nexport class LocalRuntime extends BaseAssistantRuntime<LocalThreadRuntime> {\n private readonly _proxyConfigProvider: ProxyConfigProvider;\n\n constructor(adapter: ChatModelAdapter, options: LocalRuntimeOptions) {\n const proxyConfigProvider = new ProxyConfigProvider();\n super(new LocalThreadRuntime(proxyConfigProvider, adapter, options));\n this._proxyConfigProvider = proxyConfigProvider;\n }\n\n public set adapter(adapter: ChatModelAdapter) {\n this.thread.adapter = adapter;\n }\n\n public set options(options: LocalRuntimeOptions) {\n this.thread.options = options;\n }\n\n registerModelConfigProvider(provider: ModelConfigProvider) {\n return this._proxyConfigProvider.registerModelConfigProvider(provider);\n }\n\n public switchToThread(threadId: string | null) {\n if (threadId) {\n throw new Error(\"LocalRuntime does not yet support switching threads\");\n }\n\n const { initialMessages, ...options } = this.thread.options;\n\n return (this.thread = new LocalThreadRuntime(\n this._proxyConfigProvider,\n this.thread.adapter,\n options,\n ));\n }\n\n public reset({\n initialMessages,\n }: {\n initialMessages?: readonly CoreMessage[] | undefined;\n } = {}) {\n this.switchToThread(null);\n if (!initialMessages) return;\n\n const messages = fromCoreMessages(initialMessages);\n this.thread.import({\n messages: messages.map((m, idx) => ({\n parentId: messages[idx - 1]?.id ?? null,\n message: m,\n })),\n });\n }\n}\n","import { ThreadMessage } from \"../../types\";\n\nexport const symbolInnerMessage = Symbol(\"innerMessage\");\n\nexport type ExternalStoreThreadMessage<T> = ThreadMessage & {\n [symbolInnerMessage]?: T;\n};\n\nexport const getExternalStoreMessage = <T,>(message: ThreadMessage) => {\n return (message as ExternalStoreThreadMessage<T>)[symbolInnerMessage];\n};\n","import { ThreadMessage } from \"../../types\";\n\nexport type ConverterCallback<TIn> = (\n cache: ThreadMessage | undefined,\n message: TIn,\n idx: number,\n) => ThreadMessage;\n\nexport class ThreadMessageConverter {\n private readonly cache = new WeakMap<WeakKey, ThreadMessage>();\n\n convertMessages<TIn extends WeakKey>(\n messages: TIn[],\n converter: ConverterCallback<TIn>,\n ): ThreadMessage[] {\n return messages.map((m, idx) => {\n const cached = this.cache.get(m);\n const newMessage = converter(cached, m, idx);\n this.cache.set(m, newMessage);\n return newMessage;\n });\n }\n}\n","import { MessageStatus } from \"../../types\";\n\nconst AUTO_STATUS_RUNNING = Object.freeze({ type: \"running\" });\nconst AUTO_STATUS_COMPLETE = Object.freeze({\n type: \"complete\",\n reason: \"unknown\",\n});\n\nexport const isAutoStatus = (status: MessageStatus) =>\n status === AUTO_STATUS_RUNNING || status === AUTO_STATUS_COMPLETE;\n\nexport const getAutoStatus = (isLast: boolean, isRunning: boolean) =>\n isLast && isRunning ? AUTO_STATUS_RUNNING : AUTO_STATUS_COMPLETE;\n","import {\n MessageStatus,\n TextContentPart,\n ImageContentPart,\n ToolCallContentPart,\n UIContentPart,\n ThreadMessage,\n ThreadAssistantContentPart,\n ThreadAssistantMessage,\n ThreadUserContentPart,\n ThreadUserMessage,\n ThreadSystemMessage,\n} from \"../../types\";\nimport { CoreToolCallContentPart } from \"../../types/AssistantTypes\";\n\nexport type ThreadMessageLike = {\n role: \"assistant\" | \"user\" | \"system\";\n content: (\n | TextContentPart\n | ImageContentPart\n | ToolCallContentPart<any, any>\n | CoreToolCallContentPart<any, any>\n | UIContentPart\n )[];\n id?: string | undefined;\n createdAt?: Date | undefined;\n status?: MessageStatus | undefined;\n};\n\nexport const fromThreadMessageLike = (\n like: ThreadMessageLike,\n fallbackId: string,\n fallbackStatus: MessageStatus,\n): ThreadMessage => {\n const { role, content, id, createdAt, status } = like;\n const common = {\n id: id ?? fallbackId,\n createdAt: createdAt ?? new Date(),\n };\n switch (role) {\n case \"assistant\":\n return {\n ...common,\n role,\n content: content.map((part): ThreadAssistantContentPart => {\n const type = part.type;\n switch (type) {\n case \"text\":\n case \"ui\":\n return part;\n\n case \"tool-call\": {\n if (\"argsText\" in part) return part;\n return {\n ...part,\n argsText: JSON.stringify(part.args),\n };\n }\n\n default: {\n const unhandledType: \"image\" = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n }),\n status: status ?? fallbackStatus,\n } satisfies ThreadAssistantMessage;\n\n case \"user\":\n return {\n ...common,\n role,\n content: content.map((part): ThreadUserContentPart => {\n const type = part.type;\n switch (type) {\n case \"text\":\n case \"ui\":\n case \"image\":\n return part;\n\n default: {\n const unhandledType: \"tool-call\" = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n }),\n } satisfies ThreadUserMessage;\n\n case \"system\":\n if (content.length !== 1 || content[0]!.type !== \"text\")\n throw new Error(\n \"System messages must have exactly one text content part.\",\n );\n\n return {\n ...common,\n role,\n content: content as [TextContentPart],\n } satisfies ThreadSystemMessage;\n\n default: {\n const unsupportedRole: never = role;\n throw new Error(`Unknown message role: ${unsupportedRole}`);\n }\n }\n};\n","import type { TextContentPart, ThreadMessage } from \"../types/AssistantTypes\";\n\nexport const getThreadMessageText = (message: ThreadMessage) => {\n const textParts = message.content.filter(\n (part) => part.type === \"text\",\n ) as TextContentPart[];\n\n return textParts.map((part) => part.text).join(\"\\n\\n\");\n};\n","import { ReactThreadRuntime } from \"../core\";\nimport { MessageRepository } from \"../utils/MessageRepository\";\nimport { AppendMessage, ThreadMessage, Unsubscribe } from \"../../types\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\nimport { AddToolResultOptions } from \"../../context\";\nimport {\n getExternalStoreMessage,\n symbolInnerMessage,\n} from \"./getExternalStoreMessage\";\nimport { ThreadMessageConverter } from \"./ThreadMessageConverter\";\nimport { getAutoStatus, isAutoStatus } from \"./auto-status\";\nimport { fromThreadMessageLike } from \"./ThreadMessageLike\";\nimport { RuntimeCapabilities } from \"../../context/stores/Thread\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\n\nexport const hasUpcomingMessage = (\n isRunning: boolean,\n messages: ThreadMessage[],\n) => {\n return isRunning && messages[messages.length - 1]?.role !== \"assistant\";\n};\n\nexport class ExternalStoreThreadRuntime implements ReactThreadRuntime {\n private _subscriptions = new Set<() => void>();\n private repository = new MessageRepository();\n private assistantOptimisticId: string | null = null;\n\n private _capabilities: RuntimeCapabilities = {\n switchToBranch: false,\n edit: false,\n reload: false,\n cancel: false,\n unstable_copy: false,\n speak: false,\n };\n\n public get capabilities() {\n return this._capabilities;\n }\n\n public messages: ThreadMessage[] = [];\n public isDisabled = false;\n public converter = new ThreadMessageConverter();\n\n private _store!: ExternalStoreAdapter<any>;\n\n public readonly composer = {\n text: \"\",\n setText: (value: string) => {\n this.composer.text = value;\n this.notifySubscribers();\n },\n };\n\n constructor(store: ExternalStoreAdapter<any>) {\n this.store = store;\n }\n\n public set store(store: ExternalStoreAdapter<any>) {\n if (this._store === store) return;\n\n const isRunning = store.isRunning ?? false;\n this.isDisabled = store.isDisabled ?? false;\n\n const oldStore = this._store as ExternalStoreAdapter<any> | undefined;\n this._store = store;\n this._capabilities = {\n switchToBranch: this._store.setMessages !== undefined,\n edit: this._store.onEdit !== undefined,\n reload: this._store.onReload !== undefined,\n cancel: this._store.onCancel !== undefined,\n unstable_copy: this._store.unstable_capabilities?.copy !== null,\n speak: this._store.onSpeak !== undefined,\n };\n\n if (oldStore) {\n // flush the converter cache when the convertMessage prop changes\n if (oldStore.convertMessage !== store.convertMessage) {\n this.converter = new ThreadMessageConverter();\n } else if (\n oldStore.isRunning === store.isRunning &&\n oldStore.messages === store.messages\n ) {\n this.notifySubscribers();\n // no conversion update\n return;\n }\n }\n\n const messages = !store.convertMessage\n ? store.messages\n : this.converter.convertMessages(store.messages, (cache, m, idx) => {\n if (!store.convertMessage) return m;\n\n const isLast = idx === store.messages.length - 1;\n const autoStatus = getAutoStatus(isLast, isRunning);\n\n if (\n cache &&\n (cache.role !== \"assistant\" ||\n !isAutoStatus(cache.status) ||\n cache.status === autoStatus)\n )\n return cache;\n\n const newMessage = fromThreadMessageLike(\n store.convertMessage(m, idx),\n idx.toString(),\n autoStatus,\n );\n (newMessage as any)[symbolInnerMessage] = m;\n return newMessage;\n });\n\n for (let i = 0; i < messages.length; i++) {\n const message = messages[i]!;\n const parent = messages[i - 1];\n this.repository.addOrUpdateMessage(parent?.id ?? null, message);\n }\n\n if (this.assistantOptimisticId) {\n this.repository.deleteMessage(this.assistantOptimisticId);\n this.assistantOptimisticId = null;\n }\n\n if (hasUpcomingMessage(isRunning, messages)) {\n this.assistantOptimisticId = this.repository.appendOptimisticMessage(\n messages.at(-1)?.id ?? null,\n {\n role: \"assistant\",\n content: [],\n },\n );\n }\n\n this.repository.resetHead(\n this.assistantOptimisticId ?? messages.at(-1)?.id ?? null,\n );\n\n this.messages = this.repository.getMessages();\n this.notifySubscribers();\n }\n\n private notifySubscribers() {\n for (const callback of this._subscriptions) callback();\n }\n\n public getBranches(messageId: string): string[] {\n return this.repository.getBranches(messageId);\n }\n\n public switchToBranch(branchId: string): void {\n if (!this._store.setMessages)\n throw new Error(\"Runtime does not support switching branches.\");\n\n this.repository.switchToBranch(branchId);\n this.updateMessages(this.repository.getMessages());\n }\n\n public async append(message: AppendMessage): Promise<void> {\n if (message.parentId !== (this.messages.at(-1)?.id ?? null)) {\n if (!this._store.onEdit)\n throw new Error(\"Runtime does not support editing messages.\");\n await this._store.onEdit(message);\n } else {\n await this._store.onNew(message);\n }\n }\n\n public async startRun(parentId: string | null): Promise<void> {\n if (!this._store.onReload)\n throw new Error(\"Runtime does not support reloading messages.\");\n\n await this._store.onReload(parentId);\n }\n\n public cancelRun(): void {\n if (!this._store.onCancel)\n throw new Error(\"Runtime does not support cancelling runs.\");\n\n this._store.onCancel();\n\n if (this.assistantOptimisticId) {\n this.repository.deleteMessage(this.assistantOptimisticId);\n this.assistantOptimisticId = null;\n }\n\n let messages = this.repository.getMessages();\n const previousMessage = messages[messages.length - 1];\n if (\n previousMessage?.role === \"user\" &&\n previousMessage.id === messages.at(-1)?.id // ensure the previous message is a leaf node\n ) {\n this.repository.deleteMessage(previousMessage.id);\n if (!this.composer.text.trim()) {\n this.composer.setText(getThreadMessageText(previousMessage));\n }\n\n messages = this.repository.getMessages();\n } else {\n this.notifySubscribers();\n }\n\n // resync messages (for reloading, to restore the previous branch)\n setTimeout(() => {\n this.updateMessages(messages);\n }, 0);\n }\n\n public addToolResult(options: AddToolResultOptions) {\n if (!this._store.onAddToolResult)\n throw new Error(\"Runtime does not support tool results.\");\n this._store.onAddToolResult(options);\n }\n\n public speak(messageId: string) {\n if (!this._store.onSpeak)\n throw new Error(\"Runtime does not support speaking.\");\n\n const { message } = this.repository.getMessage(messageId);\n return this._store.onSpeak(message);\n }\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n private updateMessages = (messages: ThreadMessage[]) => {\n this._store.setMessages?.(\n messages.flatMap(getExternalStoreMessage).filter((m) => m != null),\n );\n };\n}\n","import { BaseAssistantRuntime, ProxyConfigProvider } from \"../../internal\";\nimport { ModelConfigProvider } from \"../../types\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\nimport { ExternalStoreThreadRuntime } from \"./ExternalStoreThreadRuntime\";\n\nexport class ExternalStoreRuntime extends BaseAssistantRuntime<ExternalStoreThreadRuntime> {\n private readonly _proxyConfigProvider = new ProxyConfigProvider();\n\n constructor(store: ExternalStoreAdapter<any>) {\n super(new ExternalStoreThreadRuntime(store));\n }\n\n public set store(store: ExternalStoreAdapter<any>) {\n this.thread.store = store;\n }\n\n public getModelConfig() {\n return this._proxyConfigProvider.getModelConfig();\n }\n\n public registerModelConfigProvider(provider: ModelConfigProvider) {\n return this._proxyConfigProvider.registerModelConfigProvider(provider);\n }\n\n public async switchToThread(threadId: string | null) {\n if (threadId) {\n if (!this.store.onSwitchThread)\n throw new Error(\"Runtime does not support switching threads.\");\n\n this.thread = new ExternalStoreThreadRuntime({\n messages: [],\n onNew: this.store.onNew,\n });\n this.store.onSwitchThread(threadId);\n } else {\n if (!this.store.onNewThread)\n throw new Error(\"Runtime does not support switching to new threads.\");\n\n this.thread = new ExternalStoreThreadRuntime({\n messages: [],\n onNew: this.store.onNew,\n });\n await this.store.onNewThread();\n }\n }\n}\n","import { useEffect, useState } from \"react\";\nimport { ExternalStoreRuntime } from \"./ExternalStoreRuntime\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\n\nexport const useExternalStoreRuntime = <T,>(store: ExternalStoreAdapter<T>) => {\n const [runtime] = useState(() => new ExternalStoreRuntime(store));\n\n useEffect(() => {\n runtime.store = store;\n });\n\n return runtime;\n};\n","import { LocalRuntimeOptions, useLocalRuntime } from \"..\";\nimport { useState } from \"react\";\nimport {\n DangerousInBrowserAdapter,\n DangerousInBrowserAdapterOptions,\n} from \"./DangerousInBrowserAdapter\";\n\nexport type DangerousInBrowserRuntimeOptions =\n DangerousInBrowserAdapterOptions & LocalRuntimeOptions;\n\nexport const useDangerousInBrowserRuntime = ({\n initialMessages,\n ...options\n}: DangerousInBrowserRuntimeOptions) => {\n const [adapter] = useState(() => new DangerousInBrowserAdapter(options));\n return useLocalRuntime(adapter, { initialMessages });\n};\n","import { ChatModelAdapter, ChatModelRunOptions } from \"../local\";\nimport { toCoreMessages } from \"../edge/converters/toCoreMessages\";\nimport { toLanguageModelTools } from \"../edge/converters/toLanguageModelTools\";\nimport { EdgeRuntimeRequestOptions } from \"../edge/EdgeRuntimeRequestOptions\";\nimport { runResultStream } from \"../edge/streams/runResultStream\";\nimport { toolResultStream } from \"../edge/streams/toolResultStream\";\nimport { asAsyncIterable } from \"../edge/EdgeChatAdapter\";\nimport {\n CreateEdgeRuntimeAPIOptions,\n getEdgeRuntimeStream,\n} from \"../edge/createEdgeRuntimeAPI\";\n\nexport type DangerousInBrowserAdapterOptions = CreateEdgeRuntimeAPIOptions;\n\nexport class DangerousInBrowserAdapter implements ChatModelAdapter {\n constructor(private options: DangerousInBrowserAdapterOptions) {}\n\n async *run({ messages, abortSignal, config }: ChatModelRunOptions) {\n const res = await getEdgeRuntimeStream({\n options: this.options,\n abortSignal,\n requestData: {\n system: config.system,\n messages: toCoreMessages(messages),\n tools: config.tools ? toLanguageModelTools(config.tools) : [],\n ...config.callSettings,\n ...config.config,\n } satisfies EdgeRuntimeRequestOptions,\n });\n\n const stream = res\n .pipeThrough(toolResultStream(config.tools, abortSignal))\n .pipeThrough(runResultStream());\n\n for await (const update of asAsyncIterable(stream)) {\n yield update;\n }\n }\n}\n","import { ThreadMessage } from \"../../types\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\nimport { SpeechSynthesisAdapter } from \"./SpeechAdapterTypes\";\n\nexport class WebSpeechSynthesisAdapter implements SpeechSynthesisAdapter {\n speak(message: ThreadMessage): SpeechSynthesisAdapter.Utterance {\n const text = getThreadMessageText(message);\n const utterance = new SpeechSynthesisUtterance(text);\n\n const endHandlers = new Set<() => void>();\n const handleEnd = (\n reason: \"finished\" | \"error\" | \"cancelled\",\n error?: unknown,\n ) => {\n if (res.status.type === \"ended\") return;\n\n res.status = { type: \"ended\", reason, error };\n endHandlers.forEach((handler) => handler());\n };\n\n utterance.addEventListener(\"end\", () => handleEnd(\"finished\"));\n utterance.addEventListener(\"error\", (e) => handleEnd(\"error\", e.error));\n\n window.speechSynthesis.speak(utterance);\n\n const res: SpeechSynthesisAdapter.Utterance = {\n status: { type: \"running\" },\n cancel: () => {\n window.speechSynthesis.cancel();\n handleEnd(\"cancelled\");\n },\n onEnd: (callback) => {\n if (res.status.type === \"ended\") {\n let cancelled = false;\n queueMicrotask(() => {\n if (!cancelled) callback();\n });\n return () => {\n cancelled = true;\n };\n } else {\n endHandlers.add(callback);\n return () => {\n endHandlers.delete(callback);\n };\n }\n },\n };\n return res;\n }\n}\n","import { create } from \"zustand\";\nimport { AssistantRuntime } from \"../../runtimes\";\nimport { MutableRefObject } from \"react\";\n\nexport type AssistantActionsState = Readonly<{\n switchToThread: (threadId: string | null) => void;\n getRuntime: () => AssistantRuntime;\n}>;\n\nexport const makeAssistantActionsStore = (\n runtimeRef: MutableRefObject<AssistantRuntime>,\n) =>\n create<AssistantActionsState>(() =>\n Object.freeze({\n switchToThread: () => runtimeRef.current.switchToThread(null),\n getRuntime: () => runtimeRef.current,\n }),\n );\n","import { create } from \"zustand\";\nimport { AssistantRuntime } from \"../../runtimes\";\n\nexport type AssistantRuntimeStore = AssistantRuntime;\n\nexport const makeAssistantRuntimeStore = (runtime: AssistantRuntime) => {\n return create<AssistantRuntimeStore>(() => runtime);\n};\n","import { useMemo } from \"react\";\nimport { useMessageContext } from \"./MessageContext\";\nimport { useThreadContext } from \"./ThreadContext\";\nimport type { ComposerState } from \"../stores/Composer\";\nimport type { EditComposerState } from \"../stores/EditComposer\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type ComposerContextValue = {\n useComposer: ReadonlyStore<EditComposerState | ComposerState>;\n type: \"edit\" | \"new\";\n};\n\nexport const useComposerContext = (): ComposerContextValue => {\n const { useComposer } = useThreadContext();\n const { useEditComposer } = useMessageContext({ optional: true }) ?? {};\n return useMemo(\n () => ({\n useComposer: (useEditComposer ?? useComposer) as ReadonlyStore<\n EditComposerState | ComposerState\n >,\n type: useEditComposer ? (\"edit\" as const) : (\"new\" as const),\n }),\n [useEditComposer, useComposer],\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { MessageState } from \"../stores/Message\";\nimport type { EditComposerState } from \"../stores/EditComposer\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { MessageUtilsState } from \"../stores/MessageUtils\";\n\nexport type MessageContextValue = {\n useMessage: ReadonlyStore<MessageState>;\n useMessageUtils: ReadonlyStore<MessageUtilsState>;\n useEditComposer: ReadonlyStore<EditComposerState>;\n};\n\nexport const MessageContext = createContext<MessageContextValue | null>(null);\n\nexport function useMessageContext(): MessageContextValue;\nexport function useMessageContext(options: {\n optional: true;\n}): MessageContextValue | null;\nexport function useMessageContext(options?: { optional: true }) {\n const context = useContext(MessageContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component can only be used inside a component passed to <ThreadPrimitive.Messages components={...} />.\",\n );\n return context;\n}\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { ContentPartState } from \"../stores/ContentPart\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type ContentPartContextValue = {\n useContentPart: ReadonlyStore<ContentPartState>;\n};\n\nexport const ContentPartContext = createContext<ContentPartContextValue | null>(\n null,\n);\n\nexport function useContentPartContext(): ContentPartContextValue;\nexport function useContentPartContext(options: {\n optional: true;\n}): ContentPartContextValue | null;\nexport function useContentPartContext(options?: { optional: true }) {\n const context = useContext(ContentPartContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component can only be used inside a component passed to <MessagePrimitive.Content components={...} >.\",\n );\n return context;\n}\n","import { useCallback } from \"react\";\nimport { ThreadContextValue, useThreadContext } from \"../context\";\nimport { AppendMessage } from \"../types\";\n\ntype CreateAppendMessage =\n | string\n | {\n parentId?: string | null | undefined;\n role?: AppendMessage[\"role\"] | undefined;\n content: AppendMessage[\"content\"];\n };\n\nconst toAppendMessage = (\n useThreadMessages: ThreadContextValue[\"useThreadMessages\"],\n message: CreateAppendMessage,\n): AppendMessage => {\n if (typeof message === \"string\") {\n return {\n parentId: useThreadMessages.getState().at(-1)?.id ?? null,\n role: \"user\",\n content: [{ type: \"text\", text: message }],\n };\n }\n\n return {\n parentId:\n message.parentId ?? useThreadMessages.getState().at(-1)?.id ?? null,\n role: message.role ?? \"user\",\n content: message.content,\n } as AppendMessage;\n};\n\nexport const useAppendMessage = () => {\n const { useThreadMessages, useThreadActions, useViewport, useComposer } =\n useThreadContext();\n\n const append = useCallback(\n (message: CreateAppendMessage) => {\n const appendMessage = toAppendMessage(useThreadMessages, message);\n useThreadActions.getState().append(appendMessage);\n\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n },\n [useThreadMessages, useThreadActions, useViewport, useComposer],\n );\n\n return append;\n};\n","import { useCallback } from \"react\";\nimport { useAssistantContext, useThreadContext } from \"../context\";\n\nexport const useSwitchToNewThread = () => {\n const { useAssistantActions } = useAssistantContext();\n const { useComposer } = useThreadContext();\n\n const switchToNewThread = useCallback(() => {\n useAssistantActions.getState().switchToThread(null);\n useComposer.getState().focus();\n }, [useAssistantActions, useComposer]);\n\n return switchToNewThread;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\nimport type { ToolCallContentPartComponent } from \"../types/ContentPartComponentTypes\";\nimport type { Tool } from \"../types/ModelConfigTypes\";\n\nexport type AssistantToolProps<\n TArgs extends Record<string, unknown>,\n TResult,\n> = Tool<TArgs, TResult> & {\n toolName: string;\n render?: ToolCallContentPartComponent<TArgs, TResult> | undefined;\n};\n\nexport const useAssistantTool = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolProps<TArgs, TResult>,\n) => {\n const { useModelConfig, useToolUIs } = useAssistantContext();\n const registerModelConfigProvider = useModelConfig(\n (s) => s.registerModelConfigProvider,\n );\n const setToolUI = useToolUIs((s) => s.setToolUI);\n useEffect(() => {\n const { toolName, render, ...rest } = tool;\n const config = {\n tools: {\n [tool.toolName]: rest,\n },\n };\n const unsub1 = registerModelConfigProvider({\n getModelConfig: () => config,\n });\n const unsub2 = render ? setToolUI(toolName, render) : undefined;\n return () => {\n unsub1();\n unsub2?.();\n };\n }, [registerModelConfigProvider, setToolUI, tool]);\n};\n","\"use client\";\nimport { type AssistantToolProps, useAssistantTool } from \"./useAssistantTool\";\n\nexport const makeAssistantTool = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolProps<TArgs, TResult>,\n) => {\n const Tool = () => {\n useAssistantTool(tool);\n return null;\n };\n return Tool;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\nimport type { ToolCallContentPartComponent } from \"../types/ContentPartComponentTypes\";\n\nexport type AssistantToolUIProps<\n TArgs extends Record<string, unknown>,\n TResult,\n> = {\n toolName: string;\n render: ToolCallContentPartComponent<TArgs, TResult>;\n};\n\nexport const useAssistantToolUI = (\n tool: AssistantToolUIProps<any, any> | null,\n) => {\n const { useToolUIs } = useAssistantContext();\n const setToolUI = useToolUIs((s) => s.setToolUI);\n useEffect(() => {\n if (!tool) return;\n const { toolName, render } = tool;\n return setToolUI(toolName, render);\n }, [setToolUI, tool]);\n};\n","\"use client\";\nimport {\n type AssistantToolUIProps,\n useAssistantToolUI,\n} from \"./useAssistantToolUI\";\n\nexport const makeAssistantToolUI = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolUIProps<TArgs, TResult>,\n) => {\n const ToolUI = () => {\n useAssistantToolUI(tool);\n return null;\n };\n return ToolUI;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\n\nexport const useAssistantInstructions = (instruction: string) => {\n const { useModelConfig } = useAssistantContext();\n const registerModelConfigProvider = useModelConfig(\n (s) => s.registerModelConfigProvider,\n );\n useEffect(() => {\n const config = {\n system: instruction,\n };\n return registerModelConfigProvider({ getModelConfig: () => config });\n }, [registerModelConfigProvider, instruction]);\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\n\nexport type UseActionBarCopyProps = {\n copiedDuration?: number | undefined;\n};\n\nexport const useActionBarCopy = ({\n copiedDuration = 3000,\n}: UseActionBarCopyProps = {}) => {\n const { useMessage, useMessageUtils, useEditComposer } = useMessageContext();\n\n const hasCopyableContent = useCombinedStore(\n [useMessage, useEditComposer],\n ({ message }, c) => {\n return (\n !c.isEditing &&\n (message.role !== \"assistant\" || message.status.type !== \"running\") &&\n message.content.some((c) => c.type === \"text\" && c.text.length > 0)\n );\n },\n );\n\n const callback = useCallback(() => {\n const { message } = useMessage.getState();\n const { setIsCopied } = useMessageUtils.getState();\n const { isEditing, text: composerValue } = useEditComposer.getState();\n\n const valueToCopy = isEditing\n ? composerValue\n : getThreadMessageText(message);\n\n navigator.clipboard.writeText(valueToCopy).then(() => {\n setIsCopied(true);\n setTimeout(() => setIsCopied(false), copiedDuration);\n });\n }, [useMessage, useMessageUtils, useEditComposer, copiedDuration]);\n\n if (!hasCopyableContent) return null;\n return callback;\n};\n","import { useMemo } from \"react\";\nimport {\n type CombinedSelector,\n createCombinedStore,\n} from \"./createCombinedStore\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\n\nexport const useCombinedStore = <T extends Array<unknown>, R>(\n stores: { [K in keyof T]: ReadonlyStore<T[K]> },\n selector: CombinedSelector<T, R>,\n): R => {\n // eslint-disable-next-line react-hooks/exhaustive-deps -- shallow-compare the store array\n const useCombined = useMemo(() => createCombinedStore<T, R>(stores), stores);\n return useCombined(selector);\n};\n","\"use client\";\n\nimport { useSyncExternalStore } from \"react\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\n\nexport type CombinedSelector<T extends Array<unknown>, R> = (...args: T) => R;\n\nexport const createCombinedStore = <T extends Array<unknown>, R>(stores: {\n [K in keyof T]: ReadonlyStore<T[K]>;\n}) => {\n const subscribe = (callback: () => void): Unsubscribe => {\n const unsubscribes = stores.map((store) => store.subscribe(callback));\n return () => {\n for (const unsub of unsubscribes) {\n unsub();\n }\n };\n };\n\n return (selector: CombinedSelector<T, R>): R => {\n const getSnapshot = (): R =>\n selector(...(stores.map((store) => store.getState()) as T));\n\n return useSyncExternalStore(subscribe, getSnapshot, getSnapshot);\n };\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarEdit = () => {\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) => m.message.role !== \"user\" || c.isEditing,\n );\n\n const callback = useCallback(() => {\n const { edit } = useEditComposer.getState();\n edit();\n }, [useEditComposer]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarReload = () => {\n const { useThread, useThreadActions, useComposer, useViewport } =\n useThreadContext();\n const { useMessage } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useThread, useMessage],\n (t, m) => t.isRunning || t.isDisabled || m.message.role !== \"assistant\",\n );\n\n const callback = useCallback(() => {\n const { parentId } = useMessage.getState();\n useThreadActions.getState().startRun(parentId);\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n }, [useThreadActions, useComposer, useViewport, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarSpeak = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer, useMessageUtils } = useMessageContext();\n\n const hasSpeakableContent = useCombinedStore(\n [useMessage, useEditComposer],\n ({ message }, c) => {\n return (\n !c.isEditing &&\n (message.role !== \"assistant\" || message.status.type !== \"running\") &&\n message.content.some((c) => c.type === \"text\" && c.text.length > 0)\n );\n },\n );\n\n const callback = useCallback(async () => {\n const { message } = useMessage.getState();\n const utt = useThreadActions.getState().speak(message.id);\n useMessageUtils.getState().addUtterance(utt);\n }, [useThreadActions, useMessage, useMessageUtils]);\n\n if (!hasSpeakableContent) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useActionBarStopSpeaking = () => {\n const { useMessageUtils } = useMessageContext();\n\n const isSpeaking = useMessageUtils((u) => u.isSpeaking);\n\n const callback = useCallback(async () => {\n useMessageUtils.getState().stopSpeaking();\n }, [useMessageUtils]);\n\n if (!isSpeaking) return null;\n\n return callback;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useBranchPickerCount = () => {\n const { useMessage } = useMessageContext();\n const branchCount = useMessage((s) => s.branches.length);\n return branchCount;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useBranchPickerNext = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) =>\n c.isEditing || m.branches.indexOf(m.message.id) + 1 >= m.branches.length,\n );\n\n const callback = useCallback(() => {\n const { message, branches } = useMessage.getState();\n useThreadActions\n .getState()\n .switchToBranch(branches[branches.indexOf(message.id) + 1]!);\n }, [useThreadActions, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useBranchPickerNumber = () => {\n const { useMessage } = useMessageContext();\n const branchIdx = useMessage((s) => s.branches.indexOf(s.message.id));\n return branchIdx + 1;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useBranchPickerPrevious = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) => c.isEditing || m.branches.indexOf(m.message.id) <= 0,\n );\n\n const callback = useCallback(() => {\n const { message, branches } = useMessage.getState();\n useThreadActions\n .getState()\n .switchToBranch(branches[branches.indexOf(message.id) - 1]!);\n }, [useThreadActions, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useComposerContext } from \"../../context\";\n\nexport const useComposerCancel = () => {\n const { useComposer } = useComposerContext();\n\n const disabled = useComposer((c) => !c.canCancel);\n\n const callback = useCallback(() => {\n const { cancel } = useComposer.getState();\n cancel();\n }, [useComposer]);\n\n if (disabled) return null;\n return callback;\n};\n","\"use client\";\nimport { useComposerContext } from \"../../context/react/ComposerContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\n\ntype ComposerIfFilters = {\n editing: boolean | undefined;\n};\n\nexport type UseComposerIfProps = RequireAtLeastOne<ComposerIfFilters>;\n\nexport const useComposerIf = (props: UseComposerIfProps) => {\n const { useComposer } = useComposerContext();\n return useComposer((composer) => {\n if (props.editing === true && !composer.isEditing) return false;\n if (props.editing === false && composer.isEditing) return false;\n\n return true;\n });\n};\n","import { useCallback } from \"react\";\nimport { useComposerContext, useThreadContext } from \"../../context\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useComposerSend = () => {\n const {\n useThread,\n useViewport,\n useComposer: useNewComposer,\n } = useThreadContext();\n const { useComposer } = useComposerContext();\n\n const disabled = useCombinedStore(\n [useThread, useComposer],\n (t, c) => t.isRunning || !c.isEditing || c.text.length === 0,\n );\n\n const callback = useCallback(() => {\n const composerState = useComposer.getState();\n if (!composerState.isEditing) return;\n\n composerState.send();\n\n useViewport.getState().scrollToBottom();\n useNewComposer.getState().focus();\n }, [useNewComposer, useComposer, useViewport]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { UIContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartDisplay = () => {\n const { useContentPart } = useContentPartContext();\n\n const display = useContentPart((c) => {\n if (c.part.type !== \"ui\")\n throw new Error(\n \"This component can only be used inside ui content parts.\",\n );\n\n return c as UIContentPartState;\n });\n\n return display;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { ImageContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartImage = () => {\n const { useContentPart } = useContentPartContext();\n\n const image = useContentPart((c) => {\n if (c.part.type !== \"image\")\n throw new Error(\n \"ContentPartImage can only be used inside image content parts.\",\n );\n\n return c as ImageContentPartState;\n });\n\n return image;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { TextContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartText = () => {\n const { useContentPart } = useContentPartContext();\n\n const text = useContentPart((c) => {\n if (c.part.type !== \"text\")\n throw new Error(\n \"ContentPartText can only be used inside text content parts.\",\n );\n\n return c as TextContentPartState;\n });\n\n return text;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\ntype MessageIfFilters = {\n user: boolean | undefined;\n assistant: boolean | undefined;\n system: boolean | undefined;\n hasBranches: boolean | undefined;\n copied: boolean | undefined;\n lastOrHover: boolean | undefined;\n speaking: boolean | undefined;\n};\nexport type UseMessageIfProps = RequireAtLeastOne<MessageIfFilters>;\n\nexport const useMessageIf = (props: UseMessageIfProps) => {\n const { useMessage, useMessageUtils } = useMessageContext();\n\n return useCombinedStore(\n [useMessage, useMessageUtils],\n ({ message, branches, isLast }, { isCopied, isHovering, isSpeaking }) => {\n if (props.hasBranches === true && branches.length < 2) return false;\n\n if (props.user && message.role !== \"user\") return false;\n if (props.assistant && message.role !== \"assistant\") return false;\n if (props.system && message.role !== \"system\") return false;\n\n if (props.lastOrHover === true && !isHovering && !isLast) return false;\n\n if (props.copied === true && !isCopied) return false;\n if (props.copied === false && isCopied) return false;\n \n if (props.speaking === true && !isSpeaking) return false;\n if (props.speaking === false && isSpeaking) return false;\n\n return true;\n },\n );\n};\n","\"use client\";\n\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\ntype ThreadIfFilters = {\n empty: boolean | undefined;\n running: boolean | undefined;\n disabled: boolean | undefined;\n};\n\nexport type UseThreadIfProps = RequireAtLeastOne<ThreadIfFilters>;\n\nexport const useThreadIf = (props: UseThreadIfProps) => {\n const { useThread, useThreadMessages } = useThreadContext();\n return useCombinedStore(\n [useThread, useThreadMessages],\n (thread, messages) => {\n if (props.empty === true && messages.length !== 0) return false;\n if (props.empty === false && messages.length === 0) return false;\n if (props.running === true && !thread.isRunning) return false;\n if (props.running === false && thread.isRunning) return false;\n if (props.disabled === true && thread.isDisabled) return false;\n if (props.disabled === false && thread.isDisabled) return false;\n\n return true;\n },\n );\n};\n","import { useThreadIf } from \"./useThreadIf\";\n\nexport const useThreadEmpty = () => {\n return useThreadIf({ empty: true });\n};\n","import { useCallback } from \"react\";\nimport { useThreadContext } from \"../../context\";\n\nexport const useThreadScrollToBottom = () => {\n const { useComposer, useViewport } = useThreadContext();\n\n const isAtBottom = useViewport((s) => s.isAtBottom);\n\n const handleScrollToBottom = useCallback(() => {\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n }, [useViewport, useComposer]);\n\n if (isAtBottom) return null;\n return handleScrollToBottom;\n};\n","import { useCallback } from \"react\";\nimport { useThreadContext } from \"../../context\";\nimport { useAppendMessage } from \"../../hooks\";\n\nexport type UseApplyThreadSuggestionProps = {\n prompt: string;\n method: \"replace\";\n autoSend?: boolean | undefined;\n};\n\nexport const useThreadSuggestion = ({\n prompt,\n autoSend,\n}: UseApplyThreadSuggestionProps) => {\n const { useThread, useComposer } = useThreadContext();\n\n const append = useAppendMessage();\n const disabled = useThread((t) => t.isDisabled);\n const callback = useCallback(() => {\n const thread = useThread.getState();\n const composer = useComposer.getState();\n if (autoSend && !thread.isRunning) {\n append(prompt);\n composer.setText(\"\");\n } else {\n composer.setText(prompt);\n }\n }, [useThread, useComposer, autoSend, append, prompt]);\n\n if (disabled) return null;\n return callback;\n};\n","export { ActionBarPrimitiveRoot as Root } from \"./ActionBarRoot\";\nexport { ActionBarPrimitiveCopy as Copy } from \"./ActionBarCopy\";\nexport { ActionBarPrimitiveReload as Reload } from \"./ActionBarReload\";\nexport { ActionBarPrimitiveEdit as Edit } from \"./ActionBarEdit\";\nexport { ActionBarPrimitiveSpeak as Speak } from \"./ActionBarSpeak\";\nexport { ActionBarPrimitiveStopSpeaking as StopSpeaking } from \"./ActionBarStopSpeaking\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport {\n useActionBarFloatStatus,\n HideAndFloatStatus,\n UseActionBarFloatStatusProps,\n} from \"./useActionBarFloatStatus\";\n\ntype ActionBarPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ActionBarPrimitiveRootProps = PrimitiveDivProps &\n UseActionBarFloatStatusProps;\n\nexport const ActionBarPrimitiveRoot = forwardRef<\n ActionBarPrimitiveRootElement,\n ActionBarPrimitiveRootProps\n>(({ hideWhenRunning, autohide, autohideFloat, ...rest }, ref) => {\n const hideAndfloatStatus = useActionBarFloatStatus({\n hideWhenRunning,\n autohide,\n autohideFloat,\n });\n\n if (hideAndfloatStatus === HideAndFloatStatus.Hidden) return null;\n\n return (\n <Primitive.div\n {...(hideAndfloatStatus === HideAndFloatStatus.Floating\n ? { \"data-floating\": \"true\" }\n : null)}\n {...rest}\n ref={ref}\n />\n );\n});\n\nActionBarPrimitiveRoot.displayName = \"ActionBarPrimitive.Root\";\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport enum HideAndFloatStatus {\n Hidden = \"hidden\",\n Floating = \"floating\",\n Normal = \"normal\",\n}\n\nexport type UseActionBarFloatStatusProps = {\n hideWhenRunning?: boolean | undefined;\n autohide?: \"always\" | \"not-last\" | \"never\" | undefined;\n autohideFloat?: \"always\" | \"single-branch\" | \"never\" | undefined;\n};\n\nexport const useActionBarFloatStatus = ({\n hideWhenRunning,\n autohide,\n autohideFloat,\n}: UseActionBarFloatStatusProps) => {\n const { useThread } = useThreadContext();\n const { useMessage, useMessageUtils } = useMessageContext();\n\n return useCombinedStore(\n [useThread, useMessage, useMessageUtils],\n (t, m, mu) => {\n if (hideWhenRunning && t.isRunning) return HideAndFloatStatus.Hidden;\n\n const autohideEnabled =\n autohide === \"always\" || (autohide === \"not-last\" && !m.isLast);\n\n // normal status\n if (!autohideEnabled) return HideAndFloatStatus.Normal;\n\n // hidden status\n if (!mu.isHovering) return HideAndFloatStatus.Hidden;\n\n // floating status\n if (\n autohideFloat === \"always\" ||\n (autohideFloat === \"single-branch\" && m.branches.length <= 1)\n )\n return HideAndFloatStatus.Floating;\n\n return HideAndFloatStatus.Normal;\n },\n );\n};\n","\"use client\";\n\nimport { ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\ntype ActionButtonCallback<TProps> = (props: TProps) => null | (() => void);\n\ntype PrimitiveButtonElement = ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\n\nexport type ActionButtonProps<THook> = PrimitiveButtonProps &\n (THook extends (props: infer TProps) => unknown ? TProps : never);\n\nexport const createActionButton = <TProps,>(\n displayName: string,\n useActionButton: ActionButtonCallback<TProps>,\n forwardProps: (keyof NonNullable<TProps>)[] = [],\n) => {\n const ActionButton = forwardRef<\n PrimitiveButtonElement,\n PrimitiveButtonProps & TProps\n >((props, forwardedRef) => {\n const forwardedProps = {} as TProps;\n const primitiveProps = {} as PrimitiveButtonProps;\n\n (Object.keys(props) as Array<keyof typeof props>).forEach((key) => {\n if (forwardProps.includes(key as keyof TProps)) {\n (forwardedProps as any)[key] = props[key];\n } else {\n (primitiveProps as any)[key] = props[key];\n }\n });\n\n const callback = useActionButton(forwardedProps as TProps);\n return (\n <Primitive.button\n type=\"button\"\n disabled={!callback}\n {...primitiveProps}\n ref={forwardedRef}\n onClick={composeEventHandlers(primitiveProps.onClick, () => {\n callback?.();\n })}\n />\n );\n });\n\n ActionButton.displayName = displayName;\n\n return ActionButton;\n};\n","\"use client\";\n\nimport { useActionBarCopy } from \"../../primitive-hooks/actionBar/useActionBarCopy\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveCopyProps = ActionButtonProps<\n typeof useActionBarCopy\n>;\n\nexport const ActionBarPrimitiveCopy = createActionButton(\n \"ActionBarPrimitive.Copy\",\n useActionBarCopy,\n [\"copiedDuration\"],\n);\n","\"use client\";\n\nimport { useActionBarReload } from \"../../primitive-hooks/actionBar/useActionBarReload\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveReloadProps = ActionButtonProps<\n typeof useActionBarReload\n>;\n\nexport const ActionBarPrimitiveReload = createActionButton(\n \"ActionBarPrimitive.Reload\",\n useActionBarReload,\n);\n","\"use client\";\n\nimport { useActionBarEdit } from \"../../primitive-hooks/actionBar/useActionBarEdit\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveEditProps = ActionButtonProps<\n typeof useActionBarEdit\n>;\n\nexport const ActionBarPrimitiveEdit = createActionButton(\n \"ActionBarPrimitive.Edit\",\n useActionBarEdit,\n);\n","\"use client\";\n\nimport { useActionBarSpeak } from \"../../primitive-hooks/actionBar/useActionBarSpeak\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveSpeakProps = ActionButtonProps<\n typeof useActionBarSpeak\n>;\n\nexport const ActionBarPrimitiveSpeak = createActionButton(\n \"ActionBarPrimitive.Speak\",\n useActionBarSpeak,\n);\n","\"use client\";\n\nimport { forwardRef } from \"react\";\nimport { useActionBarStopSpeaking } from \"../../primitive-hooks/actionBar/useActionBarStopSpeaking\";\nimport { ActionButtonProps } from \"../../utils/createActionButton\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\nexport type ActionBarPrimitiveStopSpeakingProps = ActionButtonProps<\n typeof useActionBarStopSpeaking\n>;\n\nexport const ActionBarPrimitiveStopSpeaking = forwardRef<\n HTMLButtonElement,\n Partial<ActionBarPrimitiveStopSpeakingProps>\n>((props, ref) => {\n const callback = useActionBarStopSpeaking();\n\n // TODO this stops working if the user is not hovering over an older message\n useEscapeKeydown((e) => {\n if (callback) {\n e.preventDefault();\n callback();\n }\n });\n\n return (\n <Primitive.button\n type=\"button\"\n disabled={!callback}\n {...props}\n ref={ref}\n onClick={composeEventHandlers(props.onClick, () => {\n callback?.();\n })}\n />\n );\n});\n","export { AssistantModalPrimitiveRoot as Root } from \"./AssistantModalRoot\";\nexport { AssistantModalPrimitiveTrigger as Trigger } from \"./AssistantModalTrigger\";\nexport { AssistantModalPrimitiveContent as Content } from \"./AssistantModalContent\";\nexport { AssistantModalPrimitiveAnchor as Anchor } from \"./AssistantModalAnchor\";\n","\"use client\";\n\nimport { FC, useState } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useOnComposerFocus } from \"../../utils/hooks/useOnComposerFocus\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\nexport type AssistantModalPrimitiveRootProps = PopoverPrimitive.PopoverProps;\n\nconst useAssistantModalOpenState = (defaultOpen = false) => {\n const state = useState(defaultOpen);\n\n const [, setOpen] = state;\n useOnComposerFocus(() => {\n setOpen(true);\n });\n\n return state;\n};\n\nexport const AssistantModalPrimitiveRoot: FC<\n AssistantModalPrimitiveRootProps\n> = ({\n __scopeAssistantModal,\n defaultOpen,\n open,\n onOpenChange,\n ...rest\n}: ScopedProps<AssistantModalPrimitiveRootProps>) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n const [modalOpen, setOpen] = useAssistantModalOpenState(defaultOpen);\n\n return (\n <PopoverPrimitive.Root\n {...scope}\n open={open === undefined ? modalOpen : open}\n onOpenChange={composeEventHandlers(onOpenChange, setOpen)}\n {...rest}\n />\n );\n};\n\nAssistantModalPrimitiveRoot.displayName = \"AssistantModalPrimitive.Root\";\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEffect } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\n\nexport const useOnComposerFocus = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const { useComposer } = useThreadContext();\n useEffect(() => {\n return useComposer.getState().onFocus(() => {\n callbackRef();\n });\n }, [useComposer, callbackRef]);\n};\n","import * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport type { Scope } from \"@radix-ui/react-context\";\n\nexport type ScopedProps<P> = P & { __scopeAssistantModal?: Scope };\nexport const usePopoverScope = PopoverPrimitive.createPopoverScope();\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\ntype AssistantModalPrimitiveTriggerElement = ElementRef<\n typeof PopoverPrimitive.Trigger\n>;\nexport type AssistantModalPrimitiveTriggerProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Trigger\n>;\n\nexport const AssistantModalPrimitiveTrigger = forwardRef<\n AssistantModalPrimitiveTriggerElement,\n AssistantModalPrimitiveTriggerProps\n>(\n (\n {\n __scopeAssistantModal,\n ...rest\n }: ScopedProps<AssistantModalPrimitiveTriggerProps>,\n ref,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return <PopoverPrimitive.Trigger {...scope} {...rest} ref={ref} />;\n },\n);\n\nAssistantModalPrimitiveTrigger.displayName = \"AssistantModalPrimitive.Trigger\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\ntype AssistantModalPrimitiveContentElement = ElementRef<\n typeof PopoverPrimitive.Content\n>;\nexport type AssistantModalPrimitiveContentProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Content\n> & {\n dissmissOnInteractOutside?: boolean | undefined;\n};\n\nexport const AssistantModalPrimitiveContent = forwardRef<\n AssistantModalPrimitiveContentElement,\n AssistantModalPrimitiveContentProps\n>(\n (\n {\n __scopeAssistantModal,\n side,\n align,\n onInteractOutside,\n dissmissOnInteractOutside = false,\n ...props\n }: ScopedProps<AssistantModalPrimitiveContentProps>,\n forwardedRef,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return (\n <PopoverPrimitive.Portal {...scope}>\n <PopoverPrimitive.Content\n {...scope}\n {...props}\n ref={forwardedRef}\n side={side ?? \"top\"}\n align={align ?? \"end\"}\n onInteractOutside={composeEventHandlers(\n onInteractOutside,\n dissmissOnInteractOutside ? undefined : (e) => e.preventDefault(),\n )}\n />\n </PopoverPrimitive.Portal>\n );\n },\n);\n\nAssistantModalPrimitiveContent.displayName = \"AssistantModalPrimitive.Content\";\n","\"use client\";\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\ntype AssistantModalPrimitiveAnchorElement = ElementRef<\n typeof PopoverPrimitive.Anchor\n>;\ntype AssistantModalPrimitiveAnchorProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Anchor\n>;\n\nexport const AssistantModalPrimitiveAnchor = forwardRef<\n AssistantModalPrimitiveAnchorElement,\n AssistantModalPrimitiveAnchorProps\n>(\n (\n {\n __scopeAssistantModal,\n ...rest\n }: ScopedProps<AssistantModalPrimitiveAnchorProps>,\n ref,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return <PopoverPrimitive.Anchor {...scope} {...rest} ref={ref} />;\n },\n);\nAssistantModalPrimitiveAnchor.displayName = \"AssistantModalPrimitive.Anchor\";\n","export { BranchPickerPrimitiveNext as Next } from \"./BranchPickerNext\";\nexport { BranchPickerPrevious as Previous } from \"./BranchPickerPrevious\";\nexport { BranchPickerPrimitiveCount as Count } from \"./BranchPickerCount\";\nexport { BranchPickerPrimitiveNumber as Number } from \"./BranchPickerNumber\";\nexport { BranchPickerPrimitiveRoot as Root } from \"./BranchPickerRoot\";\n","\"use client\";\n\nimport { useBranchPickerNext } from \"../../primitive-hooks/branchPicker/useBranchPickerNext\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type BranchPickerPrimitiveNextProps = ActionButtonProps<\n typeof useBranchPickerNext\n>;\n\nexport const BranchPickerPrimitiveNext = createActionButton(\n \"BranchPickerPrimitive.Next\",\n useBranchPickerNext,\n);\n","\"use client\";\n\nimport { useBranchPickerPrevious } from \"../../primitive-hooks/branchPicker/useBranchPickerPrevious\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type BranchPickerPrimitivePreviousProps = ActionButtonProps<\n typeof useBranchPickerPrevious\n>;\n\nexport const BranchPickerPrevious = createActionButton(\n \"BranchPickerPrimitive.Previous\",\n useBranchPickerPrevious,\n);\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport { useBranchPickerCount } from \"../../primitive-hooks/branchPicker/useBranchPickerCount\";\n\nexport type BranchPickerPrimitiveCountProps = {};\n\nexport const BranchPickerPrimitiveCount: FC<\n BranchPickerPrimitiveCountProps\n> = () => {\n const branchCount = useBranchPickerCount();\n return <>{branchCount}</>;\n};\n\nBranchPickerPrimitiveCount.displayName = \"BranchPickerPrimitive.Count\";\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport { useBranchPickerNumber } from \"../../primitive-hooks/branchPicker/useBranchPickerNumber\";\n\nexport type BranchPickerPrimitiveNumberProps = {};\n\nexport const BranchPickerPrimitiveNumber: FC<\n BranchPickerPrimitiveNumberProps\n> = () => {\n const branchNumber = useBranchPickerNumber();\n return <>{branchNumber}</>;\n};\n\nBranchPickerPrimitiveNumber.displayName = \"BranchPickerPrimitive.Number\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { If } from \"../message\";\n\ntype BranchPickerPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type BranchPickerPrimitiveRootProps = PrimitiveDivProps & {\n hideWhenSingleBranch?: boolean | undefined;\n};\n\nexport const BranchPickerPrimitiveRoot = forwardRef<\n BranchPickerPrimitiveRootElement,\n BranchPickerPrimitiveRootProps\n>(({ hideWhenSingleBranch, ...rest }, ref) => {\n return (\n <If hasBranches={hideWhenSingleBranch ? true : undefined}>\n <Primitive.div {...rest} ref={ref} />\n </If>\n );\n});\n\nBranchPickerPrimitiveRoot.displayName = \"BranchPickerPrimitive.Root\";\n","export { MessagePrimitiveRoot as Root } from \"./MessageRoot\";\nexport { MessagePrimitiveIf as If } from \"./MessageIf\";\nexport { MessagePrimitiveContent as Content } from \"./MessageContent\";\nexport { MessagePrimitiveInProgress as InProgress } from \"./MessageInProgress\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n forwardRef,\n ComponentPropsWithoutRef,\n useCallback,\n} from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useManagedRef } from \"../../utils/hooks/useManagedRef\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\n\ntype MessagePrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nconst useIsHoveringRef = () => {\n const { useMessageUtils } = useMessageContext();\n\n const callbackRef = useCallback(\n (el: HTMLElement) => {\n const setIsHovering = useMessageUtils.getState().setIsHovering;\n\n const handleMouseEnter = () => {\n setIsHovering(true);\n };\n const handleMouseLeave = () => {\n setIsHovering(false);\n };\n\n el.addEventListener(\"mouseenter\", handleMouseEnter);\n el.addEventListener(\"mouseleave\", handleMouseLeave);\n\n return () => {\n el.removeEventListener(\"mouseenter\", handleMouseEnter);\n el.removeEventListener(\"mouseleave\", handleMouseLeave);\n setIsHovering(false);\n };\n },\n [useMessageUtils],\n );\n\n return useManagedRef(callbackRef);\n};\n\nexport type MessagePrimitiveRootProps = PrimitiveDivProps;\n\nexport const MessagePrimitiveRoot = forwardRef<\n MessagePrimitiveRootElement,\n MessagePrimitiveRootProps\n>(({ onMouseEnter, onMouseLeave, ...rest }, forwardRef) => {\n const isHoveringRef = useIsHoveringRef();\n const ref = useComposedRefs<HTMLDivElement>(forwardRef, isHoveringRef);\n\n return <Primitive.div {...rest} ref={ref} />;\n});\n\nMessagePrimitiveRoot.displayName = \"MessagePrimitive.Root\";\n","import { useCallback, useRef } from \"react\";\n\nexport const useManagedRef = <TNode>(\n callback: (node: TNode) => (() => void) | void,\n) => {\n const cleanupRef = useRef<(() => void) | void>();\n\n const ref = useCallback(\n (el: TNode | null) => {\n // Call the previous cleanup function\n if (cleanupRef.current) {\n cleanupRef.current();\n }\n\n // Call the new callback and store its cleanup function\n if (el) {\n cleanupRef.current = callback(el);\n }\n },\n [callback],\n );\n\n return ref;\n};\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseMessageIfProps,\n useMessageIf,\n} from \"../../primitive-hooks/message/useMessageIf\";\n\nexport type MessagePrimitiveIfProps = PropsWithChildren<UseMessageIfProps>;\n\nexport const MessagePrimitiveIf: FC<MessagePrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useMessageIf(query);\n return result ? children : null;\n};\n\nMessagePrimitiveIf.displayName = \"MessagePrimitive.If\";\n","\"use client\";\n\nimport { type ComponentType, type FC, memo } from \"react\";\nimport {\n useAssistantContext,\n useContentPartContext,\n useThreadContext,\n} from \"../../context\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport {\n ContentPartProvider,\n EMPTY_CONTENT,\n} from \"../../context/providers/ContentPartProvider\";\nimport { ContentPartPrimitiveText } from \"../contentPart/ContentPartText\";\nimport { ContentPartPrimitiveImage } from \"../contentPart/ContentPartImage\";\nimport { ContentPartPrimitiveDisplay } from \"../contentPart/ContentPartDisplay\";\nimport type {\n ImageContentPartComponent,\n TextContentPartComponent,\n ToolCallContentPartComponent,\n ToolCallContentPartProps,\n UIContentPartComponent,\n} from \"../../types/ContentPartComponentTypes\";\nimport { ContentPartPrimitiveInProgress } from \"../contentPart/ContentPartInProgress\";\n\nexport type MessagePrimitiveContentProps = {\n components?:\n | {\n Empty?: TextContentPartComponent | undefined;\n Text?: TextContentPartComponent | undefined;\n Image?: ImageContentPartComponent | undefined;\n UI?: UIContentPartComponent | undefined;\n tools?: {\n by_name?:\n | Record<string, ToolCallContentPartComponent | undefined>\n | undefined;\n Fallback?: ComponentType<ToolCallContentPartProps> | undefined;\n };\n }\n | undefined;\n};\n\nconst defaultComponents = {\n Text: () => (\n <p style={{ whiteSpace: \"pre-line\" }}>\n <ContentPartPrimitiveText />\n <ContentPartPrimitiveInProgress>\n <span style={{ fontFamily: \"revert\" }}>{\" \\u25CF\"}</span>\n </ContentPartPrimitiveInProgress>\n </p>\n ),\n Image: () => <ContentPartPrimitiveImage />,\n UI: () => <ContentPartPrimitiveDisplay />,\n tools: {\n Fallback: (props) => {\n const { useToolUIs } = useAssistantContext();\n const Render = useToolUIs((s) => s.getToolUI(props.part.toolName));\n if (!Render) return null;\n return <Render {...props} />;\n },\n },\n} satisfies MessagePrimitiveContentProps[\"components\"];\n\ntype MessageContentPartComponentProps = {\n components: MessagePrimitiveContentProps[\"components\"];\n};\n\nconst MessageContentPartComponent: FC<MessageContentPartComponentProps> = ({\n components: {\n Empty = defaultComponents.Text,\n Text = defaultComponents.Text,\n Image = defaultComponents.Image,\n UI = defaultComponents.UI,\n tools: { by_name = {}, Fallback = defaultComponents.tools.Fallback } = {},\n } = {},\n}) => {\n const { useThreadActions } = useThreadContext();\n const { useMessage } = useMessageContext();\n const addToolResult = useThreadActions((t) => t.addToolResult);\n\n const { useContentPart } = useContentPartContext();\n const { part, status } = useContentPart();\n\n const type = part.type;\n switch (type) {\n case \"text\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n if (part === EMPTY_CONTENT) return <Empty part={part} status={status} />;\n\n return <Text part={part} status={status} />;\n\n case \"image\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n // eslint-disable-next-line jsx-a11y/alt-text\n return <Image part={part} status={status} />;\n\n case \"ui\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n return <UI part={part} status={status} />;\n\n case \"tool-call\": {\n const Tool = by_name[part.toolName] || Fallback;\n const addResult = (result: any) =>\n addToolResult({\n messageId: useMessage.getState().message.id,\n toolCallId: part.toolCallId,\n result,\n });\n return <Tool part={part} status={status} addResult={addResult} />;\n }\n default:\n const unhandledType: never = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n};\n\ntype MessageContentPartProps = {\n partIndex: number;\n components: MessagePrimitiveContentProps[\"components\"];\n};\n\nconst MessageContentPartImpl: FC<MessageContentPartProps> = ({\n partIndex,\n components,\n}) => {\n return (\n <ContentPartProvider partIndex={partIndex}>\n <MessageContentPartComponent components={components} />\n </ContentPartProvider>\n );\n};\n\nconst MessageContentPart = memo(\n MessageContentPartImpl,\n (prev, next) =>\n prev.partIndex === next.partIndex &&\n prev.components?.Text === next.components?.Text &&\n prev.components?.Image === next.components?.Image &&\n prev.components?.UI === next.components?.UI &&\n prev.components?.tools === next.components?.tools,\n);\n\nexport const MessagePrimitiveContent: FC<MessagePrimitiveContentProps> = ({\n components,\n}) => {\n const { useMessage } = useMessageContext();\n\n const contentLength = useMessage((s) => s.message.content.length) || 1;\n\n return new Array(contentLength).fill(null).map((_, idx) => {\n const partIndex = idx; // use the index as key, as message is generally append only\n return (\n <MessageContentPart\n key={partIndex}\n partIndex={partIndex}\n components={components}\n />\n );\n });\n};\n\nMessagePrimitiveContent.displayName = \"MessagePrimitive.Content\";\n","\"use client\";\n\nimport { type FC, type PropsWithChildren, useEffect, useState } from \"react\";\nimport { StoreApi, create } from \"zustand\";\nimport { ContentPartContext } from \"../react/ContentPartContext\";\nimport type { ContentPartContextValue } from \"../react/ContentPartContext\";\nimport { useMessageContext } from \"../react/MessageContext\";\nimport type { MessageState } from \"../stores\";\nimport type { ContentPartState } from \"../stores/ContentPart\";\nimport {\n ContentPartStatus,\n ThreadAssistantContentPart,\n ThreadMessage,\n ThreadUserContentPart,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\n\ntype ContentPartProviderProps = PropsWithChildren<{\n partIndex: number;\n}>;\n\nconst COMPLETE_STATUS: ContentPartStatus = {\n type: \"complete\",\n};\n\nconst toContentPartStatus = (\n message: ThreadMessage,\n partIndex: number,\n part: ThreadUserContentPart | ThreadAssistantContentPart,\n): ToolCallContentPartStatus => {\n if (message.role !== \"assistant\") return COMPLETE_STATUS;\n\n const isLastPart = partIndex === Math.max(0, message.content.length - 1);\n if (part.type !== \"tool-call\") {\n if (\n \"reason\" in message.status &&\n message.status.reason === \"tool-calls\" &&\n isLastPart\n )\n throw new Error(\n \"Encountered unexpected requires-action status. This is likely an internal bug in assistant-ui.\",\n );\n\n return isLastPart ? (message.status as ContentPartStatus) : COMPLETE_STATUS;\n }\n\n if (!!part.result) {\n return COMPLETE_STATUS;\n }\n\n return message.status as ToolCallContentPartStatus;\n};\n\nexport const EMPTY_CONTENT = Object.freeze({ type: \"text\", text: \"\" });\n\nconst getContentPartState = (\n { message }: MessageState,\n useContentPart: ContentPartContextValue[\"useContentPart\"] | undefined,\n partIndex: number,\n) => {\n let part = message.content[partIndex];\n if (!part) {\n // for empty messages, show an empty text content part\n if (message.content.length === 0 && partIndex === 0) {\n part = EMPTY_CONTENT;\n } else {\n return null;\n }\n }\n\n // if the content part is the same, don't update\n const status = toContentPartStatus(message, partIndex, part);\n const currentState = useContentPart?.getState();\n if (\n currentState &&\n currentState.part === part &&\n currentState.status === status\n )\n return null;\n\n return Object.freeze({ part, status });\n};\n\nconst useContentPartContext = (partIndex: number) => {\n const { useMessage } = useMessageContext();\n const [context] = useState<ContentPartContextValue>(() => {\n const useContentPart = create<ContentPartState>(\n () => getContentPartState(useMessage.getState(), undefined, partIndex)!,\n );\n\n return { useContentPart };\n });\n\n useEffect(() => {\n const syncContentPart = (message: MessageState) => {\n const newState = getContentPartState(\n message,\n context.useContentPart,\n partIndex,\n );\n if (!newState) return;\n (\n context.useContentPart as unknown as StoreApi<ContentPartState>\n ).setState(newState, true);\n };\n\n syncContentPart(useMessage.getState());\n return useMessage.subscribe(syncContentPart);\n }, [context, useMessage, partIndex]);\n\n return context;\n};\n\nexport const ContentPartProvider: FC<ContentPartProviderProps> = ({\n partIndex,\n children,\n}) => {\n const context = useContentPartContext(partIndex);\n\n return (\n <ContentPartContext.Provider value={context}>\n {children}\n </ContentPartContext.Provider>\n );\n};\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n forwardRef,\n ComponentPropsWithoutRef,\n ElementType,\n} from \"react\";\nimport { useContentPartText } from \"../../primitive-hooks/contentPart/useContentPartText\";\nimport { useSmooth } from \"../../utils/smooth/useSmooth\";\n\ntype ContentPartPrimitiveTextElement = ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = ComponentPropsWithoutRef<typeof Primitive.span>;\n\nexport type ContentPartPrimitiveTextProps = Omit<\n PrimitiveSpanProps,\n \"children\" | \"asChild\"\n> & {\n smooth?: boolean;\n component?: ElementType;\n};\n\nexport const ContentPartPrimitiveText = forwardRef<\n ContentPartPrimitiveTextElement,\n ContentPartPrimitiveTextProps\n>(({ smooth = true, component: Component = \"span\", ...rest }, forwardedRef) => {\n const {\n part: { text },\n status,\n } = useSmooth(useContentPartText(), smooth);\n\n return (\n <Component data-status={status.type} {...rest} ref={forwardedRef}>\n {text}\n </Component>\n );\n});\n\nContentPartPrimitiveText.displayName = \"ContentPartPrimitive.Text\";\n","import { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { useContentPartImage } from \"../../primitive-hooks/contentPart/useContentPartImage\";\n\ntype ContentPartPrimitiveImageElement = ElementRef<typeof Primitive.img>;\ntype PrimitiveImageProps = ComponentPropsWithoutRef<typeof Primitive.img>;\n\nexport type ContentPartPrimitiveImageProps = PrimitiveImageProps;\n\nexport const ContentPartPrimitiveImage = forwardRef<\n ContentPartPrimitiveImageElement,\n ContentPartPrimitiveImageProps\n>((props, forwardedRef) => {\n const {\n part: { image },\n } = useContentPartImage();\n return <Primitive.img src={image} {...props} ref={forwardedRef} />;\n});\n\nContentPartPrimitiveImage.displayName = \"ContentPartPrimitive.Image\";\n","import type { FC } from \"react\";\nimport { useContentPartDisplay } from \"../../primitive-hooks/contentPart/useContentPartDisplay\";\n\nexport type ContentPartPrimitiveDisplayProps = {};\n\nexport const ContentPartPrimitiveDisplay: FC<\n ContentPartPrimitiveDisplayProps\n> = () => {\n const {\n part: { display },\n } = useContentPartDisplay();\n return display ?? null;\n};\n\nContentPartPrimitiveDisplay.displayName = \"ContentPartPrimitive.Display\";\n","import { FC, PropsWithChildren } from \"react\";\nimport { useContentPartContext } from \"../../context\";\n\nexport type ContentPartPrimitiveInProgressProps = PropsWithChildren;\n\n// TODO should this be renamed to IsRunning?\nexport const ContentPartPrimitiveInProgress: FC<\n ContentPartPrimitiveInProgressProps\n> = ({ children }) => {\n const { useContentPart } = useContentPartContext();\n const isInProgress = useContentPart((c) => c.status.type === \"running\");\n\n return isInProgress ? children : null;\n};\n\nContentPartPrimitiveInProgress.displayName = \"ContentPartPrimitive.InProgress\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { ComponentPropsWithoutRef, FC } from \"react\";\n\ntype PrimitiveSpanProps = ComponentPropsWithoutRef<typeof Primitive.span>;\n\nexport type MessagePrimitiveInProgressProps = PrimitiveSpanProps;\n\n/**\n * @deprecated Define a custom Text renderer via ContentPartPrimitiveInProgress instead.\n */\nexport const MessagePrimitiveInProgress: FC<\n MessagePrimitiveInProgressProps\n> = () => {\n return null;\n};\n\nMessagePrimitiveInProgress.displayName = \"MessagePrimitive.InProgress\";\n","export { ComposerPrimitiveRoot as Root } from \"./ComposerRoot\";\nexport { ComposerPrimitiveInput as Input } from \"./ComposerInput\";\nexport { ComposerPrimitiveSend as Send } from \"./ComposerSend\";\nexport { ComposerPrimitiveCancel as Cancel } from \"./ComposerCancel\";\nexport { ComposerPrimitiveIf as If } from \"./ComposerIf\";\n","\"use client\";\n\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n type FormEvent,\n forwardRef,\n ComponentPropsWithoutRef,\n} from \"react\";\nimport { useComposerSend } from \"../../primitive-hooks\";\n\ntype ComposerPrimitiveRootElement = ElementRef<typeof Primitive.form>;\ntype PrimitiveFormProps = ComponentPropsWithoutRef<typeof Primitive.form>;\n\nexport type ComposerPrimitiveRootProps = PrimitiveFormProps;\n\nexport const ComposerPrimitiveRoot = forwardRef<\n ComposerPrimitiveRootElement,\n ComposerPrimitiveRootProps\n>(({ onSubmit, ...rest }, forwardedRef) => {\n const send = useComposerSend();\n\n const handleSubmit = (e: FormEvent) => {\n e.preventDefault();\n\n if (!send) return;\n send();\n };\n\n return (\n <Primitive.form\n {...rest}\n ref={forwardedRef}\n onSubmit={composeEventHandlers(onSubmit, handleSubmit)}\n />\n );\n});\n\nComposerPrimitiveRoot.displayName = \"ComposerPrimitive.Root\";\n","\"use client\";\n\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport {\n type KeyboardEvent,\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n} from \"react\";\nimport TextareaAutosize, {\n type TextareaAutosizeProps,\n} from \"react-textarea-autosize\";\nimport { useComposerContext } from \"../../context/react/ComposerContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { useOnComposerFocus } from \"../../utils/hooks/useOnComposerFocus\";\n\nexport type ComposerPrimitiveInputProps = TextareaAutosizeProps & {\n asChild?: boolean | undefined;\n};\n\nexport const ComposerPrimitiveInput = forwardRef<\n HTMLTextAreaElement,\n ComposerPrimitiveInputProps\n>(\n (\n {\n autoFocus = false,\n asChild,\n disabled: disabledProp,\n onChange,\n onKeyDown,\n ...rest\n },\n forwardedRef,\n ) => {\n const { useThread } = useThreadContext();\n const { useComposer, type } = useComposerContext();\n\n const value = useComposer((c) => {\n if (!c.isEditing) return \"\";\n return c.text;\n });\n\n const Component = asChild ? Slot : TextareaAutosize;\n\n const isDisabled = useThread((t) => t.isDisabled) ?? disabledProp ?? false;\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const ref = useComposedRefs(forwardedRef, textareaRef);\n\n useEscapeKeydown((e) => {\n const composer = useComposer.getState();\n if (composer.canCancel) {\n composer.cancel();\n e.preventDefault();\n }\n });\n\n const handleKeyPress = (e: KeyboardEvent) => {\n if (isDisabled) return;\n\n // ignore IME composition events\n if (e.nativeEvent.isComposing) return;\n\n if (e.key === \"Enter\" && e.shiftKey === false) {\n const { isRunning } = useThread.getState();\n\n if (!isRunning) {\n e.preventDefault();\n\n textareaRef.current?.closest(\"form\")?.requestSubmit();\n }\n }\n };\n\n const autoFocusEnabled = autoFocus && !isDisabled;\n const focus = useCallback(() => {\n const textarea = textareaRef.current;\n if (!textarea || !autoFocusEnabled) return;\n\n textarea.focus({ preventScroll: true });\n textarea.setSelectionRange(\n textareaRef.current.value.length,\n textareaRef.current.value.length,\n );\n }, [autoFocusEnabled]);\n\n useEffect(() => focus(), [focus]);\n\n useOnComposerFocus(() => {\n if (type === \"new\") {\n focus();\n }\n });\n\n return (\n <Component\n name=\"input\"\n value={value}\n {...rest}\n ref={ref}\n disabled={isDisabled}\n onChange={composeEventHandlers(onChange, (e) => {\n const composerState = useComposer.getState();\n if (!composerState.isEditing) return;\n return composerState.setText(e.target.value);\n })}\n onKeyDown={composeEventHandlers(onKeyDown, handleKeyPress)}\n />\n );\n },\n);\n\nComposerPrimitiveInput.displayName = \"ComposerPrimitive.Input\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport { useComposerContext } from \"../../context\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\n\ntype ComposerPrimitiveSendElement = ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\n\nexport type ComposerPrimitiveSendProps = PrimitiveButtonProps;\n\nexport const ComposerPrimitiveSend = forwardRef<\n ComposerPrimitiveSendElement,\n ComposerPrimitiveSendProps\n>(({ disabled, ...rest }, ref) => {\n const { useComposer } = useComposerContext();\n const hasValue = useComposer((c) => c.isEditing && c.text.length > 0);\n\n return (\n <Primitive.button\n type=\"submit\"\n {...rest}\n ref={ref}\n disabled={disabled || !hasValue}\n />\n );\n});\n\nComposerPrimitiveSend.displayName = \"ComposerPrimitive.Send\";\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useComposerCancel } from \"../../primitive-hooks/composer/useComposerCancel\";\n\nexport type ComposerPrimitiveCancelProps = ActionButtonProps<\n typeof useComposerCancel\n>;\n\nexport const ComposerPrimitiveCancel = createActionButton(\n \"ComposerPrimitive.Cancel\",\n useComposerCancel,\n);\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseComposerIfProps,\n useComposerIf,\n} from \"../../primitive-hooks/composer/useComposerIf\";\n\nexport type ComposerPrimitiveIfProps = PropsWithChildren<UseComposerIfProps>;\n\nexport const ComposerPrimitiveIf: FC<ComposerPrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useComposerIf(query);\n return result ? children : null;\n};\n\nComposerPrimitiveIf.displayName = \"ComposerPrimitive.If\";\n","export { ContentPartPrimitiveText as Text } from \"./ContentPartText\";\nexport { ContentPartPrimitiveImage as Image } from \"./ContentPartImage\";\nexport { ContentPartPrimitiveDisplay as Display } from \"./ContentPartDisplay\";\nexport { ContentPartPrimitiveInProgress as InProgress } from \"./ContentPartInProgress\";\n","export { ThreadPrimitiveRoot as Root } from \"./ThreadRoot\";\nexport { ThreadPrimitiveEmpty as Empty } from \"./ThreadEmpty\";\nexport { ThreadPrimitiveIf as If } from \"./ThreadIf\";\nexport { ThreadPrimitiveViewport as Viewport } from \"./ThreadViewport\";\nexport { ThreadPrimitiveMessages as Messages } from \"./ThreadMessages\";\nexport { ThreadPrimitiveScrollToBottom as ScrollToBottom } from \"./ThreadScrollToBottom\";\nexport { ThreadPrimitiveSuggestion as Suggestion } from \"./ThreadSuggestion\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\n\ntype ThreadPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ThreadPrimitiveRootProps = PrimitiveDivProps;\n\nexport const ThreadPrimitiveRoot = forwardRef<\n ThreadPrimitiveRootElement,\n ThreadPrimitiveRootProps\n>((props, ref) => {\n return <Primitive.div {...props} ref={ref} />;\n});\n\nThreadPrimitiveRoot.displayName = \"ThreadPrimitive.Root\";\n","\"use client\";\n\nimport type { FC, ReactNode } from \"react\";\nimport { useThreadEmpty } from \"../../primitive-hooks\";\n\nexport type ThreadPrimitiveEmptyProps = {\n children: ReactNode;\n};\n\nexport const ThreadPrimitiveEmpty: FC<ThreadPrimitiveEmptyProps> = ({\n children,\n}) => {\n const empty = useThreadEmpty();\n return empty ? children : null;\n};\n\nThreadPrimitiveEmpty.displayName = \"ThreadPrimitive.Empty\";\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseThreadIfProps,\n useThreadIf,\n} from \"../../primitive-hooks/thread/useThreadIf\";\n\nexport type ThreadPrimitiveIfProps = PropsWithChildren<UseThreadIfProps>;\n\nexport const ThreadPrimitiveIf: FC<ThreadPrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useThreadIf(query);\n return result ? children : null;\n};\n\nThreadPrimitiveIf.displayName = \"ThreadPrimitive.If\";\n","\"use client\";\n\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport {\n UseThreadViewportAutoScrollProps,\n useThreadViewportAutoScroll,\n} from \"../../primitive-hooks/thread/useThreadViewportAutoScroll\";\n\ntype ThreadPrimitiveViewportElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ThreadPrimitiveViewportProps = PrimitiveDivProps &\n UseThreadViewportAutoScrollProps;\n\nexport const ThreadPrimitiveViewport = forwardRef<\n ThreadPrimitiveViewportElement,\n ThreadPrimitiveViewportProps\n>(({ autoScroll, onScroll, children, ...rest }, forwardedRef) => {\n const autoScrollRef = useThreadViewportAutoScroll<HTMLDivElement>({\n autoScroll,\n });\n\n const ref = useComposedRefs(forwardedRef, autoScrollRef);\n\n return (\n <Primitive.div {...rest} ref={ref}>\n {children}\n </Primitive.div>\n );\n});\n\nThreadPrimitiveViewport.displayName = \"ThreadPrimitive.Viewport\";\n","\"use client\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useRef } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useOnResizeContent } from \"../../utils/hooks/useOnResizeContent\";\nimport { useOnScrollToBottom } from \"../../utils/hooks/useOnScrollToBottom\";\nimport { StoreApi } from \"zustand\";\nimport { ThreadViewportState } from \"../../context\";\nimport { useManagedRef } from \"../../utils/hooks/useManagedRef\";\n\nexport type UseThreadViewportAutoScrollProps = {\n autoScroll?: boolean | undefined;\n};\n\nexport const useThreadViewportAutoScroll = <TElement extends HTMLElement>({\n autoScroll = true,\n}: UseThreadViewportAutoScrollProps) => {\n const divRef = useRef<TElement>(null);\n\n const { useViewport } = useThreadContext();\n\n const lastScrollTop = useRef<number>(0);\n\n // bug: when ScrollToBottom's button changes its disabled state, the scroll stops\n // fix: delay the state change until the scroll is done\n const isScrollingToBottomRef = useRef(false);\n\n const scrollToBottom = (behavior: ScrollBehavior) => {\n const div = divRef.current;\n if (!div || !autoScroll) return;\n\n isScrollingToBottomRef.current = true;\n div.scrollTo({ top: div.scrollHeight, behavior });\n };\n\n const handleScroll = () => {\n const div = divRef.current;\n if (!div) return;\n\n const isAtBottom = useViewport.getState().isAtBottom;\n const newIsAtBottom =\n div.scrollHeight - div.scrollTop <= div.clientHeight + 1; // TODO figure out why +1 is needed\n\n if (!newIsAtBottom && lastScrollTop.current < div.scrollTop) {\n // ignore scroll down\n } else {\n if (newIsAtBottom) {\n isScrollingToBottomRef.current = false;\n }\n\n if (newIsAtBottom !== isAtBottom) {\n (useViewport as unknown as StoreApi<ThreadViewportState>).setState({\n isAtBottom: newIsAtBottom,\n });\n }\n }\n\n lastScrollTop.current = div.scrollTop;\n };\n\n const resizeRef = useOnResizeContent(() => {\n if (isScrollingToBottomRef.current || useViewport.getState().isAtBottom) {\n scrollToBottom(\"instant\");\n }\n\n handleScroll();\n });\n\n const scrollRef = useManagedRef<HTMLElement>((el) => {\n el.addEventListener(\"scroll\", handleScroll);\n return () => {\n el.removeEventListener(\"scroll\", handleScroll);\n };\n });\n\n const autoScrollRef = useComposedRefs<TElement>(resizeRef, scrollRef, divRef);\n\n useOnScrollToBottom(() => {\n scrollToBottom(\"auto\");\n });\n\n return autoScrollRef;\n};\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useCallback } from \"react\";\nimport { useManagedRef } from \"./useManagedRef\";\n\nexport const useOnResizeContent = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const refCallback = useCallback(\n (el: HTMLElement) => {\n const resizeObserver = new ResizeObserver(() => {\n callbackRef();\n });\n\n const mutationObserver = new MutationObserver((mutations) => {\n for (const mutation of mutations) {\n for (const node of mutation.addedNodes) {\n if (node instanceof Element) {\n resizeObserver.observe(node);\n }\n }\n\n for (const node of mutation.removedNodes) {\n if (node instanceof Element) {\n resizeObserver.unobserve(node);\n }\n }\n }\n\n callbackRef();\n });\n\n resizeObserver.observe(el);\n mutationObserver.observe(el, { childList: true });\n\n // Observe existing children\n for (const child of el.children) {\n resizeObserver.observe(child);\n }\n\n return () => {\n resizeObserver.disconnect();\n mutationObserver.disconnect();\n };\n },\n [callbackRef],\n );\n\n return useManagedRef(refCallback);\n};\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEffect } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\n\nexport const useOnScrollToBottom = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const { useViewport } = useThreadContext();\n useEffect(() => {\n return useViewport.getState().onScrollToBottom(() => {\n callbackRef();\n });\n }, [useViewport, callbackRef]);\n};\n","\"use client\";\n\nimport { type ComponentType, type FC, memo } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { MessageProvider } from \"../../context/providers/MessageProvider\";\nimport { ComposerPrimitiveIf } from \"../composer/ComposerIf\";\nimport { MessagePrimitiveIf } from \"../message/MessageIf\";\n\nexport type ThreadPrimitiveMessagesProps = {\n components:\n | {\n Message: ComponentType;\n UserMessage?: ComponentType | undefined;\n EditComposer?: ComponentType | undefined;\n AssistantMessage?: ComponentType | undefined;\n SystemMessage?: ComponentType | undefined;\n }\n | {\n Message?: ComponentType | undefined;\n UserMessage: ComponentType;\n EditComposer?: ComponentType | undefined;\n AssistantMessage: ComponentType;\n SystemMessage?: ComponentType | undefined;\n };\n};\n\nconst DEFAULT_SYSTEM_MESSAGE = () => null;\n\nconst getComponents = (\n components: ThreadPrimitiveMessagesProps[\"components\"],\n) => {\n return {\n EditComposer:\n components.EditComposer ??\n components.UserMessage ??\n (components.Message as ComponentType),\n UserMessage:\n components.UserMessage ?? (components.Message as ComponentType),\n AssistantMessage:\n components.AssistantMessage ?? (components.Message as ComponentType),\n SystemMessage: components.SystemMessage ?? DEFAULT_SYSTEM_MESSAGE,\n };\n};\n\ntype ThreadMessageProps = {\n messageIndex: number;\n components: ThreadPrimitiveMessagesProps[\"components\"];\n};\n\nconst ThreadMessageImpl: FC<ThreadMessageProps> = ({\n messageIndex,\n components,\n}) => {\n const { UserMessage, EditComposer, AssistantMessage, SystemMessage } =\n getComponents(components);\n return (\n <MessageProvider messageIndex={messageIndex}>\n <MessagePrimitiveIf user>\n <ComposerPrimitiveIf editing={false}>\n <UserMessage />\n </ComposerPrimitiveIf>\n <ComposerPrimitiveIf editing>\n <EditComposer />\n </ComposerPrimitiveIf>\n </MessagePrimitiveIf>\n <MessagePrimitiveIf assistant>\n <AssistantMessage />\n </MessagePrimitiveIf>\n <MessagePrimitiveIf system>\n <SystemMessage />\n </MessagePrimitiveIf>\n </MessageProvider>\n );\n};\n\nconst ThreadMessage = memo(\n ThreadMessageImpl,\n (prev, next) =>\n prev.messageIndex === next.messageIndex &&\n prev.components.Message === next.components.Message &&\n prev.components.UserMessage === next.components.UserMessage &&\n prev.components.EditComposer === next.components.EditComposer &&\n prev.components.AssistantMessage === next.components.AssistantMessage &&\n prev.components.SystemMessage === next.components.SystemMessage,\n);\n\nexport const ThreadPrimitiveMessagesImpl: FC<ThreadPrimitiveMessagesProps> = ({\n components,\n}) => {\n const { useThreadMessages } = useThreadContext();\n\n const messagesLength = useThreadMessages((t) => t.length);\n if (messagesLength === 0) return null;\n\n return new Array(messagesLength).fill(null).map((_, idx) => {\n const messageIndex = idx; // keep the same key when switching branches for better a11y support\n return (\n <ThreadMessage\n key={messageIndex}\n messageIndex={messageIndex}\n components={components}\n />\n );\n });\n};\n\nThreadPrimitiveMessagesImpl.displayName = \"ThreadPrimitive.Messages\";\n\nexport const ThreadPrimitiveMessages = memo(\n ThreadPrimitiveMessagesImpl,\n (prev, next) =>\n prev.components?.Message === next.components?.Message &&\n prev.components?.UserMessage === next.components?.UserMessage &&\n prev.components?.EditComposer === next.components?.EditComposer &&\n prev.components?.AssistantMessage === next.components?.AssistantMessage &&\n prev.components?.SystemMessage === next.components?.SystemMessage,\n);\n","\"use client\";\n\nimport { type FC, type PropsWithChildren, useEffect, useState } from \"react\";\nimport { StoreApi, create } from \"zustand\";\nimport type {\n CoreUserContentPart,\n ThreadMessage,\n} from \"../../types/AssistantTypes\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\nimport { MessageContext } from \"../react/MessageContext\";\nimport type { MessageContextValue } from \"../react/MessageContext\";\nimport { useThreadContext } from \"../react/ThreadContext\";\nimport type { MessageState } from \"../stores/Message\";\nimport { makeEditComposerStore } from \"../stores/EditComposer\";\nimport { makeMessageUtilsStore } from \"../stores/MessageUtils\";\nimport { ThreadMessagesState } from \"../stores/ThreadMessages\";\n\ntype MessageProviderProps = PropsWithChildren<{\n messageIndex: number;\n}>;\n\nconst getIsLast = (messages: ThreadMessagesState, message: ThreadMessage) => {\n return messages[messages.length - 1]?.id === message.id;\n};\n\nconst getMessageState = (\n messages: ThreadMessagesState,\n getBranches: (messageId: string) => readonly string[],\n useMessage: MessageContextValue[\"useMessage\"] | undefined,\n messageIndex: number,\n) => {\n const parentId = messages[messageIndex - 1]?.id ?? null;\n const message = messages[messageIndex];\n if (!message) return null;\n\n const isLast = getIsLast(messages, message);\n const branches = getBranches(message.id);\n\n // if the message is the same, don't update\n const currentState = useMessage?.getState();\n if (\n currentState &&\n currentState.message === message &&\n currentState.parentId === parentId &&\n currentState.branches === branches &&\n currentState.isLast === isLast\n )\n return null;\n\n return Object.freeze({\n message,\n parentId,\n branches,\n isLast,\n });\n};\n\nconst useMessageContext = (messageIndex: number) => {\n const { useThreadMessages, useThreadActions } = useThreadContext();\n\n const [context] = useState<MessageContextValue>(() => {\n const useMessage = create<MessageState>(\n () =>\n getMessageState(\n useThreadMessages.getState(),\n useThreadActions.getState().getBranches,\n undefined,\n messageIndex,\n )!,\n );\n const useMessageUtils = makeMessageUtilsStore();\n const useEditComposer = makeEditComposerStore({\n onEdit: () => {\n const message = useMessage.getState().message;\n if (message.role !== \"user\")\n throw new Error(\n \"Tried to edit a non-user message. Editing is only supported for user messages. This is likely an internal bug in assistant-ui.\",\n );\n\n const text = getThreadMessageText(message);\n\n return text;\n },\n onSend: (text) => {\n const { message, parentId } = useMessage.getState();\n if (message.role !== \"user\")\n throw new Error(\n \"Tried to edit a non-user message. Editing is only supported for user messages. This is likely an internal bug in assistant-ui.\",\n );\n\n const nonTextParts = message.content.filter(\n (part): part is CoreUserContentPart =>\n part.type !== \"text\" && part.type !== \"ui\",\n );\n useThreadActions.getState().append({\n parentId,\n role: \"user\",\n content: [{ type: \"text\", text }, ...nonTextParts],\n });\n },\n });\n\n return { useMessage, useMessageUtils, useEditComposer };\n });\n\n useEffect(() => {\n const syncMessage = (thread: ThreadMessagesState) => {\n const newState = getMessageState(\n thread,\n useThreadActions.getState().getBranches,\n context.useMessage,\n messageIndex,\n );\n if (!newState) return;\n (context.useMessage as unknown as StoreApi<MessageState>).setState(\n newState,\n true,\n );\n };\n\n syncMessage(useThreadMessages.getState());\n\n return useThreadMessages.subscribe(syncMessage);\n }, [useThreadMessages, useThreadActions, context, messageIndex]);\n\n return context;\n};\n\nexport const MessageProvider: FC<MessageProviderProps> = ({\n messageIndex,\n children,\n}) => {\n const context = useMessageContext(messageIndex);\n\n return (\n <MessageContext.Provider value={context}>\n {children}\n </MessageContext.Provider>\n );\n};\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type EditComposerState = Readonly<{\n // TODO \n /** @deprecated Use `text` instead. */\n value: string;\n /** @deprecated Use `setText` instead. */\n setValue: (value: string) => void;\n\n text: string;\n setText: (value: string) => void;\n\n canCancel: boolean;\n isEditing: boolean;\n\n edit: () => void;\n send: () => void;\n cancel: () => void;\n}>;\n\nexport const makeEditComposerStore = ({\n onEdit,\n onSend,\n}: {\n onEdit: () => string;\n onSend: (text: string) => void;\n}): ReadonlyStore<EditComposerState> =>\n create<EditComposerState>()((set, get) => ({\n get value() {\n return get().text;\n },\n setValue(value) {\n get().setText(value);\n },\n\n text: \"\",\n setText: (text) => {\n set({ text });\n },\n\n canCancel: false,\n isEditing: false,\n\n edit: () => {\n const text = onEdit();\n set({ isEditing: true, canCancel: true, text });\n },\n send: () => {\n const text = get().text;\n set({ isEditing: false, canCancel: false });\n onSend(text);\n },\n cancel: () => {\n set({ isEditing: false, canCancel: false });\n },\n }));\n","import { create } from \"zustand\";\nimport { SpeechSynthesisAdapter } from \"../../runtimes/speech/SpeechAdapterTypes\";\n\nexport type MessageUtilsState = Readonly<{\n isCopied: boolean;\n setIsCopied: (value: boolean) => void;\n isHovering: boolean;\n setIsHovering: (value: boolean) => void;\n\n isSpeaking: boolean;\n stopSpeaking: () => void;\n addUtterance: (utterance: SpeechSynthesisAdapter.Utterance) => void;\n}>;\n\nexport const makeMessageUtilsStore = () =>\n create<MessageUtilsState>((set) => {\n let utterance: SpeechSynthesisAdapter.Utterance | null = null;\n return {\n isCopied: false,\n setIsCopied: (value) => {\n set({ isCopied: value });\n },\n isHovering: false,\n setIsHovering: (value) => {\n set({ isHovering: value });\n },\n isSpeaking: false,\n stopSpeaking: () => {\n utterance?.cancel();\n },\n addUtterance: (utt) => {\n utterance = utt;\n set({ isSpeaking: true });\n utt.onEnd(() => {\n set({ isSpeaking: false });\n });\n },\n };\n });\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useThreadScrollToBottom } from \"../../primitive-hooks/thread/useThreadScrollToBottom\";\n\nexport type ThreadPrimitiveScrollToBottomProps = ActionButtonProps<\n typeof useThreadScrollToBottom\n>;\n\nexport const ThreadPrimitiveScrollToBottom = createActionButton(\n \"ThreadPrimitive.ScrollToBottom\",\n useThreadScrollToBottom,\n);\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useThreadSuggestion } from \"../../primitive-hooks/thread/useThreadSuggestion\";\n\nexport type ThreadPrimitiveSuggestionProps = ActionButtonProps<\n typeof useThreadSuggestion\n>;\n\nexport const ThreadPrimitiveSuggestion = createActionButton(\n \"ThreadPrimitive.Suggestion\",\n useThreadSuggestion,\n [\"prompt\", \"autoSend\", \"method\"],\n);\n","\"use client\";\n\nimport {\n FC,\n PropsWithChildren,\n ReactNode,\n createContext,\n useContext,\n} from \"react\";\n\nimport { AvatarProps } from \"./base/avatar\";\nimport { TextContentPartComponent } from \"../types\";\nimport { AssistantRuntime } from \"../runtimes\";\nimport { AssistantRuntimeProvider, useAssistantContext } from \"../context\";\n\nexport type SuggestionConfig = {\n text?: ReactNode;\n prompt: string;\n};\n\nexport type ThreadWelcomeConfig = {\n message?: string | null | undefined;\n suggestions?: SuggestionConfig[] | undefined;\n};\n\nexport type UserMessageConfig = {\n allowEdit?: boolean | undefined;\n};\n\nexport type AssistantMessageConfig = {\n allowReload?: boolean | undefined;\n allowCopy?: boolean | undefined;\n allowSpeak?: boolean | undefined;\n components?:\n | {\n Text?: TextContentPartComponent | undefined;\n }\n | undefined;\n};\n\nexport type BranchPickerConfig = {\n allowBranchPicker?: boolean | undefined;\n};\n\nexport type StringsConfig = {\n assistantModal?: {\n open: {\n button: {\n tooltip?: string | undefined;\n };\n };\n closed: {\n button: {\n tooltip?: string | undefined;\n };\n };\n };\n thread?: {\n scrollToBottom?: {\n tooltip?: string | undefined;\n };\n };\n userMessage?: {\n edit?: {\n tooltip?: string | undefined;\n };\n };\n assistantMessage?: {\n reload?: {\n tooltip?: string | undefined;\n };\n copy?: {\n tooltip?: string | undefined;\n };\n speak?: {\n tooltip?: string | undefined;\n stop?: {\n tooltip?: string | undefined;\n };\n };\n };\n branchPicker?: {\n previous?: {\n tooltip?: string | undefined;\n };\n next?: {\n tooltip?: string | undefined;\n };\n };\n composer?: {\n send?:\n | {\n tooltip?: string | undefined;\n }\n | undefined;\n cancel?:\n | {\n tooltip?: string | undefined;\n }\n | undefined;\n input?: {\n placeholder?: string | undefined;\n };\n };\n editComposer?: {\n send?: {\n label?: string | undefined;\n };\n cancel?: {\n label?: string | undefined;\n };\n };\n code?: {\n header?: {\n copy?: {\n tooltip?: string | undefined;\n };\n };\n };\n};\n\nconst ThreadConfigContext = createContext<ThreadConfig>({});\n\nexport type ThreadConfig = {\n runtime?: AssistantRuntime;\n\n assistantAvatar?: AvatarProps;\n\n welcome?: ThreadWelcomeConfig;\n assistantMessage?: AssistantMessageConfig;\n userMessage?: UserMessageConfig;\n\n branchPicker?: BranchPickerConfig;\n\n strings?: StringsConfig;\n};\n\nexport const useThreadConfig = (): Omit<ThreadConfig, \"runtime\"> => {\n return useContext(ThreadConfigContext);\n};\n\nexport type ThreadConfigProviderProps = PropsWithChildren<{\n config?: ThreadConfig | undefined;\n}>;\n\nexport const ThreadConfigProvider: FC<ThreadConfigProviderProps> = ({\n children,\n config,\n}) => {\n const assistant = useAssistantContext({ optional: true });\n\n const configProvider =\n config && Object.keys(config ?? {}).length > 0 ? (\n <ThreadConfigContext.Provider value={config}>\n {children}\n </ThreadConfigContext.Provider>\n ) : (\n <>{children}</>\n );\n if (!config?.runtime) return configProvider;\n\n if (assistant) {\n throw new Error(\n \"You provided a runtime to <Thread> while simulataneously using <AssistantRuntimeProvider>. This is not allowed.\",\n );\n }\n return (\n <AssistantRuntimeProvider runtime={config.runtime}>\n {configProvider}\n </AssistantRuntimeProvider>\n );\n};\n\nThreadConfigProvider.displayName = \"ThreadConfigProvider\";\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\nimport {\n AudioLinesIcon,\n CheckIcon,\n CopyIcon,\n RefreshCwIcon,\n StopCircleIcon,\n} from \"lucide-react\";\nimport { ActionBarPrimitive, MessagePrimitive } from \"../primitives\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { useThreadContext } from \"../context\";\n\nconst useAllowCopy = (ensureCapability = false) => {\n const { assistantMessage: { allowCopy = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const copySupported = useThread((t) => t.capabilities.unstable_copy);\n return allowCopy && (!ensureCapability || copySupported);\n};\n\nconst useAllowSpeak = (ensureCapability = false) => {\n const { assistantMessage: { allowSpeak = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const speakSupported = useThread((t) => t.capabilities.speak);\n return allowSpeak && (!ensureCapability || speakSupported);\n};\n\nconst useAllowReload = (ensureCapability = false) => {\n const { assistantMessage: { allowReload = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const reloadSupported = useThread((t) => t.capabilities.reload);\n return allowReload && (!ensureCapability || reloadSupported);\n};\n\nconst AssistantActionBar: FC = () => {\n const allowCopy = useAllowCopy(true);\n const allowReload = useAllowReload(true);\n const allowSpeak = useAllowSpeak(true);\n if (!allowCopy && !allowReload && !allowSpeak) return null;\n return (\n <AssistantActionBarRoot\n hideWhenRunning\n autohide=\"not-last\"\n autohideFloat=\"single-branch\"\n >\n {allowSpeak && <AssistantActionBarSpeechControl />}\n {allowCopy && <AssistantActionBarCopy />}\n {allowReload && <AssistantActionBarReload />}\n </AssistantActionBarRoot>\n );\n};\n\nAssistantActionBar.displayName = \"AssistantActionBar\";\n\nconst AssistantActionBarRoot = withDefaults(ActionBarPrimitive.Root, {\n className: \"aui-assistant-action-bar-root\",\n});\n\nAssistantActionBarRoot.displayName = \"AssistantActionBarRoot\";\n\nconst AssistantActionBarCopy = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { copy: { tooltip = \"Copy\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n\n return (\n <ActionBarPrimitive.Copy asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? (\n <>\n <MessagePrimitive.If copied>\n <CheckIcon />\n </MessagePrimitive.If>\n <MessagePrimitive.If copied={false}>\n <CopyIcon />\n </MessagePrimitive.If>\n </>\n )}\n </TooltipIconButton>\n </ActionBarPrimitive.Copy>\n );\n});\n\nAssistantActionBarCopy.displayName = \"AssistantActionBarCopy\";\n\nconst AssistantActionBarSpeechControl: FC = () => {\n return (\n <>\n <MessagePrimitive.If speaking={false}>\n <AssistantActionBarSpeak />\n </MessagePrimitive.If>\n <MessagePrimitive.If speaking>\n <AssistantActionBarStopSpeaking />\n </MessagePrimitive.If>\n </>\n );\n};\n\nconst AssistantActionBarSpeak = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { speak: { tooltip = \"Read aloud\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n const allowSpeak = useAllowSpeak();\n if (!allowSpeak) return null;\n return (\n <ActionBarPrimitive.Speak asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <AudioLinesIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.Speak>\n );\n});\n\nAssistantActionBarSpeak.displayName = \"AssistantActionBarSpeak\";\n\nconst AssistantActionBarStopSpeaking = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: {\n speak: { stop: { tooltip: stopTooltip = \"Stop\" } = {} } = {},\n } = {},\n } = {},\n } = useThreadConfig();\n const allowSpeak = useAllowSpeak();\n if (!allowSpeak) return null;\n return (\n <ActionBarPrimitive.StopSpeaking asChild>\n <TooltipIconButton tooltip={stopTooltip} {...props} ref={ref}>\n {props.children ?? <StopCircleIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.StopSpeaking>\n );\n});\n\nAssistantActionBarStopSpeaking.displayName = \"AssistantActionBarStopSpeaking\";\n\nconst AssistantActionBarReload = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { reload: { tooltip = \"Refresh\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n const allowReload = useAllowReload();\n if (!allowReload) return null;\n return (\n <ActionBarPrimitive.Reload asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n <RefreshCwIcon />\n </TooltipIconButton>\n </ActionBarPrimitive.Reload>\n );\n});\n\nAssistantActionBarReload.displayName = \"AssistantActionBarReload\";\n\nconst exports = {\n Root: AssistantActionBarRoot,\n Reload: AssistantActionBarReload,\n Copy: AssistantActionBarCopy,\n Speak: AssistantActionBarSpeak,\n StopSpeaking: AssistantActionBarStopSpeaking,\n SpeechControl: AssistantActionBarSpeechControl,\n};\n\nexport default Object.assign(\n AssistantActionBar,\n exports,\n) as typeof AssistantActionBar & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { MessagePrimitive, MessagePrimitiveContentProps } from \"../primitives\";\nimport BranchPicker from \"./branch-picker\";\nimport { Avatar } from \"./base/avatar\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport AssistantActionBar from \"./assistant-action-bar\";\nimport ContentPart from \"./content-part\";\n\nconst AssistantMessage: FC = () => {\n return (\n <AssistantMessageRoot>\n <AssistantMessageAvatar />\n <AssistantMessageContent />\n <BranchPicker />\n <AssistantActionBar />\n </AssistantMessageRoot>\n );\n};\n\nAssistantMessage.displayName = \"AssistantMessage\";\n\nconst AssistantMessageAvatar: FC = () => {\n const { assistantAvatar: avatar = { fallback: \"A\" } } = useThreadConfig();\n return <Avatar {...avatar} />;\n};\n\nconst AssistantMessageRoot = withDefaults(MessagePrimitive.Root, {\n className: \"aui-assistant-message-root\",\n});\n\nAssistantMessageRoot.displayName = \"AssistantMessageRoot\";\n\nconst AssistantMessageContentWrapper = withDefaults(\"div\", {\n className: \"aui-assistant-message-content\",\n});\n\nexport type AssistantMessageContentProps = MessagePrimitiveContentProps &\n ComponentPropsWithoutRef<\"div\">;\n\nconst AssistantMessageContent = forwardRef<\n HTMLDivElement,\n AssistantMessageContentProps\n>(({ components: componentsProp, ...rest }, ref) => {\n const { assistantMessage: { components = {} } = {} } = useThreadConfig();\n return (\n <AssistantMessageContentWrapper {...rest} ref={ref}>\n <MessagePrimitive.Content\n components={{\n ...componentsProp,\n Text: componentsProp?.Text ?? components.Text ?? ContentPart.Text,\n }}\n />\n </AssistantMessageContentWrapper>\n );\n});\n\nAssistantMessageContent.displayName = \"AssistantMessageContent\";\n\nconst exports = {\n Root: AssistantMessageRoot,\n Avatar: AssistantMessageAvatar,\n Content: AssistantMessageContent,\n};\n\nexport default Object.assign(\n AssistantMessage,\n exports,\n) as typeof AssistantMessage & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { ChevronLeftIcon, ChevronRightIcon } from \"lucide-react\";\n\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { BranchPickerPrimitive } from \"../primitives\";\nimport { useThreadContext } from \"../context\";\n\nconst useAllowBranchPicker = () => {\n const { branchPicker: { allowBranchPicker = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const branchPickerSupported = useThread((t) => t.capabilities.edit);\n return branchPickerSupported && allowBranchPicker;\n};\n\nconst BranchPicker: FC = () => {\n const allowBranchPicker = useAllowBranchPicker();\n if (!allowBranchPicker) return null;\n return (\n <BranchPickerRoot hideWhenSingleBranch>\n <BranchPickerPrevious />\n <BranchPickerState />\n <BranchPickerNext />\n </BranchPickerRoot>\n );\n};\n\nBranchPicker.displayName = \"BranchPicker\";\n\nconst BranchPickerRoot = withDefaults(BranchPickerPrimitive.Root, {\n className: \"aui-branch-picker-root\",\n});\n\nBranchPickerRoot.displayName = \"BranchPickerRoot\";\n\nconst BranchPickerPrevious = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n branchPicker: { previous: { tooltip = \"Previous\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <BranchPickerPrimitive.Previous asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ChevronLeftIcon />}\n </TooltipIconButton>\n </BranchPickerPrimitive.Previous>\n );\n});\n\nBranchPickerPrevious.displayName = \"BranchPickerPrevious\";\n\nconst BranchPickerStateWrapper = withDefaults(\"span\", {\n className: \"aui-branch-picker-state\",\n});\n\nconst BranchPickerState = forwardRef<\n HTMLSpanElement,\n ComponentPropsWithoutRef<\"span\">\n>((props, ref) => {\n return (\n <BranchPickerStateWrapper {...props} ref={ref}>\n <BranchPickerPrimitive.Number /> / <BranchPickerPrimitive.Count />\n </BranchPickerStateWrapper>\n );\n});\n\nBranchPickerState.displayName = \"BranchPickerState\";\n\nconst BranchPickerNext = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { branchPicker: { next: { tooltip = \"Next\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <BranchPickerPrimitive.Next asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ChevronRightIcon />}\n </TooltipIconButton>\n </BranchPickerPrimitive.Next>\n );\n});\n\nBranchPickerNext.displayName = \"BranchPickerNext\";\n\nconst exports = {\n Root: BranchPickerRoot,\n Previous: BranchPickerPrevious,\n Next: BranchPickerNext,\n};\n\nexport default Object.assign(BranchPicker, exports) as typeof BranchPicker &\n typeof exports;\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport * as AvatarPrimitive from \"@radix-ui/react-avatar\";\n\nimport { withDefaults } from \"../utils/withDefaults\";\n\nexport type AvatarProps = {\n src?: string | undefined;\n alt?: string | undefined;\n fallback?: string | undefined;\n};\n\nexport const Avatar: FC<AvatarProps> = ({ src, alt, fallback }) => {\n if (src == null && fallback == null) return null;\n\n return (\n <AvatarRoot>\n {src != null && <AvatarImage src={src} alt={alt} />}\n {fallback != null && <AvatarFallback>{fallback}</AvatarFallback>}\n </AvatarRoot>\n );\n};\n\nAvatar.displayName = \"Avatar\";\n\nexport const AvatarRoot = withDefaults(AvatarPrimitive.Root, {\n className: \"aui-avatar-root\",\n});\n\nAvatarRoot.displayName = \"AvatarRoot\";\n\nexport const AvatarImage = withDefaults(AvatarPrimitive.Image, {\n className: \"aui-avatar-image\",\n});\n\nAvatarImage.displayName = \"AvatarImage\";\n\nexport const AvatarFallback = withDefaults(AvatarPrimitive.Fallback, {\n className: \"aui-avatar-fallback\",\n});\n\nAvatarFallback.displayName = \"AvatarFallback\";\n","import { FC } from \"react\";\nimport { ContentPartPrimitive } from \"../primitives\";\nimport { useSmoothStatus, withSmoothContextProvider } from \"../utils/smooth\";\nimport classNames from \"classnames\";\n\nexport const Text: FC = () => {\n const status = useSmoothStatus();\n return (\n <ContentPartPrimitive.Text\n className={classNames(\n \"aui-text\",\n status.type === \"running\" && \"aui-text-running\",\n )}\n component=\"p\"\n />\n );\n};\n\nconst exports = { Text: withSmoothContextProvider(Text) };\n\nexport default exports;\n","\"use client\";\n\nimport { type FC, forwardRef } from \"react\";\nimport { BotIcon, ChevronDownIcon } from \"lucide-react\";\n\nimport {\n AssistantModalPrimitive,\n AssistantModalPrimitiveRootProps,\n} from \"../primitives\";\nimport Thread from \"./thread\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport {\n ThreadConfig,\n ThreadConfigProvider,\n ThreadConfigProviderProps,\n useThreadConfig,\n} from \"./thread-config\";\n\nconst AssistantModal: FC<ThreadConfig> = (config) => {\n return (\n <AssistantModalRoot config={config}>\n <AssistantModalTrigger />\n <AssistantModalContent>\n <Thread />\n </AssistantModalContent>\n </AssistantModalRoot>\n );\n};\n\nAssistantModal.displayName = \"AssistantModal\";\n\nconst AssistantModalRoot: FC<\n AssistantModalPrimitiveRootProps & ThreadConfigProviderProps\n> = ({ config, ...props }) => {\n return (\n <ThreadConfigProvider config={config}>\n <AssistantModalPrimitive.Root {...props} />\n </ThreadConfigProvider>\n );\n};\n\nAssistantModalRoot.displayName = \"AssistantModalRoot\";\n\nconst AssistantModalTrigger = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n return (\n <AssistantModalAnchor>\n <AssistantModalPrimitive.Trigger asChild>\n <AssistantModalButton {...props} ref={ref} />\n </AssistantModalPrimitive.Trigger>\n </AssistantModalAnchor>\n );\n});\n\nAssistantModalTrigger.displayName = \"AssistantModalTrigger\";\n\nconst AssistantModalAnchor = withDefaults(AssistantModalPrimitive.Anchor, {\n className: \"aui-root aui-modal-anchor\",\n});\n\nAssistantModalAnchor.displayName = \"AssistantModalAnchor\";\n\nconst ModalButtonStyled = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-modal-button\",\n});\n\ntype AssistantModalButtonProps = TooltipIconButtonProps & {\n \"data-state\"?: \"open\" | \"closed\";\n};\n\nconst AssistantModalButton = forwardRef<\n HTMLButtonElement,\n Partial<AssistantModalButtonProps>\n>(({ \"data-state\": state, ...rest }, ref) => {\n const {\n strings: {\n assistantModal: {\n open: {\n button: { tooltip: openTooltip = \"Close Assistant\" } = {},\n } = {},\n closed: {\n button: { tooltip: closedTooltip = \"Open Assistant\" } = {},\n } = {},\n } = {},\n } = {},\n } = useThreadConfig();\n const tooltip = state === \"open\" ? openTooltip : closedTooltip;\n\n return (\n <ModalButtonStyled\n side=\"left\"\n tooltip={tooltip}\n data-state={state}\n {...rest}\n ref={ref}\n >\n {rest.children ?? (\n <>\n <BotIcon\n data-state={state}\n className=\"aui-modal-button-closed-icon\"\n />\n <ChevronDownIcon\n data-state={state}\n className=\"aui-modal-button-open-icon\"\n />\n </>\n )}\n </ModalButtonStyled>\n );\n});\n\nAssistantModalButton.displayName = \"AssistantModalButton\";\n\nconst AssistantModalContent = withDefaults(AssistantModalPrimitive.Content, {\n className: \"aui-root aui-modal-content\",\n sideOffset: 16,\n});\n\nAssistantModalContent.displayName = \"AssistantModalContent\";\n\nconst exports = {\n Root: AssistantModalRoot,\n Trigger: AssistantModalTrigger,\n Content: AssistantModalContent,\n Button: AssistantModalButton,\n Anchor: AssistantModalAnchor,\n};\n\nexport default Object.assign(AssistantModal, exports) as typeof AssistantModal &\n typeof exports;\n","\"use client\";\n\nimport { ComponentType, forwardRef, type FC } from \"react\";\nimport { ArrowDownIcon } from \"lucide-react\";\n\nimport { withDefaults } from \"./utils/withDefaults\";\nimport Composer from \"./composer\";\nimport ThreadWelcome from \"./thread-welcome\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport AssistantMessage from \"./assistant-message\";\nimport UserMessage from \"./user-message\";\nimport EditComposer from \"./edit-composer\";\nimport {\n ThreadConfig,\n ThreadConfigProvider,\n ThreadConfigProviderProps,\n useThreadConfig,\n} from \"./thread-config\";\nimport { ThreadPrimitive, ThreadPrimitiveRootProps } from \"../primitives\";\n\nconst Thread: FC<ThreadConfig> = (config) => {\n return (\n <ThreadRoot config={config}>\n <ThreadViewport>\n <ThreadWelcome />\n <ThreadMessages />\n <ThreadViewportFooter>\n <ThreadScrollToBottom />\n <Composer />\n </ThreadViewportFooter>\n </ThreadViewport>\n </ThreadRoot>\n );\n};\n\nexport type ThreadRootProps = ThreadPrimitiveRootProps &\n ThreadConfigProviderProps;\n\nconst ThreadRootStyled = withDefaults(ThreadPrimitive.Root, {\n className: \"aui-root aui-thread-root\",\n});\n\nconst ThreadRoot = forwardRef<HTMLDivElement, ThreadRootProps>(\n ({ config, ...props }, ref) => {\n return (\n <ThreadConfigProvider config={config}>\n <ThreadRootStyled {...props} ref={ref} />\n </ThreadConfigProvider>\n );\n },\n);\n\nThreadRoot.displayName = \"ThreadRoot\";\n\nconst ThreadViewport = withDefaults(ThreadPrimitive.Viewport, {\n className: \"aui-thread-viewport\",\n});\n\nThreadViewport.displayName = \"ThreadViewport\";\n\nconst ThreadViewportFooter = withDefaults(\"div\", {\n className: \"aui-thread-viewport-footer\",\n});\n\nThreadViewportFooter.displayName = \"ThreadViewportFooter\";\n\nconst SystemMessage = () => null;\n\nconst ThreadMessages: FC<{\n components?: {\n UserMessage?: ComponentType | undefined;\n EditComposer?: ComponentType | undefined;\n AssistantMessage?: ComponentType | undefined;\n SystemMessage?: ComponentType | undefined;\n };\n}> = ({ components, ...rest }) => {\n return (\n <ThreadPrimitive.Messages\n components={{\n UserMessage: components?.UserMessage ?? UserMessage,\n EditComposer: components?.EditComposer ?? EditComposer,\n AssistantMessage: components?.AssistantMessage ?? AssistantMessage,\n SystemMessage: components?.SystemMessage ?? SystemMessage,\n }}\n {...rest}\n />\n );\n};\n\nThreadMessages.displayName = \"ThreadMessages\";\n\nconst ThreadScrollToBottomIconButton = withDefaults(TooltipIconButton, {\n variant: \"outline\",\n className: \"aui-thread-scroll-to-bottom\",\n});\n\nconst ThreadScrollToBottom = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n thread: { scrollToBottom: { tooltip = \"Scroll to bottom\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ThreadPrimitive.ScrollToBottom asChild>\n <ThreadScrollToBottomIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ArrowDownIcon />}\n </ThreadScrollToBottomIconButton>\n </ThreadPrimitive.ScrollToBottom>\n );\n});\n\nThreadScrollToBottom.displayName = \"ThreadScrollToBottom\";\n\nconst exports = {\n Root: ThreadRoot,\n Viewport: ThreadViewport,\n Messages: ThreadMessages,\n ScrollToBottom: ThreadScrollToBottom,\n ViewportFooter: ThreadViewportFooter,\n};\n\nexport default Object.assign(Thread, exports) as typeof Thread & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\n\nimport { SendHorizontalIcon } from \"lucide-react\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { CircleStopIcon } from \"./base/CircleStopIcon\";\nimport { ComposerPrimitive, ThreadPrimitive } from \"../primitives\";\nimport { useThreadContext } from \"../context\";\n\nconst Composer: FC = () => {\n return (\n <ComposerRoot>\n <ComposerInput autoFocus />\n <ComposerAction />\n </ComposerRoot>\n );\n};\n\nComposer.displayName = \"Composer\";\n\nconst ComposerRoot = withDefaults(ComposerPrimitive.Root, {\n className: \"aui-composer-root\",\n});\n\nComposerRoot.displayName = \"ComposerRoot\";\n\nconst ComposerInputStyled = withDefaults(ComposerPrimitive.Input, {\n rows: 1,\n autoFocus: true,\n className: \"aui-composer-input\",\n});\n\nexport type ComposerInputProps = ComponentPropsWithoutRef<\n typeof ComposerInputStyled\n>;\nconst ComposerInput = forwardRef<HTMLTextAreaElement, ComposerInputProps>(\n (props, ref) => {\n const {\n strings: {\n composer: { input: { placeholder = \"Write a message...\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ComposerInputStyled placeholder={placeholder} {...props} ref={ref} />\n );\n },\n);\n\nComposerInput.displayName = \"ComposerInput\";\n\nconst useAllowCancel = () => {\n const { useThread } = useThreadContext();\n const cancelSupported = useThread((t) => t.capabilities.cancel);\n return cancelSupported;\n};\n\nconst ComposerAction: FC = () => {\n const allowCancel = useAllowCancel();\n if (!allowCancel) return <ComposerSend />;\n return (\n <>\n <ThreadPrimitive.If running={false}>\n <ComposerSend />\n </ThreadPrimitive.If>\n <ThreadPrimitive.If running>\n <ComposerCancel />\n </ThreadPrimitive.If>\n </>\n );\n};\n\nComposerAction.displayName = \"ComposerAction\";\n\nconst ComposerSendButton = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-composer-send\",\n});\n\nconst ComposerSend = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { composer: { send: { tooltip = \"Send\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Send asChild>\n <ComposerSendButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <SendHorizontalIcon />}\n </ComposerSendButton>\n </ComposerPrimitive.Send>\n );\n});\n\nComposerSend.displayName = \"ComposerSend\";\n\nconst ComposerCancelButton = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-composer-cancel\",\n});\n\nconst ComposerCancel = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { composer: { cancel: { tooltip = \"Cancel\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Cancel asChild>\n <ComposerCancelButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <CircleStopIcon />}\n </ComposerCancelButton>\n </ComposerPrimitive.Cancel>\n );\n});\n\nComposerCancel.displayName = \"ComposerCancel\";\n\nconst exports = {\n Root: ComposerRoot,\n Input: ComposerInput,\n Action: ComposerAction,\n Send: ComposerSend,\n Cancel: ComposerCancel,\n};\n\nexport default Object.assign(Composer, exports) as typeof Composer &\n typeof exports;\n","import { FC } from \"react\";\n\nexport const CircleStopIcon: FC = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n >\n <rect width=\"10\" height=\"10\" x=\"3\" y=\"3\" rx=\"2\" />\n </svg>\n );\n};\n\nCircleStopIcon.displayName = \"CircleStopIcon\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { Avatar } from \"./base/avatar\";\nimport { SuggestionConfig, useThreadConfig } from \"./thread-config\";\nimport { ThreadPrimitive } from \"../primitives\";\n\nconst ThreadWelcome: FC = () => {\n return (\n <ThreadWelcomeRoot>\n <ThreadWelcomeCenter>\n <ThreadWelcomeAvatar />\n <ThreadWelcomeMessage />\n </ThreadWelcomeCenter>\n <ThreadWelcomeSuggestions />\n </ThreadWelcomeRoot>\n );\n};\n\nThreadWelcome.displayName = \"ThreadWelcome\";\n\nconst ThreadWelcomeRootStyled = withDefaults(\"div\", {\n className: \"aui-thread-welcome-root\",\n});\n\nconst ThreadWelcomeCenter = withDefaults(\"div\", {\n className: \"aui-thread-welcome-center\",\n});\n\ntype ThreadWelcomeRootProps = ComponentPropsWithoutRef<\"div\">;\n\nconst ThreadWelcomeRoot = forwardRef<HTMLDivElement, ThreadWelcomeRootProps>(\n (props, ref) => {\n return (\n <ThreadPrimitive.Empty>\n <ThreadWelcomeRootStyled {...props} ref={ref} />\n </ThreadPrimitive.Empty>\n );\n },\n);\n\nThreadWelcomeRoot.displayName = \"ThreadWelcomeRoot\";\n\nconst ThreadWelcomeAvatar: FC = () => {\n const { assistantAvatar: avatar = { fallback: \"A\" } } = useThreadConfig();\n return <Avatar {...avatar} />;\n};\n\nconst ThreadWelcomeMessageStyled = withDefaults(\"p\", {\n className: \"aui-thread-welcome-message\",\n});\n\nexport type ThreadWelcomeMessageProps = Omit<\n ComponentPropsWithoutRef<typeof ThreadWelcomeMessageStyled>,\n \"children\"\n> & { message?: string | undefined };\n\nconst ThreadWelcomeMessage = forwardRef<\n HTMLParagraphElement,\n ThreadWelcomeMessageProps\n>(({ message: messageProp, ...rest }, ref) => {\n const { welcome: { message = \"How can I help you today?\" } = {} } =\n useThreadConfig();\n return (\n <ThreadWelcomeMessageStyled {...rest} ref={ref}>\n {messageProp ?? message}\n </ThreadWelcomeMessageStyled>\n );\n});\n\nThreadWelcomeMessage.displayName = \"ThreadWelcomeMessage\";\n\nconst ThreadWelcomeSuggestionContainer = withDefaults(\"div\", {\n className: \"aui-thread-welcome-suggestion-container\",\n});\n\nconst ThreadWelcomeSuggestionStyled = withDefaults(ThreadPrimitive.Suggestion, {\n className: \"aui-thread-welcome-suggestion\",\n});\n\nexport type ThreadWelcomeSuggestionProps = {\n suggestion: SuggestionConfig;\n};\n\nconst ThreadWelcomeSuggestion: FC<ThreadWelcomeSuggestionProps> = ({\n suggestion: { text, prompt },\n}) => {\n return (\n <ThreadWelcomeSuggestionStyled\n prompt={prompt}\n method=\"replace\"\n autoSend\n >\n <span className=\"aui-thread-welcome-suggestion-text\">{text ?? prompt}</span>\n </ThreadWelcomeSuggestionStyled>\n );\n};\n\nconst ThreadWelcomeSuggestions: FC = () => {\n const { welcome: { suggestions } = {} } = useThreadConfig();\n return (\n <ThreadWelcomeSuggestionContainer>\n {suggestions?.map((suggestion, idx) => {\n const key = `${suggestion.prompt}-${idx}`;\n return <ThreadWelcomeSuggestion key={key} suggestion={suggestion} />;\n })}\n </ThreadWelcomeSuggestionContainer>\n );\n};\n\nThreadWelcomeSuggestions.displayName = \"ThreadWelcomeSuggestions\";\n\nconst exports = {\n Root: ThreadWelcomeRoot,\n Center: ThreadWelcomeCenter,\n Avatar: ThreadWelcomeAvatar,\n Message: ThreadWelcomeMessage,\n Suggestions: ThreadWelcomeSuggestions,\n Suggestion: ThreadWelcomeSuggestion,\n};\n\nexport default Object.assign(ThreadWelcome, exports) as typeof ThreadWelcome &\n typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\n\nimport BranchPicker from \"./branch-picker\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport UserActionBar from \"./user-action-bar\";\nimport ContentPart from \"./content-part\";\nimport { MessagePrimitive, MessagePrimitiveContentProps } from \"../primitives\";\n\nconst UserMessage: FC = () => {\n return (\n <UserMessageRoot>\n <UserActionBar />\n <UserMessageContent />\n <BranchPicker />\n </UserMessageRoot>\n );\n};\n\nUserMessage.displayName = \"UserMessage\";\n\nconst UserMessageRoot = withDefaults(MessagePrimitive.Root, {\n className: \"aui-user-message-root\",\n});\n\nUserMessageRoot.displayName = \"UserMessageRoot\";\n\nconst UserMessageContentWrapper = withDefaults(\"div\", {\n className: \"aui-user-message-content\",\n});\n\nexport type UserMessageContentProps = MessagePrimitiveContentProps &\n ComponentPropsWithoutRef<\"div\">;\n\nconst UserMessageContent = forwardRef<HTMLDivElement, UserMessageContentProps>(\n ({ components, ...props }, ref) => {\n return (\n <UserMessageContentWrapper {...props} ref={ref}>\n <MessagePrimitive.Content\n components={{\n ...components,\n Text: components?.Text ?? ContentPart.Text,\n }}\n />\n </UserMessageContentWrapper>\n );\n },\n);\n\nUserMessageContent.displayName = \"UserMessageContent\";\n\nconst exports = {\n Root: UserMessageRoot,\n Content: UserMessageContent,\n};\n\nexport default Object.assign(UserMessage, exports) as typeof UserMessage &\n typeof exports;\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\nimport { PencilIcon } from \"lucide-react\";\n\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { useThreadContext } from \"../context\";\nimport { ActionBarPrimitive } from \"../primitives\";\n\nconst useAllowEdit = (ensureCapability = false) => {\n const { userMessage: { allowEdit = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const editSupported = useThread((t) => t.capabilities.edit);\n return allowEdit && (!ensureCapability || editSupported);\n};\n\nconst UserActionBar: FC = () => {\n const allowEdit = useAllowEdit(true);\n if (!allowEdit) return null;\n return (\n <UserActionBarRoot hideWhenRunning autohide=\"not-last\">\n <UserActionBarEdit />\n </UserActionBarRoot>\n );\n};\n\nUserActionBar.displayName = \"UserActionBar\";\n\nconst UserActionBarRoot = withDefaults(ActionBarPrimitive.Root, {\n className: \"aui-user-action-bar-root\",\n});\n\nUserActionBarRoot.displayName = \"UserActionBarRoot\";\n\nconst UserActionBarEdit = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { userMessage: { edit: { tooltip = \"Edit\" } = {} } = {} } = {},\n } = useThreadConfig();\n const allowEdit = useAllowEdit();\n if (!allowEdit) return null;\n return (\n <ActionBarPrimitive.Edit asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <PencilIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.Edit>\n );\n});\n\nUserActionBarEdit.displayName = \"UserActionBarEdit\";\n\nconst exports = {\n Root: UserActionBarRoot,\n Edit: UserActionBarEdit,\n};\n\nexport default Object.assign(UserActionBar, exports) as typeof UserActionBar &\n typeof exports;\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\n\nimport { Button, ButtonProps } from \"./base/button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { ComposerPrimitive } from \"../primitives\";\n\nconst EditComposer: FC = () => {\n return (\n <EditComposerRoot>\n <EditComposerInput />\n\n <EditComposerFooter>\n <EditComposerCancel />\n <EditComposerSend />\n </EditComposerFooter>\n </EditComposerRoot>\n );\n};\n\nEditComposer.displayName = \"EditComposer\";\n\nconst EditComposerRoot = withDefaults(ComposerPrimitive.Root, {\n className: \"aui-edit-composer-root\",\n});\n\nEditComposerRoot.displayName = \"EditComposerRoot\";\n\nconst EditComposerInput = withDefaults(ComposerPrimitive.Input, {\n className: \"aui-edit-composer-input\",\n});\n\nEditComposerInput.displayName = \"EditComposerInput\";\n\nconst EditComposerFooter = withDefaults(\"div\", {\n className: \"aui-edit-composer-footer\",\n});\n\nEditComposerFooter.displayName = \"EditComposerFooter\";\n\nconst EditComposerCancel = forwardRef<HTMLButtonElement, Partial<ButtonProps>>(\n (props, ref) => {\n const {\n strings: {\n editComposer: { cancel: { label = \"Cancel\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Cancel asChild>\n <Button variant=\"ghost\" {...props} ref={ref}>\n {props.children ?? label}\n </Button>\n </ComposerPrimitive.Cancel>\n );\n },\n);\n\nEditComposerCancel.displayName = \"EditComposerCancel\";\n\nconst EditComposerSend = forwardRef<HTMLButtonElement, Partial<ButtonProps>>(\n (props, ref) => {\n const {\n strings: { editComposer: { send: { label = \"Send\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Send asChild>\n <Button {...props} ref={ref}>\n {props.children ?? label}\n </Button>\n </ComposerPrimitive.Send>\n );\n },\n);\n\nEditComposerSend.displayName = \"EditComposerSend\";\n\nconst exports = {\n Root: EditComposerRoot,\n Input: EditComposerInput,\n Footer: EditComposerFooter,\n Cancel: EditComposerCancel,\n Send: EditComposerSend,\n};\n\nexport default Object.assign(EditComposer, exports) as typeof EditComposer &\n typeof exports;\n"]}
|
1
|
+
{"version":3,"sources":["/home/runner/work/assistant-ui/assistant-ui/packages/react/dist/index.js","../src/context/providers/AssistantRuntimeProvider.tsx","../src/context/providers/AssistantProvider.tsx","../src/context/react/AssistantContext.ts","../src/context/stores/AssistantModelConfig.ts","../src/utils/ProxyConfigProvider.ts","../src/context/stores/AssistantToolUIs.ts","../src/context/providers/ThreadProvider.tsx","../src/context/react/ThreadContext.ts","../src/context/stores/Composer.ts","../src/context/stores/Thread.ts","../src/context/stores/ThreadViewport.tsx","../src/context/stores/ThreadActions.ts","../src/context/stores/ThreadMessages.ts","../src/context/stores/ThreadRuntime.tsx","../src/runtimes/core/subscribeToMainThread.ts","../src/runtimes/local/useLocalRuntime.tsx","../src/runtimes/core/BaseAssistantRuntime.tsx","../src/internal.ts","../src/utils/idUtils.tsx","../src/runtimes/edge/converters/fromCoreMessage.ts","../src/runtimes/utils/MessageRepository.tsx","../src/utils/smooth/useSmooth.tsx","../src/utils/smooth/SmoothContext.tsx","../src/ui/base/tooltip-icon-button.tsx","../src/ui/base/tooltip.tsx","../src/ui/utils/withDefaults.tsx","../src/ui/base/button.tsx","../src/runtimes/edge/converters/fromLanguageModelMessages.ts","../src/runtimes/edge/converters/fromLanguageModelTools.ts","../src/runtimes/edge/streams/utils/chunkByLineStream.ts","../src/runtimes/edge/streams/utils/streamPartDecoderStream.ts","../src/runtimes/edge/streams/utils/index.ts","../src/runtimes/edge/useEdgeRuntime.ts","../src/runtimes/edge/streams/assistantDecoderStream.ts","../src/runtimes/edge/EdgeChatAdapter.ts","../src/runtimes/local/shouldContinue.tsx","../src/runtimes/local/LocalThreadRuntime.tsx","../src/runtimes/local/LocalRuntime.tsx","../src/runtimes/external-store/getExternalStoreMessage.tsx","../src/runtimes/external-store/ThreadMessageConverter.ts","../src/runtimes/external-store/auto-status.tsx","../src/runtimes/external-store/ThreadMessageLike.tsx","../src/utils/getThreadMessageText.tsx","../src/runtimes/external-store/ExternalStoreThreadRuntime.tsx","../src/runtimes/external-store/ExternalStoreRuntime.tsx","../src/runtimes/external-store/useExternalStoreRuntime.tsx","../src/runtimes/external-store/external-message-converter.tsx","../src/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.ts","../src/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.ts","../src/runtimes/speech/WebSpeechSynthesisAdapter.ts","../src/context/stores/AssistantActions.tsx","../src/context/stores/AssistantRuntime.tsx","../src/context/react/ComposerContext.ts","../src/context/react/MessageContext.ts","../src/context/react/ContentPartContext.ts","../src/hooks/useAppendMessage.tsx","../src/hooks/useSwitchToNewThread.tsx","../src/model-config/useAssistantTool.tsx","../src/model-config/makeAssistantTool.tsx","../src/model-config/useAssistantToolUI.tsx","../src/model-config/makeAssistantToolUI.tsx","../src/model-config/useAssistantInstructions.tsx","../src/primitive-hooks/actionBar/useActionBarCopy.tsx","../src/utils/combined/useCombinedStore.ts","../src/utils/combined/createCombinedStore.ts","../src/primitive-hooks/actionBar/useActionBarEdit.tsx","../src/primitive-hooks/actionBar/useActionBarReload.tsx","../src/primitive-hooks/actionBar/useActionBarSpeak.tsx","../src/primitive-hooks/actionBar/useActionBarStopSpeaking.tsx","../src/primitive-hooks/branchPicker/useBranchPickerCount.tsx","../src/primitive-hooks/branchPicker/useBranchPickerNext.tsx","../src/primitive-hooks/branchPicker/useBranchPickerNumber.tsx","../src/primitive-hooks/branchPicker/useBranchPickerPrevious.tsx","../src/primitive-hooks/composer/useComposerCancel.tsx","../src/primitive-hooks/composer/useComposerIf.tsx","../src/primitive-hooks/composer/useComposerSend.tsx","../src/primitive-hooks/contentPart/useContentPartDisplay.tsx","../src/primitive-hooks/contentPart/useContentPartImage.tsx","../src/primitive-hooks/contentPart/useContentPartText.tsx","../src/primitive-hooks/message/useMessageIf.tsx","../src/primitive-hooks/thread/useThreadIf.tsx","../src/primitive-hooks/thread/useThreadEmpty.tsx","../src/primitive-hooks/thread/useThreadScrollToBottom.tsx","../src/primitive-hooks/thread/useThreadSuggestion.tsx","../src/primitives/actionBar/index.ts","../src/primitives/actionBar/ActionBarRoot.tsx","../src/primitives/actionBar/useActionBarFloatStatus.tsx","../src/utils/createActionButton.tsx","../src/primitives/actionBar/ActionBarCopy.tsx","../src/primitives/actionBar/ActionBarReload.tsx","../src/primitives/actionBar/ActionBarEdit.tsx","../src/primitives/actionBar/ActionBarSpeak.tsx","../src/primitives/actionBar/ActionBarStopSpeaking.tsx","../src/primitives/assistantModal/index.ts","../src/primitives/assistantModal/AssistantModalRoot.tsx","../src/utils/hooks/useOnComposerFocus.tsx","../src/primitives/assistantModal/scope.tsx","../src/primitives/assistantModal/AssistantModalTrigger.tsx","../src/primitives/assistantModal/AssistantModalContent.tsx","../src/primitives/assistantModal/AssistantModalAnchor.tsx","../src/primitives/branchPicker/index.ts","../src/primitives/branchPicker/BranchPickerNext.tsx","../src/primitives/branchPicker/BranchPickerPrevious.tsx","../src/primitives/branchPicker/BranchPickerCount.tsx","../src/primitives/branchPicker/BranchPickerNumber.tsx","../src/primitives/branchPicker/BranchPickerRoot.tsx","../src/primitives/message/index.ts","../src/primitives/message/MessageRoot.tsx","../src/utils/hooks/useManagedRef.ts","../src/primitives/message/MessageIf.tsx","../src/primitives/message/MessageContent.tsx","../src/context/providers/ContentPartProvider.tsx","../src/primitives/contentPart/ContentPartText.tsx","../src/primitives/contentPart/ContentPartImage.tsx","../src/primitives/contentPart/ContentPartDisplay.tsx","../src/primitives/contentPart/ContentPartInProgress.tsx","../src/primitives/message/MessageInProgress.tsx","../src/primitives/composer/index.ts","../src/primitives/composer/ComposerRoot.tsx","../src/primitives/composer/ComposerInput.tsx","../src/primitives/composer/ComposerSend.tsx","../src/primitives/composer/ComposerCancel.tsx","../src/primitives/composer/ComposerIf.tsx","../src/primitives/contentPart/index.ts","../src/primitives/thread/index.ts","../src/primitives/thread/ThreadRoot.tsx","../src/primitives/thread/ThreadEmpty.tsx","../src/primitives/thread/ThreadIf.tsx","../src/primitives/thread/ThreadViewport.tsx","../src/primitive-hooks/thread/useThreadViewportAutoScroll.tsx","../src/utils/hooks/useOnResizeContent.tsx","../src/utils/hooks/useOnScrollToBottom.tsx","../src/primitives/thread/ThreadMessages.tsx","../src/context/providers/MessageProvider.tsx","../src/context/stores/EditComposer.ts","../src/context/stores/MessageUtils.ts","../src/primitives/thread/ThreadScrollToBottom.tsx","../src/primitives/thread/ThreadSuggestion.tsx","../src/ui/thread-config.tsx","../src/ui/assistant-action-bar.tsx","../src/ui/assistant-message.tsx","../src/ui/branch-picker.tsx","../src/ui/base/avatar.tsx","../src/ui/content-part.tsx","../src/ui/assistant-modal.tsx","../src/ui/thread.tsx","../src/ui/composer.tsx","../src/ui/base/CircleStopIcon.tsx","../src/ui/thread-welcome.tsx","../src/ui/user-message.tsx","../src/ui/user-action-bar.tsx","../src/ui/edit-composer.tsx"],"names":["create","createContext","useContext","runtime","message","useSmoothStatus","text","useState","forwardRef","jsx","useMemo","jsxs","useInsertionEffect","useEffect","useCallback","Primitive","composeEventHandlers","PopoverPrimitive","useCallbackRef","Fragment","useContentPartContext","memo","useComposedRefs","useRef","useEscapeKeydown","useMessageContext","UserMessage","BranchPickerPrevious","classNames","exports"],"mappings":"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","file":"/home/runner/work/assistant-ui/assistant-ui/packages/react/dist/index.js","sourcesContent":[null,"import type { FC, PropsWithChildren } from \"react\";\nimport { memo } from \"react\";\nimport type { AssistantRuntime } from \"../../runtimes/core/AssistantRuntime\";\nimport { AssistantProvider } from \"./AssistantProvider\";\n\ntype AssistantRuntimeProviderProps = {\n runtime: AssistantRuntime;\n};\n\nconst AssistantRuntimeProviderImpl: FC<\n PropsWithChildren<AssistantRuntimeProviderProps>\n> = ({ children, runtime }) => {\n return <AssistantProvider runtime={runtime}>{children}</AssistantProvider>;\n};\n\nexport const AssistantRuntimeProvider = memo(AssistantRuntimeProviderImpl);\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport { useEffect, useInsertionEffect, useRef, useState } from \"react\";\nimport type { AssistantRuntime } from \"../../runtimes\";\nimport { AssistantContext } from \"../react/AssistantContext\";\nimport { makeAssistantModelConfigStore } from \"../stores/AssistantModelConfig\";\nimport { makeAssistantToolUIsStore } from \"../stores/AssistantToolUIs\";\nimport { ThreadProvider } from \"./ThreadProvider\";\nimport { makeAssistantActionsStore } from \"../stores/AssistantActions\";\nimport {\n AssistantRuntimeStore,\n makeAssistantRuntimeStore,\n} from \"../stores/AssistantRuntime\";\nimport { StoreApi } from \"zustand\";\n\ntype AssistantProviderProps = {\n runtime: AssistantRuntime;\n};\n\nexport const AssistantProvider: FC<\n PropsWithChildren<AssistantProviderProps>\n> = ({ children, runtime }) => {\n const runtimeRef = useRef(runtime);\n useInsertionEffect(() => {\n runtimeRef.current = runtime;\n });\n\n const [context] = useState(() => {\n const useAssistantRuntime = makeAssistantRuntimeStore(runtime);\n const useModelConfig = makeAssistantModelConfigStore();\n const useToolUIs = makeAssistantToolUIsStore();\n const useAssistantActions = makeAssistantActionsStore(runtimeRef);\n\n return {\n useModelConfig,\n useToolUIs,\n useAssistantRuntime,\n useAssistantActions,\n };\n });\n\n const getModelConfig = context.useModelConfig();\n useEffect(() => {\n return runtime.registerModelConfigProvider(getModelConfig);\n }, [runtime, getModelConfig]);\n\n useEffect(\n () =>\n (\n context.useAssistantRuntime as unknown as StoreApi<AssistantRuntimeStore>\n ).setState(runtime, true),\n [runtime, context],\n );\n\n return (\n <AssistantContext.Provider value={context}>\n <ThreadProvider provider={runtime}>{children}</ThreadProvider>\n </AssistantContext.Provider>\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { AssistantModelConfigState } from \"../stores/AssistantModelConfig\";\nimport type { AssistantToolUIsState } from \"../stores/AssistantToolUIs\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { AssistantActionsState } from \"../stores/AssistantActions\";\nimport { AssistantRuntime } from \"../../runtimes\";\n\nexport type AssistantContextValue = {\n useModelConfig: ReadonlyStore<AssistantModelConfigState>;\n useToolUIs: ReadonlyStore<AssistantToolUIsState>;\n useAssistantRuntime: ReadonlyStore<AssistantRuntime>;\n useAssistantActions: ReadonlyStore<AssistantActionsState>;\n};\n\nexport const AssistantContext = createContext<AssistantContextValue | null>(\n null,\n);\n\nexport function useAssistantContext(): AssistantContextValue;\nexport function useAssistantContext(options: {\n optional: true;\n}): AssistantContextValue | null;\nexport function useAssistantContext(options?: { optional: true }) {\n const context = useContext(AssistantContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within an AssistantRuntimeProvider.\",\n );\n return context;\n}\n","\"use client\";\n\nimport { create } from \"zustand\";\nimport type { ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport { ProxyConfigProvider } from \"../../utils/ProxyConfigProvider\";\n\nexport type AssistantModelConfigState = Readonly<\n ModelConfigProvider & {\n registerModelConfigProvider: (provider: ModelConfigProvider) => () => void;\n }\n>;\n\nexport const makeAssistantModelConfigStore = () =>\n create<AssistantModelConfigState>(() => {\n const proxy = new ProxyConfigProvider();\n\n return Object.freeze({\n getModelConfig: () => {\n return proxy.getModelConfig();\n },\n registerModelConfigProvider: (provider: ModelConfigProvider) => {\n return proxy.registerModelConfigProvider(provider);\n },\n }) satisfies AssistantModelConfigState;\n });\n","\"use client\";\nimport {\n type ModelConfigProvider,\n mergeModelConfigs,\n} from \"../types/ModelConfigTypes\";\n\nexport class ProxyConfigProvider implements ModelConfigProvider {\n private _providers = new Set<ModelConfigProvider>();\n\n getModelConfig() {\n return mergeModelConfigs(this._providers);\n }\n\n registerModelConfigProvider(provider: ModelConfigProvider) {\n this._providers.add(provider);\n return () => {\n this._providers.delete(provider);\n };\n }\n}\n","\"use client\";\n\nimport { create } from \"zustand\";\nimport type { ToolCallContentPartComponent } from \"../../types/ContentPartComponentTypes\";\n\nexport type AssistantToolUIsState = Readonly<{\n getToolUI: (toolName: string) => ToolCallContentPartComponent | null;\n setToolUI: (\n toolName: string,\n render: ToolCallContentPartComponent,\n ) => () => void;\n}>;\n\nexport const makeAssistantToolUIsStore = () =>\n create<AssistantToolUIsState>((set) => {\n const renderers = new Map<string, ToolCallContentPartComponent[]>();\n\n return Object.freeze({\n getToolUI: (name) => {\n const arr = renderers.get(name);\n const last = arr?.at(-1);\n if (last) return last;\n return null;\n },\n setToolUI: (name, render) => {\n let arr = renderers.get(name);\n if (!arr) {\n arr = [];\n renderers.set(name, arr);\n }\n arr.push(render);\n set({}); // notify the store listeners\n\n return () => {\n const index = arr.indexOf(render);\n if (index !== -1) {\n arr.splice(index, 1);\n }\n if (index === arr.length) {\n set({}); // notify the store listeners\n }\n };\n },\n }) satisfies AssistantToolUIsState;\n });\n","import type { FC, PropsWithChildren } from \"react\";\nimport { useEffect, useInsertionEffect, useState } from \"react\";\nimport type { ReactThreadRuntime } from \"../../runtimes/core/ReactThreadRuntime\";\nimport type { ThreadContextValue } from \"../react/ThreadContext\";\nimport { ThreadContext } from \"../react/ThreadContext\";\nimport { ComposerState, makeComposerStore } from \"../stores/Composer\";\nimport {\n ThreadState,\n getThreadStateFromRuntime,\n makeThreadStore,\n} from \"../stores/Thread\";\nimport { makeThreadViewportStore } from \"../stores/ThreadViewport\";\nimport { makeThreadActionStore } from \"../stores/ThreadActions\";\nimport { StoreApi } from \"zustand\";\nimport {\n ThreadMessagesState,\n makeThreadMessagesStore,\n} from \"../stores/ThreadMessages\";\nimport { ThreadRuntimeWithSubscribe } from \"../../runtimes/core/AssistantRuntime\";\nimport {\n makeThreadRuntimeStore,\n ThreadRuntimeStore,\n} from \"../stores/ThreadRuntime\";\nimport { subscribeToMainThread } from \"../../runtimes\";\n\ntype ThreadProviderProps = {\n provider: ThreadRuntimeWithSubscribe;\n};\n\nexport const ThreadProvider: FC<PropsWithChildren<ThreadProviderProps>> = ({\n children,\n provider,\n}) => {\n const [context] = useState<ThreadContextValue>(() => {\n const useThreadRuntime = makeThreadRuntimeStore(provider.thread);\n const useThread = makeThreadStore(useThreadRuntime);\n const useThreadMessages = makeThreadMessagesStore(useThreadRuntime);\n const useThreadActions = makeThreadActionStore(useThreadRuntime);\n const useViewport = makeThreadViewportStore();\n const useComposer = makeComposerStore(useThreadRuntime);\n\n return {\n useThread,\n useThreadRuntime,\n useThreadMessages,\n useThreadActions,\n useComposer,\n useViewport,\n };\n });\n\n // TODO it might make sense to move this into the make* functions\n useEffect(() => {\n const onThreadUpdate = () => {\n const thread = provider.thread;\n\n const oldState = context.useThread.getState();\n const state = getThreadStateFromRuntime(thread);\n if (\n oldState.threadId !== state.threadId ||\n oldState.isDisabled !== state.isDisabled ||\n oldState.isRunning !== state.isRunning ||\n // TODO ensure capabilities is memoized\n oldState.capabilities !== state.capabilities\n ) {\n (context.useThread as unknown as StoreApi<ThreadState>).setState(\n state,\n true,\n );\n }\n\n if (thread.messages !== context.useThreadMessages.getState()) {\n (\n context.useThreadMessages as unknown as StoreApi<ThreadMessagesState>\n ).setState(thread.messages, true);\n }\n\n const composerState = context.useComposer.getState();\n if (\n thread.composer.text !== composerState.text ||\n state.capabilities.cancel !== composerState.canCancel\n ) {\n (context.useComposer as unknown as StoreApi<ComposerState>).setState({\n text: thread.composer.text,\n canCancel: state.capabilities.cancel,\n });\n }\n };\n\n onThreadUpdate();\n return subscribeToMainThread(provider, onThreadUpdate);\n }, [provider, context]);\n\n useInsertionEffect(\n () =>\n provider.subscribe(() => {\n (\n context.useThreadRuntime as unknown as StoreApi<ThreadRuntimeStore>\n ).setState(provider.thread, true);\n }),\n [provider, context],\n );\n\n // subscribe to thread updates\n const Synchronizer = context.useThreadRuntime(\n (t) => (t as ReactThreadRuntime).unstable_synchronizer,\n );\n\n return (\n <ThreadContext.Provider value={context}>\n {Synchronizer && <Synchronizer />}\n {children}\n </ThreadContext.Provider>\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { ComposerState } from \"../stores/Composer\";\nimport type { ThreadState } from \"../stores/Thread\";\nimport type { ThreadViewportState } from \"../stores/ThreadViewport\";\nimport { ThreadActionsState } from \"../stores/ThreadActions\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadMessagesState } from \"../stores/ThreadMessages\";\nimport { ThreadRuntimeStore } from \"../stores/ThreadRuntime\";\n\nexport type ThreadContextValue = {\n useThread: ReadonlyStore<ThreadState>;\n useThreadRuntime: ReadonlyStore<ThreadRuntimeStore>;\n useThreadMessages: ReadonlyStore<ThreadMessagesState>;\n useThreadActions: ReadonlyStore<ThreadActionsState>;\n useComposer: ReadonlyStore<ComposerState>;\n useViewport: ReadonlyStore<ThreadViewportState>;\n};\n\nexport const ThreadContext = createContext<ThreadContextValue | null>(null);\n\nexport function useThreadContext(): ThreadContextValue;\nexport function useThreadContext(options: {\n optional: true;\n}): ThreadContextValue | null;\nexport function useThreadContext(options?: { optional: true }) {\n const context = useContext(ThreadContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within an AssistantRuntimeProvider.\",\n );\n return context;\n}\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { Unsubscribe } from \"../../types/Unsubscribe\";\nimport { ThreadContextValue } from \"../react\";\n\nexport type ComposerState = Readonly<{\n /** @deprecated Use `text` instead. */\n value: string;\n /** @deprecated Use `setText` instead. */\n setValue: (value: string) => void;\n\n text: string;\n setText: (value: string) => void;\n\n canCancel: boolean;\n isEditing: true;\n\n send: () => void;\n cancel: () => void;\n focus: () => void;\n onFocus: (listener: () => void) => Unsubscribe;\n}>;\n\nexport const makeComposerStore = (\n useThreadRuntime: ThreadContextValue[\"useThreadRuntime\"],\n): ReadonlyStore<ComposerState> => {\n const focusListeners = new Set<() => void>();\n return create<ComposerState>()((_, get) => {\n const runtime = useThreadRuntime.getState();\n return {\n get value() {\n return get().text;\n },\n setValue(value) {\n get().setText(value);\n },\n\n text: runtime.composer.text,\n setText: (value) => {\n useThreadRuntime.getState().composer.setText(value);\n },\n\n canCancel: runtime.capabilities.cancel,\n isEditing: true,\n\n send: () => {\n const runtime = useThreadRuntime.getState();\n const text = runtime.composer.text;\n runtime.composer.setText(\"\");\n\n runtime.append({\n parentId: runtime.messages.at(-1)?.id ?? null,\n role: \"user\",\n content: [{ type: \"text\", text }],\n });\n },\n cancel: () => {\n useThreadRuntime.getState().cancelRun();\n },\n focus: () => {\n for (const listener of focusListeners) {\n listener();\n }\n },\n onFocus: (listener) => {\n focusListeners.add(listener);\n return () => {\n focusListeners.delete(listener);\n };\n },\n };\n });\n};\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\n\nexport type ThreadState = Readonly<{\n capabilities: Readonly<RuntimeCapabilities>;\n threadId: string;\n isRunning: boolean;\n isDisabled: boolean;\n}>;\n\nexport type RuntimeCapabilities = {\n switchToBranch: boolean;\n edit: boolean;\n reload: boolean;\n cancel: boolean;\n unstable_copy: boolean;\n speak: boolean;\n};\n\nexport const getThreadStateFromRuntime = (\n runtime: ThreadRuntimeStore,\n): ThreadState => {\n const lastMessage = runtime.messages.at(-1);\n return Object.freeze({\n threadId: runtime.threadId,\n capabilities: runtime.capabilities,\n isDisabled: runtime.isDisabled,\n isRunning:\n lastMessage?.role !== \"assistant\"\n ? false\n : lastMessage.status.type === \"running\",\n });\n};\n\nexport const makeThreadStore = (\n runtimeRef: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n const runtime = runtimeRef.getState();\n return create<ThreadState>(() => getThreadStateFromRuntime(runtime));\n};\n","\"use client\";\nimport { create } from \"zustand\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\n\nexport type ThreadViewportState = Readonly<{\n isAtBottom: boolean;\n scrollToBottom: () => void;\n onScrollToBottom: (callback: () => void) => Unsubscribe;\n}>;\n\nexport const makeThreadViewportStore = () => {\n const scrollToBottomListeners = new Set<() => void>();\n\n return create<ThreadViewportState>(() => ({\n isAtBottom: true,\n scrollToBottom: () => {\n for (const listener of scrollToBottomListeners) {\n listener();\n }\n },\n onScrollToBottom: (callback) => {\n scrollToBottomListeners.add(callback);\n return () => {\n scrollToBottomListeners.delete(callback);\n };\n },\n }));\n};\n","import { create } from \"zustand\";\nimport type { AppendMessage } from \"../../types/AssistantTypes\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\nimport { SpeechSynthesisAdapter } from \"../../runtimes/speech/SpeechAdapterTypes\";\n\nexport type AddToolResultOptions = {\n messageId: string;\n toolName: string;\n toolCallId: string;\n result: any;\n};\n\nexport type ThreadActionsState = Readonly<{\n getBranches: (messageId: string) => readonly string[];\n switchToBranch: (branchId: string) => void;\n\n append: (message: AppendMessage) => void;\n startRun: (parentId: string | null) => void;\n cancelRun: () => void;\n\n addToolResult: (options: AddToolResultOptions) => void;\n\n speak: (messageId: string) => SpeechSynthesisAdapter.Utterance;\n}>;\n\nexport const makeThreadActionStore = (\n runtimeStore: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n return create<ThreadActionsState>(() =>\n Object.freeze({\n getBranches: (messageId) =>\n runtimeStore.getState().getBranches(messageId),\n switchToBranch: (branchId) =>\n runtimeStore.getState().switchToBranch(branchId),\n\n startRun: (parentId) => runtimeStore.getState().startRun(parentId),\n append: (message) => runtimeStore.getState().append(message),\n cancelRun: () => runtimeStore.getState().cancelRun(),\n\n addToolResult: (options) =>\n runtimeStore.getState().addToolResult(options),\n\n speak: (messageId) => runtimeStore.getState().speak(messageId),\n }),\n );\n};\n","import { create } from \"zustand\";\nimport type { ThreadMessage } from \"../../types/AssistantTypes\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { ThreadRuntimeStore } from \"./ThreadRuntime\";\n\nexport type ThreadMessagesState = readonly ThreadMessage[];\n\nexport const makeThreadMessagesStore = (\n runtimeRef: ReadonlyStore<ThreadRuntimeStore>,\n) => {\n return create<ThreadMessagesState>(() => runtimeRef.getState().messages);\n};\n","import { create } from \"zustand\";\nimport { ThreadRuntime } from \"../../runtimes\";\n\nexport type ThreadRuntimeStore = ThreadRuntime;\n\nexport const makeThreadRuntimeStore = (runtime: ThreadRuntime) => {\n return create<ThreadRuntimeStore>(() => runtime);\n};\n","import { Unsubscribe } from \"../../types\";\nimport { ThreadRuntimeWithSubscribe } from \"./AssistantRuntime\";\n\nexport const subscribeToMainThread = (\n runtime: ThreadRuntimeWithSubscribe,\n callback: () => void,\n) => {\n let first = true;\n let cleanup: Unsubscribe | undefined;\n const inner = () => {\n cleanup?.();\n cleanup = runtime.thread.subscribe(callback);\n\n if (!first) {\n callback();\n }\n first = false;\n };\n\n const unsubscribe = runtime.subscribe(inner);\n inner();\n\n return () => {\n unsubscribe();\n cleanup?.();\n };\n};\n","\"use client\";\n\nimport { useInsertionEffect, useState } from \"react\";\nimport type { ChatModelAdapter } from \"./ChatModelAdapter\";\nimport { LocalRuntime } from \"./LocalRuntime\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\n\nexport const useLocalRuntime = (\n adapter: ChatModelAdapter,\n options: LocalRuntimeOptions = {},\n) => {\n const [runtime] = useState(() => new LocalRuntime(adapter, options));\n\n useInsertionEffect(() => {\n runtime.adapter = adapter;\n runtime.options = options;\n });\n\n return runtime;\n};\n","import { type ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\nimport type { AssistantRuntime } from \"./AssistantRuntime\";\nimport { ReactThreadRuntime } from \"./ReactThreadRuntime\";\n\nexport abstract class BaseAssistantRuntime<\n TThreadRuntime extends ReactThreadRuntime,\n> implements AssistantRuntime\n{\n constructor(private _thread: TThreadRuntime) {\n this._thread = _thread;\n }\n\n get thread() {\n return this._thread;\n }\n\n set thread(thread: TThreadRuntime) {\n this._thread = thread;\n this.subscriptionHandler();\n }\n\n public abstract registerModelConfigProvider(\n provider: ModelConfigProvider,\n ): Unsubscribe;\n public abstract switchToThread(threadId: string | null): void;\n\n private _subscriptions = new Set<() => void>();\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n private subscriptionHandler = () => {\n for (const callback of this._subscriptions) callback();\n };\n}\n","export { ProxyConfigProvider } from \"./utils/ProxyConfigProvider\";\nexport { MessageRepository } from \"./runtimes/utils/MessageRepository\";\nexport { BaseAssistantRuntime } from \"./runtimes/core/BaseAssistantRuntime\";\nexport * from \"./utils/smooth\";\nexport { TooltipIconButton } from \"./ui/base/tooltip-icon-button\";\nexport { generateId } from \"./utils/idUtils\";\n","import { customAlphabet } from \"nanoid/non-secure\";\n\nexport const generateId = customAlphabet(\n \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\",\n 7,\n);\n\nconst optimisticPrefix = \"__optimistic__\";\nexport const generateOptimisticId = () => `${optimisticPrefix}${generateId()}`;\nexport const isOptimisticId = (id: string) => id.startsWith(optimisticPrefix);\n","import { generateId } from \"../../../internal\";\nimport {\n ThreadMessage,\n CoreMessage,\n ToolCallContentPart,\n MessageStatus,\n} from \"../../../types\";\n\nexport const fromCoreMessages = (\n message: readonly CoreMessage[],\n): ThreadMessage[] => {\n return message.map((message) => fromCoreMessage(message));\n};\n\nexport const fromCoreMessage = (\n message: CoreMessage,\n {\n id = generateId(),\n status = { type: \"complete\", reason: \"unknown\" } as MessageStatus,\n } = {},\n): ThreadMessage => {\n const commonProps = {\n id,\n createdAt: new Date(),\n };\n\n const role = message.role;\n switch (role) {\n case \"assistant\":\n return {\n ...commonProps,\n role,\n content: message.content.map((part) => {\n if (part.type === \"tool-call\") {\n return {\n ...part,\n argsText: JSON.stringify(part.args),\n } satisfies ToolCallContentPart;\n }\n return part;\n }),\n status,\n } satisfies ThreadMessage;\n\n case \"user\":\n return {\n ...commonProps,\n role,\n content: message.content,\n } satisfies ThreadMessage;\n\n case \"system\":\n return {\n ...commonProps,\n role,\n content: message.content,\n } satisfies ThreadMessage;\n\n default: {\n const unsupportedRole: never = role;\n throw new Error(`Unknown message role: ${unsupportedRole}`);\n }\n }\n};\n","import type { CoreMessage, ThreadMessage } from \"../../types/AssistantTypes\";\nimport { generateOptimisticId } from \"../../utils/idUtils\";\nimport { fromCoreMessage } from \"../edge/converters/fromCoreMessage\";\n\ntype RepositoryParent = {\n children: string[];\n next: RepositoryMessage | null;\n};\n\ntype RepositoryMessage = RepositoryParent & {\n prev: RepositoryMessage | null;\n current: ThreadMessage;\n level: number;\n};\n\nexport interface ExportedMessageRepository {\n headId?: string | null;\n messages: Array<{\n message: ThreadMessage;\n parentId: string | null;\n }>;\n}\n\nconst findHead = (\n message: RepositoryMessage | RepositoryParent,\n): RepositoryMessage | null => {\n if (message.next) return findHead(message.next);\n if (\"current\" in message) return message;\n return null;\n};\n\nexport class MessageRepository {\n private messages = new Map<string, RepositoryMessage>(); // message_id -> item\n private head: RepositoryMessage | null = null;\n private root: RepositoryParent = {\n children: [],\n next: null,\n };\n\n private performOp(\n newParent: RepositoryMessage | null,\n child: RepositoryMessage,\n operation: \"cut\" | \"link\" | \"relink\",\n ) {\n const parentOrRoot = child.prev ?? this.root;\n const newParentOrRoot = newParent ?? this.root;\n\n if (operation === \"relink\" && parentOrRoot === newParentOrRoot) return;\n\n // cut\n if (operation !== \"link\") {\n // remove from parentOrRoot.children\n parentOrRoot.children = parentOrRoot.children.filter(\n (m) => m !== child.current.id,\n );\n\n // update parentOrRoot.next\n if (parentOrRoot.next === child) {\n const fallbackId = parentOrRoot.children.at(-1);\n const fallback = fallbackId ? this.messages.get(fallbackId) : null;\n if (fallback === undefined) {\n throw new Error(\n \"MessageRepository(performOp/cut): Fallback sibling message not found. This is likely an internal bug in assistant-ui.\",\n );\n }\n parentOrRoot.next = fallback;\n }\n }\n\n // link\n if (operation !== \"cut\") {\n // ensure the child is not part of parent tree\n for (\n let current: RepositoryMessage | null = newParent;\n current;\n current = current.prev\n ) {\n if (current.current.id === child.current.id) {\n throw new Error(\n \"MessageRepository(performOp/link): A message with the same id already exists in the parent tree. This error occurs if the same message id is found multiple times. This is likely an internal bug in assistant-ui.\",\n );\n }\n }\n\n // add to parentOrRoot.children\n newParentOrRoot.children = [\n ...newParentOrRoot.children,\n child.current.id,\n ];\n\n // update parentOrRoot.next\n if (findHead(child) === this.head || newParentOrRoot.next === null) {\n newParentOrRoot.next = child;\n }\n\n child.prev = newParent;\n }\n }\n getMessages() {\n const messages = new Array<ThreadMessage>(this.head?.level ?? 0);\n for (let current = this.head; current; current = current.prev) {\n messages[current.level] = current.current;\n }\n return messages;\n }\n\n addOrUpdateMessage(parentId: string | null, message: ThreadMessage) {\n const existingItem = this.messages.get(message.id);\n const prev = parentId ? this.messages.get(parentId) : null;\n if (prev === undefined)\n throw new Error(\n \"MessageRepository(addOrUpdateMessage): Parent message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n // update existing message\n if (existingItem) {\n existingItem.current = message;\n this.performOp(prev, existingItem, \"relink\");\n return;\n }\n\n // create a new message\n const newItem: RepositoryMessage = {\n prev,\n current: message,\n next: null,\n children: [],\n level: prev ? prev.level + 1 : 0,\n };\n\n this.messages.set(message.id, newItem);\n this.performOp(prev, newItem, \"link\");\n\n if (this.head === prev) {\n this.head = newItem;\n }\n }\n\n getMessage(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(updateMessage): Message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n return {\n parentId: message.prev?.current.id ?? null,\n message: message.current,\n };\n }\n\n appendOptimisticMessage(parentId: string | null, message: CoreMessage) {\n let optimisticId: string;\n do {\n optimisticId = generateOptimisticId();\n } while (this.messages.has(optimisticId));\n\n this.addOrUpdateMessage(\n parentId,\n fromCoreMessage(message, {\n id: optimisticId,\n status: { type: \"running\" },\n }),\n );\n\n return optimisticId;\n }\n\n deleteMessage(messageId: string, replacementId?: string | null | undefined) {\n const message = this.messages.get(messageId);\n\n if (!message)\n throw new Error(\n \"MessageRepository(deleteMessage): Optimistic message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const replacement =\n replacementId === undefined\n ? message.prev // if no replacementId is provided, use the parent\n : replacementId === null\n ? null\n : this.messages.get(replacementId);\n if (replacement === undefined)\n throw new Error(\n \"MessageRepository(deleteMessage): Replacement not found. This is likely an internal bug in assistant-ui.\",\n );\n\n for (const child of message.children) {\n const childMessage = this.messages.get(child);\n if (!childMessage)\n throw new Error(\n \"MessageRepository(deleteMessage): Child message not found. This is likely an internal bug in assistant-ui.\",\n );\n this.performOp(replacement, childMessage, \"relink\");\n }\n\n this.performOp(null, message, \"cut\");\n this.messages.delete(messageId);\n\n if (this.head === message) {\n this.head = findHead(replacement ?? this.root);\n }\n }\n\n getBranches(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(getBranches): Message not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const { children } = message.prev ?? this.root;\n return children;\n }\n\n switchToBranch(messageId: string) {\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(switchToBranch): Branch not found. This is likely an internal bug in assistant-ui.\",\n );\n\n const prevOrRoot = message.prev ?? this.root;\n prevOrRoot.next = message;\n\n this.head = findHead(message);\n }\n\n resetHead(messageId: string | null) {\n if (messageId === null) {\n this.head = null;\n return;\n }\n\n const message = this.messages.get(messageId);\n if (!message)\n throw new Error(\n \"MessageRepository(resetHead): Branch not found. This is likely an internal bug in assistant-ui.\",\n );\n\n this.head = message;\n for (\n let current: RepositoryMessage | null = message;\n current;\n current = current.prev\n ) {\n if (current.prev) {\n current.prev.next = current;\n }\n }\n }\n\n export(): ExportedMessageRepository {\n const exportItems: ExportedMessageRepository[\"messages\"] = [];\n\n // hint: we are relying on the insertion order of the messages\n // this is important for the import function to properly link the messages\n for (const [, message] of this.messages) {\n exportItems.push({\n message: message.current,\n parentId: message.prev?.current.id ?? null,\n });\n }\n\n return {\n headId: this.head?.current.id ?? null,\n messages: exportItems,\n };\n }\n\n import({ headId, messages }: ExportedMessageRepository) {\n for (const { message, parentId } of messages) {\n this.addOrUpdateMessage(parentId, message);\n }\n\n // switch to the saved head id if it is not the most recent message\n this.resetHead(headId ?? messages.at(-1)?.message.id ?? null);\n }\n}\n","\"use client\";\n\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport { useMessageContext } from \"../../context\";\nimport {\n ContentPartStatus,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\nimport { TextContentPartState } from \"../../context/stores/ContentPart\";\nimport { useSmoothContext } from \"./SmoothContext\";\nimport { StoreApi } from \"zustand\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\n\nclass TextStreamAnimator {\n private animationFrameId: number | null = null;\n private lastUpdateTime: number = Date.now();\n\n public targetText: string = \"\";\n\n constructor(\n public currentText: string,\n private setText: (newText: string) => void,\n ) {}\n\n start() {\n if (this.animationFrameId !== null) return;\n this.lastUpdateTime = Date.now();\n this.animate();\n }\n\n stop() {\n if (this.animationFrameId !== null) {\n cancelAnimationFrame(this.animationFrameId);\n this.animationFrameId = null;\n }\n }\n\n private animate = () => {\n const currentTime = Date.now();\n const deltaTime = currentTime - this.lastUpdateTime;\n let timeToConsume = deltaTime;\n\n const remainingChars = this.targetText.length - this.currentText.length;\n const baseTimePerChar = Math.min(5, 250 / remainingChars);\n\n let charsToAdd = 0;\n while (timeToConsume >= baseTimePerChar && charsToAdd < remainingChars) {\n charsToAdd++;\n timeToConsume -= baseTimePerChar;\n }\n\n if (charsToAdd !== remainingChars) {\n this.animationFrameId = requestAnimationFrame(this.animate);\n } else {\n this.animationFrameId = null;\n }\n if (charsToAdd === 0) return;\n\n this.currentText = this.targetText.slice(\n 0,\n this.currentText.length + charsToAdd,\n );\n this.lastUpdateTime = currentTime - timeToConsume;\n this.setText(this.currentText);\n };\n}\n\nconst SMOOTH_STATUS: ContentPartStatus = Object.freeze({\n type: \"running\",\n});\n\nexport const useSmooth = (\n state: TextContentPartState,\n smooth: boolean = false,\n): TextContentPartState => {\n const { useSmoothStatus } = useSmoothContext({ optional: true }) ?? {};\n\n const {\n part: { text },\n } = state;\n const { useMessage } = useMessageContext();\n const id = useMessage((m) => m.message.id);\n\n const idRef = useRef(id);\n const [displayedText, setDisplayedText] = useState(text);\n\n const setText = useCallbackRef((text: string) => {\n setDisplayedText(text);\n (\n useSmoothStatus as unknown as\n | StoreApi<ToolCallContentPartStatus>\n | undefined\n )?.setState(text !== state.part.text ? SMOOTH_STATUS : state.status);\n });\n\n // TODO this is hacky\n useEffect(() => {\n // TODO add a helper function so we don't have to override the types\n (\n useSmoothStatus as unknown as\n | StoreApi<ToolCallContentPartStatus>\n | undefined\n )?.setState(text !== displayedText ? SMOOTH_STATUS : state.status);\n }, [useSmoothStatus, text, displayedText, state.status]);\n\n const [animatorRef] = useState<TextStreamAnimator>(\n new TextStreamAnimator(text, setText),\n );\n\n useEffect(() => {\n if (!smooth) {\n animatorRef.stop();\n return;\n }\n\n if (idRef.current !== id || !text.startsWith(animatorRef.targetText)) {\n idRef.current = id;\n setText(text);\n\n animatorRef.currentText = text;\n animatorRef.targetText = text;\n animatorRef.stop();\n\n return;\n }\n\n animatorRef.targetText = text;\n animatorRef.start();\n }, [setText, animatorRef, id, smooth, text]);\n\n useEffect(() => {\n return () => {\n animatorRef.stop();\n };\n }, [animatorRef]);\n\n return useMemo(\n () =>\n smooth\n ? {\n part: { type: \"text\", text: displayedText },\n status: text === displayedText ? state.status : SMOOTH_STATUS,\n }\n : state,\n [smooth, displayedText, state, text],\n );\n};\n","import {\n createContext,\n FC,\n forwardRef,\n PropsWithChildren,\n useContext,\n useState,\n} from \"react\";\nimport { useContentPartContext } from \"../../context\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\nimport { create } from \"zustand\";\nimport {\n ContentPartStatus,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\n\ntype SmoothContextValue = {\n useSmoothStatus: ReadonlyStore<ToolCallContentPartStatus | ContentPartStatus>;\n};\n\nconst SmoothContext = createContext<SmoothContextValue | null>(null);\n\nconst makeSmoothContext = (\n initialState: ContentPartStatus | ToolCallContentPartStatus,\n) => {\n const useSmoothStatus = create(() => initialState);\n return { useSmoothStatus };\n};\n\nexport const SmoothContextProvider: FC<PropsWithChildren> = ({ children }) => {\n const outer = useSmoothContext({ optional: true });\n const { useContentPart } = useContentPartContext();\n\n const [context] = useState(() =>\n makeSmoothContext(useContentPart.getState().status),\n );\n\n // do not wrap if there is an outer SmoothContextProvider\n if (outer) return children;\n\n return (\n <SmoothContext.Provider value={context}>{children}</SmoothContext.Provider>\n );\n};\n\nexport const withSmoothContextProvider = <C extends React.ComponentType<any>>(\n Component: C,\n): C => {\n const Wrapped = forwardRef((props, ref) => {\n return (\n <SmoothContextProvider>\n <Component {...(props as any)} ref={ref} />\n </SmoothContextProvider>\n );\n });\n Wrapped.displayName = Component.displayName;\n return Wrapped as any;\n};\n\nexport function useSmoothContext(): SmoothContextValue;\nexport function useSmoothContext(options: {\n optional: true;\n}): SmoothContextValue | null;\nexport function useSmoothContext(options?: { optional: true }) {\n const context = useContext(SmoothContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component must be used within a SmoothContextProvider.\",\n );\n return context;\n}\n\nexport const useSmoothStatus = () => {\n const { useSmoothStatus } = useSmoothContext();\n return useSmoothStatus();\n};\n","\"use client\";\n\nimport { forwardRef } from \"react\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"./tooltip\";\nimport { Button, ButtonProps } from \"./button\";\n\nexport type TooltipIconButtonProps = ButtonProps & {\n tooltip: string;\n side?: \"top\" | \"bottom\" | \"left\" | \"right\";\n};\n\nexport const TooltipIconButton = forwardRef<\n HTMLButtonElement,\n TooltipIconButtonProps\n>(({ children, tooltip, side = \"bottom\", ...rest }, ref) => {\n return (\n <Tooltip>\n <TooltipTrigger asChild>\n <Button variant=\"ghost\" size=\"icon\" {...rest} ref={ref}>\n {children}\n <span className=\"aui-sr-only\">{tooltip}</span>\n </Button>\n </TooltipTrigger>\n <TooltipContent side={side}>{tooltip}</TooltipContent>\n </Tooltip>\n );\n});\n\nTooltipIconButton.displayName = \"TooltipIconButton\";\n","\"use client\";\n\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\nimport { withDefaults } from \"../utils/withDefaults\";\nimport { FC } from \"react\";\n\nexport const Tooltip: FC<TooltipPrimitive.TooltipProps> = (props) => {\n return (\n <TooltipPrimitive.Provider>\n <TooltipPrimitive.Root {...props} />\n </TooltipPrimitive.Provider>\n );\n};\n\nTooltip.displayName = \"Tooltip\";\n\nexport const TooltipTrigger = TooltipPrimitive.Trigger;\n\nexport const TooltipContent = withDefaults(TooltipPrimitive.Content, {\n sideOffset: 4,\n className: \"aui-tooltip-content\",\n});\n\nTooltipContent.displayName = \"TooltipContent\";\n","import {\n ComponentPropsWithoutRef,\n ElementRef,\n ElementType,\n forwardRef,\n} from \"react\";\nimport classNames from \"classnames\";\n\nexport const withDefaultProps =\n <TProps extends { className?: string }>({\n className,\n ...defaultProps\n }: Partial<TProps>) =>\n ({ className: classNameProp, ...props }: TProps) => {\n return {\n className: classNames(className, classNameProp),\n ...defaultProps,\n ...props,\n } as TProps;\n };\n\nexport const withDefaults = <TComponent extends ElementType>(\n Component: TComponent,\n defaultProps: Partial<ComponentPropsWithoutRef<TComponent>>,\n) => {\n type TComponentProps = typeof defaultProps;\n const getProps = withDefaultProps<TComponentProps>(defaultProps);\n const WithDefaults = forwardRef<ElementRef<TComponent>, TComponentProps>(\n (props, ref) => {\n const ComponentAsAny = Component as any;\n return <ComponentAsAny {...getProps(props as any)} ref={ref} />;\n },\n );\n WithDefaults.displayName =\n \"withDefaults(\" +\n (typeof Component === \"string\" ? Component : Component.displayName) +\n \")\";\n return WithDefaults;\n};\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { ElementRef, forwardRef } from \"react\";\n\nconst buttonVariants = cva(\"aui-button\", {\n variants: {\n variant: {\n default: \"aui-button-primary\",\n outline: \"aui-button-outline\",\n ghost: \"aui-button-ghost\",\n },\n size: {\n default: \"aui-button-medium\",\n icon: \"aui-button-icon\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n});\n\ntype ButtonElement = ElementRef<typeof Primitive.button>;\n\nexport type ButtonProps = React.ComponentPropsWithoutRef<\n typeof Primitive.button\n> &\n VariantProps<typeof buttonVariants>;\n\nconst Button = forwardRef<ButtonElement, ButtonProps>(\n ({ className, variant, size, ...props }, ref) => {\n return (\n <Primitive.button\n className={buttonVariants({ variant, size, className })}\n {...props}\n ref={ref}\n />\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","import { LanguageModelV1Message } from \"@ai-sdk/provider\";\nimport { CoreMessage, ToolCallContentPart } from \"../../../types\";\n\ntype fromLanguageModelMessagesOptions = {\n mergeRoundtrips: boolean;\n};\n\nexport const fromLanguageModelMessages = (\n lm: LanguageModelV1Message[],\n { mergeRoundtrips }: fromLanguageModelMessagesOptions,\n): CoreMessage[] => {\n const messages: CoreMessage[] = [];\n\n for (const lmMessage of lm) {\n const role = lmMessage.role;\n switch (role) {\n case \"system\": {\n messages.push({\n role: \"system\",\n content: [\n {\n type: \"text\",\n text: lmMessage.content,\n },\n ],\n });\n break;\n }\n case \"user\": {\n messages.push({\n role: \"user\",\n content: lmMessage.content.map((part) => {\n const type = part.type;\n switch (type) {\n case \"text\": {\n return {\n type: \"text\",\n text: part.text,\n };\n }\n case \"image\": {\n if (part.image instanceof URL) {\n return {\n type: \"image\",\n image: part.image.href,\n };\n }\n throw new Error(\"Only images with URL data are supported\");\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n }),\n });\n break;\n }\n case \"assistant\": {\n const newContent = lmMessage.content.map((part) => {\n if (part.type === \"tool-call\") {\n return {\n type: \"tool-call\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n argsText: JSON.stringify(part.args),\n args: part.args as Record<string, unknown>,\n } satisfies ToolCallContentPart;\n }\n return part;\n });\n\n if (mergeRoundtrips) {\n const previousMessage = messages[messages.length - 1];\n if (previousMessage?.role === \"assistant\") {\n previousMessage.content.push(...newContent);\n break;\n }\n }\n\n messages.push({\n role: \"assistant\",\n content: newContent,\n });\n break;\n }\n case \"tool\": {\n const previousMessage = messages[messages.length - 1];\n if (previousMessage?.role !== \"assistant\")\n throw new Error(\n \"A tool message must be preceded by an assistant message.\",\n );\n\n for (const tool of lmMessage.content) {\n const toolCall = previousMessage.content.find(\n (c): c is ToolCallContentPart =>\n c.type === \"tool-call\" && c.toolCallId === tool.toolCallId,\n );\n if (!toolCall)\n throw new Error(\"Received tool result for an unknown tool call.\");\n if (toolCall.toolName !== tool.toolName)\n throw new Error(\"Tool call name mismatch.\");\n\n toolCall.result = tool.result;\n if (tool.isError) {\n toolCall.isError = true;\n }\n }\n\n break;\n }\n\n default: {\n const unhandledRole: never = role;\n throw new Error(`Unknown message role: ${unhandledRole}`);\n }\n }\n }\n\n return messages;\n};\n","import { LanguageModelV1FunctionTool } from \"@ai-sdk/provider\";\nimport { Tool } from \"../../../types/ModelConfigTypes\";\n\nexport const fromLanguageModelTools = (\n tools: LanguageModelV1FunctionTool[],\n): Record<string, Tool<any, any>> => {\n return Object.fromEntries(\n tools.map((tool) => [\n tool.name,\n {\n description: tool.description,\n parameters: tool.parameters,\n },\n ]),\n );\n};\n","export function chunkByLineStream() {\n let buffer = \"\";\n\n return new TransformStream({\n transform(chunk, controller) {\n buffer += chunk;\n const lines = buffer.split(\"\\n\");\n\n // Process all complete lines\n for (let i = 0; i < lines.length - 1; i++) {\n controller.enqueue(lines[i]);\n }\n\n // Keep the last incomplete line in the buffer\n buffer = lines[lines.length - 1]!;\n },\n flush(controller) {\n // flush any remaining content in the buffer\n if (buffer) {\n controller.enqueue(buffer);\n }\n },\n });\n}\n","import { chunkByLineStream } from \"./chunkByLineStream\";\nimport { PipeableTransformStream } from \"./PipeableTransformStream\";\nimport { StreamPart } from \"./StreamPart\";\n\nconst decodeStreamPart = <T extends Record<string, unknown>>(\n part: string,\n): StreamPart<T> => {\n const index = part.indexOf(\":\");\n if (index === -1) throw new Error(\"Invalid stream part\");\n return {\n type: part.slice(0, index),\n value: JSON.parse(part.slice(index + 1)),\n };\n};\n\nexport function streamPartDecoderStream<T extends Record<string, unknown>>() {\n const decodeStream = new TransformStream<string, StreamPart<T>>({\n transform(chunk, controller) {\n controller.enqueue(decodeStreamPart<T>(chunk));\n },\n });\n\n return new PipeableTransformStream((readable) => {\n return readable\n .pipeThrough(new TextDecoderStream())\n .pipeThrough(chunkByLineStream())\n .pipeThrough(decodeStream);\n });\n}\n","import { streamPartDecoderStream } from \"./streamPartDecoderStream\";\nimport { streamPartEncoderStream } from \"./streamPartEncoderStream\";\nimport { StreamPart } from \"./StreamPart\";\n\nexport declare namespace StreamUtils {\n export { StreamPart };\n}\n\nexport const streamUtils = {\n streamPartEncoderStream,\n streamPartDecoderStream,\n};\n","import { LocalRuntimeOptions, useLocalRuntime } from \"..\";\nimport { useState } from \"react\";\nimport { EdgeChatAdapterOptions, EdgeChatAdapter } from \"./EdgeChatAdapter\";\n\nexport type EdgeRuntimeOptions = EdgeChatAdapterOptions & LocalRuntimeOptions;\n\nexport const useEdgeRuntime = ({\n initialMessages,\n maxToolRoundtrips,\n adapters,\n ...options\n}: EdgeRuntimeOptions) => {\n const [adapter] = useState(() => new EdgeChatAdapter(options));\n return useLocalRuntime(adapter, {\n initialMessages,\n maxToolRoundtrips,\n adapters,\n });\n};\n","import {\n AssistantStreamChunk,\n AssistantStreamChunkType,\n} from \"./AssistantStreamChunkType\";\nimport { StreamPart } from \"./utils/StreamPart\";\nimport { ToolResultStreamPart } from \"./toolResultStream\";\n\nexport function assistantDecoderStream() {\n const toolCallNames = new Map<string, string>();\n let currentToolCall:\n | { id: string; name: string; argsText: string }\n | undefined;\n\n return new TransformStream<\n StreamPart<AssistantStreamChunk>,\n ToolResultStreamPart\n >({\n transform({ type, value }, controller) {\n if (\n currentToolCall &&\n type !== AssistantStreamChunkType.ToolCallArgsTextDelta &&\n type !== AssistantStreamChunkType.Error\n ) {\n controller.enqueue({\n type: \"tool-call\",\n toolCallType: \"function\",\n toolCallId: currentToolCall.id,\n toolName: currentToolCall.name,\n args: currentToolCall.argsText,\n });\n currentToolCall = undefined;\n }\n\n switch (type) {\n case AssistantStreamChunkType.TextDelta: {\n controller.enqueue({\n type: \"text-delta\",\n textDelta: value,\n });\n break;\n }\n case AssistantStreamChunkType.ToolCallBegin: {\n const { id, name } = value;\n toolCallNames.set(id, name);\n currentToolCall = { id, name, argsText: \"\" };\n break;\n }\n case AssistantStreamChunkType.ToolCallArgsTextDelta: {\n const delta = value;\n currentToolCall!.argsText += delta;\n controller.enqueue({\n type: \"tool-call-delta\",\n toolCallType: \"function\",\n toolCallId: currentToolCall!.id,\n toolName: currentToolCall!.name,\n argsTextDelta: delta,\n });\n break;\n }\n case AssistantStreamChunkType.ToolCallResult: {\n controller.enqueue({\n type: \"tool-result\",\n toolCallType: \"function\",\n toolCallId: value.id,\n toolName: toolCallNames.get(value.id)!,\n result: value.result,\n });\n break;\n }\n case AssistantStreamChunkType.Finish: {\n controller.enqueue({\n type: \"finish\",\n ...value,\n });\n break;\n }\n case AssistantStreamChunkType.Error: {\n controller.enqueue({\n type: \"error\",\n error: value,\n });\n break;\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unhandled chunk type: ${unhandledType}`);\n }\n }\n },\n });\n}\n","import { ChatModelAdapter, ChatModelRunOptions } from \"../local\";\nimport { ChatModelRunResult } from \"../local/ChatModelAdapter\";\nimport { toCoreMessages } from \"./converters/toCoreMessages\";\nimport { toLanguageModelTools } from \"./converters/toLanguageModelTools\";\nimport { EdgeRuntimeRequestOptions } from \"./EdgeRuntimeRequestOptions\";\nimport { assistantDecoderStream } from \"./streams/assistantDecoderStream\";\nimport { streamPartDecoderStream } from \"./streams/utils/streamPartDecoderStream\";\nimport { runResultStream } from \"./streams/runResultStream\";\nimport { toolResultStream } from \"./streams/toolResultStream\";\n\nexport function asAsyncIterable<T>(\n source: ReadableStream<T>,\n): AsyncIterable<T> {\n return {\n [Symbol.asyncIterator]: () => {\n const reader = source.getReader();\n return {\n async next(): Promise<IteratorResult<T, undefined>> {\n const { done, value } = await reader.read();\n return done\n ? { done: true, value: undefined }\n : { done: false, value };\n },\n };\n },\n };\n}\nexport type EdgeChatAdapterOptions = {\n api: string;\n\n credentials?: RequestCredentials;\n headers?: Record<string, string> | Headers;\n body?: object;\n};\n\nexport class EdgeChatAdapter implements ChatModelAdapter {\n constructor(private options: EdgeChatAdapterOptions) {}\n\n async *run({ messages, abortSignal, config }: ChatModelRunOptions) {\n const headers = new Headers(this.options.headers);\n headers.set(\"Content-Type\", \"application/json\");\n\n const result = await fetch(this.options.api, {\n method: \"POST\",\n headers,\n credentials: this.options.credentials ?? \"same-origin\",\n body: JSON.stringify({\n system: config.system,\n messages: toCoreMessages(messages),\n tools: config.tools ? toLanguageModelTools(config.tools) : [],\n ...config.callSettings,\n ...config.config,\n\n ...this.options.body,\n } satisfies EdgeRuntimeRequestOptions),\n signal: abortSignal,\n });\n\n if (result.status !== 200) {\n throw new Error(`Status ${result.status}: ${await result.text()}`);\n }\n\n const stream = result\n .body!.pipeThrough(streamPartDecoderStream())\n .pipeThrough(assistantDecoderStream())\n .pipeThrough(toolResultStream(config.tools, abortSignal))\n .pipeThrough(runResultStream());\n\n let update: ChatModelRunResult | undefined;\n for await (update of asAsyncIterable(stream)) {\n yield update;\n }\n\n if (update === undefined)\n throw new Error(\"No data received from Edge Runtime\");\n }\n}\n","import type { ThreadAssistantMessage } from \"../../types\";\n\nexport const shouldContinue = (result: ThreadAssistantMessage) =>\n result.status?.type === \"requires-action\" &&\n result.status.reason === \"tool-calls\" &&\n result.content.every((c) => c.type !== \"tool-call\" || !!c.result);\n","import { AddToolResultOptions } from \"../../context\";\nimport { generateId } from \"../../internal\";\nimport type {\n ModelConfigProvider,\n AppendMessage,\n ThreadUserMessage,\n ThreadAssistantMessage,\n Unsubscribe,\n} from \"../../types\";\nimport { fromCoreMessages } from \"../edge\";\nimport {\n ExportedMessageRepository,\n MessageRepository,\n} from \"../utils/MessageRepository\";\nimport type { ChatModelAdapter, ChatModelRunResult } from \"./ChatModelAdapter\";\nimport { shouldContinue } from \"./shouldContinue\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\nimport { ThreadRuntime } from \"../core\";\nimport { SpeechSynthesisAdapter } from \"../speech\";\n\nexport class LocalThreadRuntime implements ThreadRuntime {\n private _subscriptions = new Set<() => void>();\n\n private abortController: AbortController | null = null;\n private readonly repository = new MessageRepository();\n\n public readonly capabilities = {\n switchToBranch: true,\n edit: true,\n reload: true,\n cancel: true,\n unstable_copy: true,\n speak: false,\n };\n\n public readonly threadId: string;\n public readonly isDisabled = false;\n\n public get messages() {\n return this.repository.getMessages();\n }\n\n public readonly composer = {\n text: \"\",\n setText: (value: string) => {\n this.composer.text = value;\n this.notifySubscribers();\n },\n };\n\n constructor(\n private configProvider: ModelConfigProvider,\n public adapter: ChatModelAdapter,\n { initialMessages, ...options }: LocalRuntimeOptions,\n ) {\n this.threadId = generateId();\n this.options = options;\n if (initialMessages) {\n let parentId: string | null = null;\n const messages = fromCoreMessages(initialMessages);\n for (const message of messages) {\n this.repository.addOrUpdateMessage(parentId, message);\n parentId = message.id;\n }\n }\n }\n\n private _options!: LocalRuntimeOptions;\n\n public get options() {\n return this._options;\n }\n\n public set options({ initialMessages, ...options }: LocalRuntimeOptions) {\n this._options = options;\n\n const canSpeak = options.adapters?.speech !== undefined;\n if (this.capabilities.speak !== canSpeak) {\n this.capabilities.speak = canSpeak;\n this.notifySubscribers();\n }\n }\n\n public getBranches(messageId: string): string[] {\n return this.repository.getBranches(messageId);\n }\n\n public switchToBranch(branchId: string): void {\n this.repository.switchToBranch(branchId);\n this.notifySubscribers();\n }\n\n public async append(message: AppendMessage): Promise<void> {\n if (message.role !== \"user\")\n throw new Error(\n \"Only appending user messages are supported in LocalRuntime. This is likely an internal bug in assistant-ui.\",\n );\n\n // add user message\n const userMessageId = generateId();\n const userMessage: ThreadUserMessage = {\n id: userMessageId,\n role: \"user\",\n content: message.content,\n createdAt: new Date(),\n };\n this.repository.addOrUpdateMessage(message.parentId, userMessage);\n\n await this.startRun(userMessageId);\n }\n\n public async startRun(parentId: string | null): Promise<void> {\n this.repository.resetHead(parentId);\n\n // add assistant message\n const id = generateId();\n let message: ThreadAssistantMessage = {\n id,\n role: \"assistant\",\n status: { type: \"running\" },\n content: [],\n createdAt: new Date(),\n };\n\n do {\n message = await this.performRoundtrip(parentId, message);\n } while (shouldContinue(message));\n }\n\n private async performRoundtrip(\n parentId: string | null,\n message: ThreadAssistantMessage,\n ) {\n const messages = this.repository.getMessages();\n\n // abort existing run\n this.abortController?.abort();\n this.abortController = new AbortController();\n\n const initialContent = message.content;\n const initialRoundtrips = message.metadata?.roundtrips;\n const initalCustom = message.metadata?.custom;\n const updateMessage = (m: Partial<ChatModelRunResult>) => {\n message = {\n ...message,\n ...(m.content\n ? { content: [...initialContent, ...(m.content ?? [])] }\n : undefined),\n status: m.status ?? message.status,\n // TODO deprecated, remove in v0.6\n ...(m.metadata?.roundtrips\n ? {\n roundtrips: [\n ...(initialRoundtrips ?? []),\n ...m.metadata.roundtrips,\n ],\n }\n : undefined),\n ...(m.metadata\n ? {\n metadata: {\n ...message.metadata,\n ...(m.metadata.roundtrips\n ? {\n roundtrips: [\n ...(initialRoundtrips ?? []),\n ...m.metadata.roundtrips,\n ],\n }\n : undefined),\n ...(m.metadata?.custom\n ? {\n custom: { ...(initalCustom ?? {}), ...m.metadata.custom },\n }\n : undefined),\n },\n }\n : undefined),\n };\n this.repository.addOrUpdateMessage(parentId, message);\n this.notifySubscribers();\n };\n\n const maxToolRoundtrips = this.options.maxToolRoundtrips ?? 1;\n const toolRoundtrips = message.metadata?.roundtrips?.length ?? 0;\n if (toolRoundtrips > maxToolRoundtrips) {\n // reached max tool roundtrips\n updateMessage({\n status: {\n type: \"incomplete\",\n reason: \"tool-calls\",\n },\n });\n return message;\n } else {\n updateMessage({\n status: {\n type: \"running\",\n },\n });\n }\n\n try {\n const promiseOrGenerator = this.adapter.run({\n messages,\n abortSignal: this.abortController.signal,\n config: this.configProvider.getModelConfig(),\n onUpdate: updateMessage,\n });\n\n // handle async iterator for streaming results\n if (Symbol.asyncIterator in promiseOrGenerator) {\n for await (const r of promiseOrGenerator) {\n updateMessage(r);\n }\n } else {\n updateMessage(await promiseOrGenerator);\n }\n\n this.abortController = null;\n\n if (message.status.type === \"running\") {\n updateMessage({\n status: { type: \"complete\", reason: \"unknown\" },\n });\n }\n } catch (e) {\n this.abortController = null;\n\n // TODO this should be handled by the run result stream\n if (e instanceof Error && e.name === \"AbortError\") {\n updateMessage({\n status: { type: \"incomplete\", reason: \"cancelled\" },\n });\n } else {\n updateMessage({\n status: { type: \"incomplete\", reason: \"error\", error: e },\n });\n\n throw e;\n }\n }\n return message;\n }\n\n cancelRun(): void {\n if (!this.abortController) return;\n\n this.abortController.abort();\n this.abortController = null;\n }\n\n private notifySubscribers() {\n for (const callback of this._subscriptions) callback();\n }\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n public addToolResult({\n messageId,\n toolCallId,\n result,\n }: AddToolResultOptions) {\n let { parentId, message } = this.repository.getMessage(messageId);\n\n if (message.role !== \"assistant\")\n throw new Error(\"Tried to add tool result to non-assistant message\");\n\n let added = false;\n let found = false;\n const newContent = message.content.map((c) => {\n if (c.type !== \"tool-call\") return c;\n if (c.toolCallId !== toolCallId) return c;\n found = true;\n if (!c.result) added = true;\n return {\n ...c,\n result,\n };\n });\n\n if (!found)\n throw new Error(\"Tried to add tool result to non-existing tool call\");\n\n message = {\n ...message,\n content: newContent,\n };\n this.repository.addOrUpdateMessage(parentId, message);\n\n if (added && shouldContinue(message)) {\n this.performRoundtrip(parentId, message);\n }\n }\n\n // TODO lift utterance state to thread runtime\n private _utterance: SpeechSynthesisAdapter.Utterance | undefined;\n\n public speak(messageId: string) {\n const adapter = this.options.adapters?.speech;\n if (!adapter) throw new Error(\"Speech adapter not configured\");\n\n const { message } = this.repository.getMessage(messageId);\n\n if (this._utterance) {\n this._utterance.cancel();\n this._utterance = undefined;\n }\n\n const utterance = adapter.speak(message);\n utterance.onEnd(() => {\n if (this._utterance === utterance) {\n this._utterance = undefined;\n }\n });\n this._utterance = utterance;\n\n return this._utterance;\n }\n\n public export() {\n return this.repository.export();\n }\n\n public import(data: ExportedMessageRepository) {\n this.repository.import(data);\n this.notifySubscribers();\n }\n}\n","import { type ModelConfigProvider } from \"../../types/ModelConfigTypes\";\nimport type { CoreMessage } from \"../../types/AssistantTypes\";\nimport { BaseAssistantRuntime } from \"../core/BaseAssistantRuntime\";\nimport type { ChatModelAdapter } from \"./ChatModelAdapter\";\nimport { ProxyConfigProvider } from \"../../internal\";\nimport { LocalThreadRuntime } from \"./LocalThreadRuntime\";\nimport { LocalRuntimeOptions } from \"./LocalRuntimeOptions\";\nimport { fromCoreMessages } from \"../edge/converters/fromCoreMessage\";\n\nexport class LocalRuntime extends BaseAssistantRuntime<LocalThreadRuntime> {\n private readonly _proxyConfigProvider: ProxyConfigProvider;\n\n constructor(adapter: ChatModelAdapter, options: LocalRuntimeOptions) {\n const proxyConfigProvider = new ProxyConfigProvider();\n super(new LocalThreadRuntime(proxyConfigProvider, adapter, options));\n this._proxyConfigProvider = proxyConfigProvider;\n }\n\n public set adapter(adapter: ChatModelAdapter) {\n this.thread.adapter = adapter;\n }\n\n public set options(options: LocalRuntimeOptions) {\n this.thread.options = options;\n }\n\n registerModelConfigProvider(provider: ModelConfigProvider) {\n return this._proxyConfigProvider.registerModelConfigProvider(provider);\n }\n\n public switchToThread(threadId: string | null) {\n if (threadId) {\n throw new Error(\"LocalRuntime does not yet support switching threads\");\n }\n\n const { initialMessages, ...options } = this.thread.options;\n\n return (this.thread = new LocalThreadRuntime(\n this._proxyConfigProvider,\n this.thread.adapter,\n options,\n ));\n }\n\n public reset({\n initialMessages,\n }: {\n initialMessages?: readonly CoreMessage[] | undefined;\n } = {}) {\n this.switchToThread(null);\n if (!initialMessages) return;\n\n const messages = fromCoreMessages(initialMessages);\n this.thread.import({\n messages: messages.map((m, idx) => ({\n parentId: messages[idx - 1]?.id ?? null,\n message: m,\n })),\n });\n }\n}\n","import { ThreadMessage } from \"../../types\";\n\nexport const symbolInnerMessage = Symbol(\"innerMessage\");\n\nexport type ExternalStoreThreadMessage<T> = ThreadMessage & {\n [symbolInnerMessage]?: T;\n};\n\nexport const getExternalStoreMessage = <T,>(message: ThreadMessage) => {\n return (message as ExternalStoreThreadMessage<T>)[symbolInnerMessage];\n};\n","import { ThreadMessage } from \"../../types\";\n\nexport type ConverterCallback<TIn> = (\n cache: ThreadMessage | undefined,\n message: TIn,\n idx: number,\n) => ThreadMessage;\n\nexport class ThreadMessageConverter {\n private readonly cache = new WeakMap<WeakKey, ThreadMessage>();\n\n convertMessages<TIn extends WeakKey>(\n messages: TIn[],\n converter: ConverterCallback<TIn>,\n ): ThreadMessage[] {\n return messages.map((m, idx) => {\n const cached = this.cache.get(m);\n const newMessage = converter(cached, m, idx);\n this.cache.set(m, newMessage);\n return newMessage;\n });\n }\n}\n","import { MessageStatus } from \"../../types\";\n\nconst AUTO_STATUS_RUNNING = Object.freeze({ type: \"running\" });\nconst AUTO_STATUS_COMPLETE = Object.freeze({\n type: \"complete\",\n reason: \"unknown\",\n});\n\nexport const isAutoStatus = (status: MessageStatus) =>\n status === AUTO_STATUS_RUNNING || status === AUTO_STATUS_COMPLETE;\n\nexport const getAutoStatus = (isLast: boolean, isRunning: boolean) =>\n isLast && isRunning ? AUTO_STATUS_RUNNING : AUTO_STATUS_COMPLETE;\n","import {\n MessageStatus,\n TextContentPart,\n ImageContentPart,\n ToolCallContentPart,\n UIContentPart,\n ThreadMessage,\n ThreadAssistantContentPart,\n ThreadAssistantMessage,\n ThreadUserContentPart,\n ThreadUserMessage,\n ThreadSystemMessage,\n} from \"../../types\";\nimport { CoreToolCallContentPart } from \"../../types/AssistantTypes\";\n\nexport type ThreadMessageLike = {\n role: \"assistant\" | \"user\" | \"system\";\n content:\n | string\n | (\n | TextContentPart\n | ImageContentPart\n | ToolCallContentPart<any, any>\n | CoreToolCallContentPart<any, any>\n | UIContentPart\n )[];\n id?: string | undefined;\n createdAt?: Date | undefined;\n status?: MessageStatus | undefined;\n};\n\nexport const fromThreadMessageLike = (\n like: ThreadMessageLike,\n fallbackId: string,\n fallbackStatus: MessageStatus,\n): ThreadMessage => {\n const { role, id, createdAt, status } = like;\n const common = {\n id: id ?? fallbackId,\n createdAt: createdAt ?? new Date(),\n };\n\n const content =\n typeof like.content === \"string\"\n ? [{ type: \"text\" as const, text: like.content }]\n : like.content;\n\n switch (role) {\n case \"assistant\":\n return {\n ...common,\n role,\n content: content\n .map((part): ThreadAssistantContentPart | null => {\n const type = part.type;\n switch (type) {\n case \"text\":\n if (part.text.trim().length === 0) return null;\n return part;\n\n case \"ui\":\n return part;\n\n case \"tool-call\": {\n if (\"argsText\" in part) return part;\n return {\n ...part,\n argsText: JSON.stringify(part.args),\n };\n }\n\n default: {\n const unhandledType: \"image\" = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n })\n .filter((c) => !!c),\n status: status ?? fallbackStatus,\n } satisfies ThreadAssistantMessage;\n\n case \"user\":\n return {\n ...common,\n role,\n content: content.map((part): ThreadUserContentPart => {\n const type = part.type;\n switch (type) {\n case \"text\":\n case \"ui\":\n case \"image\":\n return part;\n\n default: {\n const unhandledType: \"tool-call\" = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n }\n }),\n } satisfies ThreadUserMessage;\n\n case \"system\":\n if (content.length !== 1 || content[0]!.type !== \"text\")\n throw new Error(\n \"System messages must have exactly one text content part.\",\n );\n\n return {\n ...common,\n role,\n content: content as [TextContentPart],\n } satisfies ThreadSystemMessage;\n\n default: {\n const unsupportedRole: never = role;\n throw new Error(`Unknown message role: ${unsupportedRole}`);\n }\n }\n};\n","import type { TextContentPart, ThreadMessage } from \"../types/AssistantTypes\";\n\nexport const getThreadMessageText = (message: ThreadMessage) => {\n const textParts = message.content.filter(\n (part) => part.type === \"text\",\n ) as TextContentPart[];\n\n return textParts.map((part) => part.text).join(\"\\n\\n\");\n};\n","import { ReactThreadRuntime } from \"../core\";\nimport { MessageRepository } from \"../utils/MessageRepository\";\nimport { AppendMessage, ThreadMessage, Unsubscribe } from \"../../types\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\nimport { AddToolResultOptions } from \"../../context\";\nimport {\n getExternalStoreMessage,\n symbolInnerMessage,\n} from \"./getExternalStoreMessage\";\nimport { ThreadMessageConverter } from \"./ThreadMessageConverter\";\nimport { getAutoStatus, isAutoStatus } from \"./auto-status\";\nimport { fromThreadMessageLike } from \"./ThreadMessageLike\";\nimport { RuntimeCapabilities } from \"../../context/stores/Thread\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\nimport { generateId } from \"../../internal\";\n\nexport const hasUpcomingMessage = (\n isRunning: boolean,\n messages: ThreadMessage[],\n) => {\n return isRunning && messages[messages.length - 1]?.role !== \"assistant\";\n};\n\nexport class ExternalStoreThreadRuntime implements ReactThreadRuntime {\n private _subscriptions = new Set<() => void>();\n private repository = new MessageRepository();\n private assistantOptimisticId: string | null = null;\n\n private _capabilities: RuntimeCapabilities = {\n switchToBranch: false,\n edit: false,\n reload: false,\n cancel: false,\n unstable_copy: false,\n speak: false,\n };\n\n public get capabilities() {\n return this._capabilities;\n }\n\n public threadId!: string;\n public messages!: ThreadMessage[];\n public isDisabled!: boolean;\n public converter = new ThreadMessageConverter();\n\n private _store!: ExternalStoreAdapter<any>;\n\n public readonly composer = {\n text: \"\",\n setText: (value: string) => {\n this.composer.text = value;\n this.notifySubscribers();\n },\n };\n\n constructor(store: ExternalStoreAdapter<any>) {\n this.store = store;\n }\n\n public get store() {\n return this._store;\n }\n\n public set store(store: ExternalStoreAdapter<any>) {\n if (this._store === store) return;\n\n this.threadId = store.threadId ?? this.threadId ?? generateId();\n const isRunning = store.isRunning ?? false;\n this.isDisabled = store.isDisabled ?? false;\n\n const oldStore = this._store as ExternalStoreAdapter<any> | undefined;\n this._store = store;\n this._capabilities = {\n switchToBranch: this._store.setMessages !== undefined,\n edit: this._store.onEdit !== undefined,\n reload: this._store.onReload !== undefined,\n cancel: this._store.onCancel !== undefined,\n unstable_copy: this._store.unstable_capabilities?.copy !== null,\n speak: this._store.onSpeak !== undefined,\n };\n\n if (oldStore) {\n // flush the converter cache when the convertMessage prop changes\n if (oldStore.convertMessage !== store.convertMessage) {\n this.converter = new ThreadMessageConverter();\n } else if (\n oldStore.isRunning === store.isRunning &&\n oldStore.messages === store.messages\n ) {\n this.notifySubscribers();\n // no conversion update\n return;\n }\n }\n\n const messages = !store.convertMessage\n ? store.messages\n : this.converter.convertMessages(store.messages, (cache, m, idx) => {\n if (!store.convertMessage) return m;\n\n const isLast = idx === store.messages.length - 1;\n const autoStatus = getAutoStatus(isLast, isRunning);\n\n if (\n cache &&\n (cache.role !== \"assistant\" ||\n !isAutoStatus(cache.status) ||\n cache.status === autoStatus)\n )\n return cache;\n\n const newMessage = fromThreadMessageLike(\n store.convertMessage(m, idx),\n idx.toString(),\n autoStatus,\n );\n (newMessage as any)[symbolInnerMessage] = m;\n return newMessage;\n });\n\n for (let i = 0; i < messages.length; i++) {\n const message = messages[i]!;\n const parent = messages[i - 1];\n this.repository.addOrUpdateMessage(parent?.id ?? null, message);\n }\n\n if (this.assistantOptimisticId) {\n this.repository.deleteMessage(this.assistantOptimisticId);\n this.assistantOptimisticId = null;\n }\n\n if (hasUpcomingMessage(isRunning, messages)) {\n this.assistantOptimisticId = this.repository.appendOptimisticMessage(\n messages.at(-1)?.id ?? null,\n {\n role: \"assistant\",\n content: [],\n },\n );\n }\n\n this.repository.resetHead(\n this.assistantOptimisticId ?? messages.at(-1)?.id ?? null,\n );\n\n this.messages = this.repository.getMessages();\n this.notifySubscribers();\n }\n\n private notifySubscribers() {\n for (const callback of this._subscriptions) callback();\n }\n\n public getBranches(messageId: string): string[] {\n return this.repository.getBranches(messageId);\n }\n\n public switchToBranch(branchId: string): void {\n if (!this._store.setMessages)\n throw new Error(\"Runtime does not support switching branches.\");\n\n this.repository.switchToBranch(branchId);\n this.updateMessages(this.repository.getMessages());\n }\n\n public async append(message: AppendMessage): Promise<void> {\n if (message.parentId !== (this.messages.at(-1)?.id ?? null)) {\n if (!this._store.onEdit)\n throw new Error(\"Runtime does not support editing messages.\");\n await this._store.onEdit(message);\n } else {\n await this._store.onNew(message);\n }\n }\n\n public async startRun(parentId: string | null): Promise<void> {\n if (!this._store.onReload)\n throw new Error(\"Runtime does not support reloading messages.\");\n\n await this._store.onReload(parentId);\n }\n\n public cancelRun(): void {\n if (!this._store.onCancel)\n throw new Error(\"Runtime does not support cancelling runs.\");\n\n this._store.onCancel();\n\n if (this.assistantOptimisticId) {\n this.repository.deleteMessage(this.assistantOptimisticId);\n this.assistantOptimisticId = null;\n }\n\n let messages = this.repository.getMessages();\n const previousMessage = messages[messages.length - 1];\n if (\n previousMessage?.role === \"user\" &&\n previousMessage.id === messages.at(-1)?.id // ensure the previous message is a leaf node\n ) {\n this.repository.deleteMessage(previousMessage.id);\n if (!this.composer.text.trim()) {\n this.composer.setText(getThreadMessageText(previousMessage));\n }\n\n messages = this.repository.getMessages();\n } else {\n this.notifySubscribers();\n }\n\n // resync messages (for reloading, to restore the previous branch)\n setTimeout(() => {\n this.updateMessages(messages);\n }, 0);\n }\n\n public addToolResult(options: AddToolResultOptions) {\n if (!this._store.onAddToolResult)\n throw new Error(\"Runtime does not support tool results.\");\n this._store.onAddToolResult(options);\n }\n\n public speak(messageId: string) {\n if (!this._store.onSpeak)\n throw new Error(\"Runtime does not support speaking.\");\n\n const { message } = this.repository.getMessage(messageId);\n return this._store.onSpeak(message);\n }\n\n public subscribe(callback: () => void): Unsubscribe {\n this._subscriptions.add(callback);\n return () => this._subscriptions.delete(callback);\n }\n\n private updateMessages = (messages: ThreadMessage[]) => {\n this._store.setMessages?.(\n messages.flatMap(getExternalStoreMessage).filter((m) => m != null),\n );\n };\n}\n","import { BaseAssistantRuntime, ProxyConfigProvider } from \"../../internal\";\nimport { ModelConfigProvider } from \"../../types\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\nimport { ExternalStoreThreadRuntime } from \"./ExternalStoreThreadRuntime\";\n\nexport class ExternalStoreRuntime extends BaseAssistantRuntime<ExternalStoreThreadRuntime> {\n private readonly _proxyConfigProvider = new ProxyConfigProvider();\n\n constructor(store: ExternalStoreAdapter<any>) {\n super(new ExternalStoreThreadRuntime(store));\n }\n\n public get store() {\n return this.thread.store;\n }\n\n public set store(store: ExternalStoreAdapter<any>) {\n this.thread.store = store;\n }\n\n public getModelConfig() {\n return this._proxyConfigProvider.getModelConfig();\n }\n\n public registerModelConfigProvider(provider: ModelConfigProvider) {\n return this._proxyConfigProvider.registerModelConfigProvider(provider);\n }\n\n public async switchToThread(threadId: string | null) {\n if (threadId) {\n if (!this.store.onSwitchThread)\n throw new Error(\"Runtime does not support switching threads.\");\n\n this.thread = new ExternalStoreThreadRuntime({\n messages: [],\n onNew: this.store.onNew,\n });\n this.store.onSwitchThread(threadId);\n } else {\n if (!this.store.onNewThread)\n throw new Error(\"Runtime does not support switching to new threads.\");\n\n this.thread = new ExternalStoreThreadRuntime({\n messages: [],\n onNew: this.store.onNew,\n });\n await this.store.onNewThread();\n }\n }\n}\n","import { useEffect, useState } from \"react\";\nimport { ExternalStoreRuntime } from \"./ExternalStoreRuntime\";\nimport { ExternalStoreAdapter } from \"./ExternalStoreAdapter\";\n\nexport const useExternalStoreRuntime = <T,>(store: ExternalStoreAdapter<T>) => {\n const [runtime] = useState(() => new ExternalStoreRuntime(store));\n\n useEffect(() => {\n runtime.store = store;\n });\n\n return runtime;\n};\n","import { useMemo } from \"react\";\nimport { ThreadMessageConverter } from \"./ThreadMessageConverter\";\nimport {\n getExternalStoreMessage,\n symbolInnerMessage,\n} from \"./getExternalStoreMessage\";\nimport { fromThreadMessageLike, ThreadMessageLike } from \"./ThreadMessageLike\";\nimport { getAutoStatus, isAutoStatus } from \"./auto-status\";\nimport { ToolCallContentPart } from \"../../types\";\n\nexport namespace useExternalMessageConverter {\n export type Message =\n | ThreadMessageLike\n | {\n role: \"tool\";\n toolCallId: string;\n toolName?: string | undefined;\n result: any;\n };\n\n export type Callback<T> = (message: T) => Message | Message[];\n}\n\ntype CallbackResult<T> = {\n input: T;\n outputs: useExternalMessageConverter.Message[];\n};\n\ntype ChunkResult<T> = {\n inputs: T[];\n outputs: useExternalMessageConverter.Message[];\n};\n\nconst joinExternalMessages = (\n messages: useExternalMessageConverter.Message[],\n): ThreadMessageLike => {\n const assistantMessage: ThreadMessageLike & { content: any[] } = {\n role: \"assistant\",\n content: [],\n };\n for (const output of messages) {\n if (output.role === \"tool\") {\n const toolCallIdx = assistantMessage.content.findIndex(\n (c) => c.type === \"tool-call\" && c.toolCallId === output.toolCallId,\n );\n if (toolCallIdx !== -1) {\n const toolCall = assistantMessage.content[\n toolCallIdx\n ]! as ToolCallContentPart;\n if (output.toolName) {\n if (toolCall.toolName !== output.toolName)\n throw new Error(\n `Tool call name ${output.toolCallId} ${output.toolName} does not match existing tool call ${toolCall.toolName}`,\n );\n }\n assistantMessage.content[toolCallIdx] = {\n ...toolCall,\n result: output.result,\n };\n } else {\n throw new Error(\n `Tool call ${output.toolCallId} ${output.toolName} not found in assistant message`,\n );\n }\n } else {\n const content = output.content;\n const role = output.role;\n switch (role) {\n case \"system\":\n case \"user\":\n return { role, content };\n case \"assistant\":\n if (assistantMessage.content.length === 0) {\n assistantMessage.id = output.id;\n assistantMessage.createdAt ??= output.createdAt;\n assistantMessage.status ??= output.status;\n // TODO keep this in sync\n }\n assistantMessage.content.push(...content);\n break;\n default: {\n const unsupportedRole: never = role;\n throw new Error(`Unknown message role: ${unsupportedRole}`);\n }\n }\n }\n }\n return assistantMessage;\n};\n\nconst chunkExternalMessages = <T,>(callbackResults: CallbackResult<T>[]) => {\n const results: ChunkResult<T>[] = [];\n let isAssistant = false;\n let inputs: T[] = [];\n let outputs: useExternalMessageConverter.Message[] = [];\n\n const flush = () => {\n if (outputs.length) {\n results.push({\n inputs,\n outputs,\n });\n }\n inputs = [];\n outputs = [];\n };\n\n for (const callbackResult of callbackResults) {\n for (const output of callbackResult.outputs) {\n if (!isAssistant || output.role === \"user\" || output.role === \"system\") {\n flush();\n }\n isAssistant = output.role === \"assistant\" || output.role === \"tool\";\n\n if (inputs.at(-1) !== callbackResult.input) {\n inputs.push(callbackResult.input);\n }\n outputs.push(output);\n }\n }\n flush();\n return results;\n};\n\nexport const useExternalMessageConverter = <T extends WeakKey>({\n callback,\n messages,\n isRunning,\n}: {\n callback: useExternalMessageConverter.Callback<T>;\n messages: T[];\n isRunning: boolean;\n}) => {\n const state = useMemo(\n () => ({\n callback,\n callbackCache: new WeakMap<T, CallbackResult<T>>(),\n chunkCache: new WeakMap<\n useExternalMessageConverter.Message,\n ChunkResult<T>\n >(),\n converterCache: new ThreadMessageConverter(),\n }),\n [callback],\n );\n\n return useMemo(() => {\n const callbackResults: CallbackResult<T>[] = [];\n for (const message of messages) {\n let result = state.callbackCache.get(message);\n if (!result) {\n const output = state.callback(message);\n const outputs = Array.isArray(output) ? output : [output];\n result = { input: message, outputs };\n state.callbackCache.set(message, result);\n }\n callbackResults.push(result);\n }\n\n const chunks = chunkExternalMessages(callbackResults).map((m) => {\n const key = m.outputs[0];\n if (!key) return m;\n\n const cached = state.chunkCache.get(key);\n if (cached && shallowArrayEqual(cached.outputs, m.outputs)) return cached;\n state.chunkCache.set(key, m);\n return m;\n });\n\n return state.converterCache.convertMessages(\n chunks,\n (cache, message, idx) => {\n const isLast = idx === chunks.length - 1;\n const autoStatus = getAutoStatus(isLast, isRunning);\n\n if (\n cache &&\n (cache.role !== \"assistant\" ||\n !isAutoStatus(cache.status) ||\n cache.status === autoStatus)\n ) {\n const inputs = getExternalStoreMessage(cache) as T[];\n if (shallowArrayEqual(inputs, message.inputs)) {\n return cache;\n }\n }\n\n const newMessage = fromThreadMessageLike(\n joinExternalMessages(message.outputs),\n idx.toString(),\n autoStatus,\n );\n (newMessage as any)[symbolInnerMessage] = message.inputs;\n return newMessage;\n },\n );\n }, [state, messages, isRunning]);\n};\n\nconst shallowArrayEqual = (a: unknown[], b: unknown[]) => {\n if (a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n};\n","import { LocalRuntimeOptions, useLocalRuntime } from \"..\";\nimport { useState } from \"react\";\nimport {\n DangerousInBrowserAdapter,\n DangerousInBrowserAdapterOptions,\n} from \"./DangerousInBrowserAdapter\";\n\nexport type DangerousInBrowserRuntimeOptions =\n DangerousInBrowserAdapterOptions & LocalRuntimeOptions;\n\nexport const useDangerousInBrowserRuntime = ({\n initialMessages,\n ...options\n}: DangerousInBrowserRuntimeOptions) => {\n const [adapter] = useState(() => new DangerousInBrowserAdapter(options));\n return useLocalRuntime(adapter, { initialMessages });\n};\n","import { ChatModelAdapter, ChatModelRunOptions } from \"../local\";\nimport { toCoreMessages } from \"../edge/converters/toCoreMessages\";\nimport { toLanguageModelTools } from \"../edge/converters/toLanguageModelTools\";\nimport { EdgeRuntimeRequestOptions } from \"../edge/EdgeRuntimeRequestOptions\";\nimport { runResultStream } from \"../edge/streams/runResultStream\";\nimport { toolResultStream } from \"../edge/streams/toolResultStream\";\nimport { asAsyncIterable } from \"../edge/EdgeChatAdapter\";\nimport {\n CreateEdgeRuntimeAPIOptions,\n getEdgeRuntimeStream,\n} from \"../edge/createEdgeRuntimeAPI\";\n\nexport type DangerousInBrowserAdapterOptions = CreateEdgeRuntimeAPIOptions;\n\nexport class DangerousInBrowserAdapter implements ChatModelAdapter {\n constructor(private options: DangerousInBrowserAdapterOptions) {}\n\n async *run({ messages, abortSignal, config }: ChatModelRunOptions) {\n const res = await getEdgeRuntimeStream({\n options: this.options,\n abortSignal,\n requestData: {\n system: config.system,\n messages: toCoreMessages(messages),\n tools: config.tools ? toLanguageModelTools(config.tools) : [],\n ...config.callSettings,\n ...config.config,\n } satisfies EdgeRuntimeRequestOptions,\n });\n\n const stream = res\n .pipeThrough(toolResultStream(config.tools, abortSignal))\n .pipeThrough(runResultStream());\n\n for await (const update of asAsyncIterable(stream)) {\n yield update;\n }\n }\n}\n","import { ThreadMessage } from \"../../types\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\nimport { SpeechSynthesisAdapter } from \"./SpeechAdapterTypes\";\n\nexport class WebSpeechSynthesisAdapter implements SpeechSynthesisAdapter {\n speak(message: ThreadMessage): SpeechSynthesisAdapter.Utterance {\n const text = getThreadMessageText(message);\n const utterance = new SpeechSynthesisUtterance(text);\n\n const endHandlers = new Set<() => void>();\n const handleEnd = (\n reason: \"finished\" | \"error\" | \"cancelled\",\n error?: unknown,\n ) => {\n if (res.status.type === \"ended\") return;\n\n res.status = { type: \"ended\", reason, error };\n endHandlers.forEach((handler) => handler());\n };\n\n utterance.addEventListener(\"end\", () => handleEnd(\"finished\"));\n utterance.addEventListener(\"error\", (e) => handleEnd(\"error\", e.error));\n\n window.speechSynthesis.speak(utterance);\n\n const res: SpeechSynthesisAdapter.Utterance = {\n status: { type: \"running\" },\n cancel: () => {\n window.speechSynthesis.cancel();\n handleEnd(\"cancelled\");\n },\n onEnd: (callback) => {\n if (res.status.type === \"ended\") {\n let cancelled = false;\n queueMicrotask(() => {\n if (!cancelled) callback();\n });\n return () => {\n cancelled = true;\n };\n } else {\n endHandlers.add(callback);\n return () => {\n endHandlers.delete(callback);\n };\n }\n },\n };\n return res;\n }\n}\n","import { create } from \"zustand\";\nimport { AssistantRuntime } from \"../../runtimes\";\nimport { MutableRefObject } from \"react\";\n\nexport type AssistantActionsState = Readonly<{\n switchToThread: (threadId: string | null) => void;\n getRuntime: () => AssistantRuntime;\n}>;\n\nexport const makeAssistantActionsStore = (\n runtimeRef: MutableRefObject<AssistantRuntime>,\n) =>\n create<AssistantActionsState>(() =>\n Object.freeze({\n switchToThread: () => runtimeRef.current.switchToThread(null),\n getRuntime: () => runtimeRef.current,\n }),\n );\n","import { create } from \"zustand\";\nimport { AssistantRuntime } from \"../../runtimes\";\n\nexport type AssistantRuntimeStore = AssistantRuntime;\n\nexport const makeAssistantRuntimeStore = (runtime: AssistantRuntime) => {\n return create<AssistantRuntimeStore>(() => runtime);\n};\n","import { useMemo } from \"react\";\nimport { useMessageContext } from \"./MessageContext\";\nimport { useThreadContext } from \"./ThreadContext\";\nimport type { ComposerState } from \"../stores/Composer\";\nimport type { EditComposerState } from \"../stores/EditComposer\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type ComposerContextValue = {\n useComposer: ReadonlyStore<EditComposerState | ComposerState>;\n type: \"edit\" | \"new\";\n};\n\nexport const useComposerContext = (): ComposerContextValue => {\n const { useComposer } = useThreadContext();\n const { useEditComposer } = useMessageContext({ optional: true }) ?? {};\n return useMemo(\n () => ({\n useComposer: (useEditComposer ?? useComposer) as ReadonlyStore<\n EditComposerState | ComposerState\n >,\n type: useEditComposer ? (\"edit\" as const) : (\"new\" as const),\n }),\n [useEditComposer, useComposer],\n );\n};\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { MessageState } from \"../stores/Message\";\nimport type { EditComposerState } from \"../stores/EditComposer\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\nimport { MessageUtilsState } from \"../stores/MessageUtils\";\n\nexport type MessageContextValue = {\n useMessage: ReadonlyStore<MessageState>;\n useMessageUtils: ReadonlyStore<MessageUtilsState>;\n useEditComposer: ReadonlyStore<EditComposerState>;\n};\n\nexport const MessageContext = createContext<MessageContextValue | null>(null);\n\nexport function useMessageContext(): MessageContextValue;\nexport function useMessageContext(options: {\n optional: true;\n}): MessageContextValue | null;\nexport function useMessageContext(options?: { optional: true }) {\n const context = useContext(MessageContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component can only be used inside a component passed to <ThreadPrimitive.Messages components={...} />.\",\n );\n return context;\n}\n","\"use client\";\n\nimport { createContext, useContext } from \"react\";\nimport type { ContentPartState } from \"../stores/ContentPart\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type ContentPartContextValue = {\n useContentPart: ReadonlyStore<ContentPartState>;\n};\n\nexport const ContentPartContext = createContext<ContentPartContextValue | null>(\n null,\n);\n\nexport function useContentPartContext(): ContentPartContextValue;\nexport function useContentPartContext(options: {\n optional: true;\n}): ContentPartContextValue | null;\nexport function useContentPartContext(options?: { optional: true }) {\n const context = useContext(ContentPartContext);\n if (!options?.optional && !context)\n throw new Error(\n \"This component can only be used inside a component passed to <MessagePrimitive.Content components={...} >.\",\n );\n return context;\n}\n","import { useCallback } from \"react\";\nimport { ThreadContextValue, useThreadContext } from \"../context\";\nimport { AppendMessage } from \"../types\";\n\ntype CreateAppendMessage =\n | string\n | {\n parentId?: string | null | undefined;\n role?: AppendMessage[\"role\"] | undefined;\n content: AppendMessage[\"content\"];\n };\n\nconst toAppendMessage = (\n useThreadMessages: ThreadContextValue[\"useThreadMessages\"],\n message: CreateAppendMessage,\n): AppendMessage => {\n if (typeof message === \"string\") {\n return {\n parentId: useThreadMessages.getState().at(-1)?.id ?? null,\n role: \"user\",\n content: [{ type: \"text\", text: message }],\n };\n }\n\n return {\n parentId:\n message.parentId ?? useThreadMessages.getState().at(-1)?.id ?? null,\n role: message.role ?? \"user\",\n content: message.content,\n } as AppendMessage;\n};\n\nexport const useAppendMessage = () => {\n const { useThreadMessages, useThreadActions, useViewport, useComposer } =\n useThreadContext();\n\n const append = useCallback(\n (message: CreateAppendMessage) => {\n const appendMessage = toAppendMessage(useThreadMessages, message);\n useThreadActions.getState().append(appendMessage);\n\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n },\n [useThreadMessages, useThreadActions, useViewport, useComposer],\n );\n\n return append;\n};\n","import { useCallback } from \"react\";\nimport { useAssistantContext, useThreadContext } from \"../context\";\n\nexport const useSwitchToNewThread = () => {\n const { useAssistantActions } = useAssistantContext();\n const { useComposer } = useThreadContext();\n\n const switchToNewThread = useCallback(() => {\n useAssistantActions.getState().switchToThread(null);\n useComposer.getState().focus();\n }, [useAssistantActions, useComposer]);\n\n return switchToNewThread;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\nimport type { ToolCallContentPartComponent } from \"../types/ContentPartComponentTypes\";\nimport type { Tool } from \"../types/ModelConfigTypes\";\n\nexport type AssistantToolProps<\n TArgs extends Record<string, unknown>,\n TResult,\n> = Tool<TArgs, TResult> & {\n toolName: string;\n render?: ToolCallContentPartComponent<TArgs, TResult> | undefined;\n};\n\nexport const useAssistantTool = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolProps<TArgs, TResult>,\n) => {\n const { useModelConfig, useToolUIs } = useAssistantContext();\n const registerModelConfigProvider = useModelConfig(\n (s) => s.registerModelConfigProvider,\n );\n const setToolUI = useToolUIs((s) => s.setToolUI);\n useEffect(() => {\n const { toolName, render, ...rest } = tool;\n const config = {\n tools: {\n [tool.toolName]: rest,\n },\n };\n const unsub1 = registerModelConfigProvider({\n getModelConfig: () => config,\n });\n const unsub2 = render ? setToolUI(toolName, render) : undefined;\n return () => {\n unsub1();\n unsub2?.();\n };\n }, [registerModelConfigProvider, setToolUI, tool]);\n};\n","\"use client\";\nimport { FC } from \"react\";\nimport { type AssistantToolProps, useAssistantTool } from \"./useAssistantTool\";\n\nexport type AssistantTool = FC & {\n unstable_tool: AssistantToolProps<any, any>;\n};\n\nexport const makeAssistantTool = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolProps<TArgs, TResult>,\n) => {\n const Tool: AssistantTool = () => {\n useAssistantTool(tool);\n return null;\n };\n Tool.unstable_tool = tool;\n return Tool;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\nimport type { ToolCallContentPartComponent } from \"../types/ContentPartComponentTypes\";\n\nexport type AssistantToolUIProps<\n TArgs extends Record<string, unknown>,\n TResult,\n> = {\n toolName: string;\n render: ToolCallContentPartComponent<TArgs, TResult>;\n};\n\nexport const useAssistantToolUI = (\n tool: AssistantToolUIProps<any, any> | null,\n) => {\n const { useToolUIs } = useAssistantContext();\n const setToolUI = useToolUIs((s) => s.setToolUI);\n useEffect(() => {\n if (!tool) return;\n const { toolName, render } = tool;\n return setToolUI(toolName, render);\n }, [setToolUI, tool]);\n};\n","\"use client\";\nimport { FC } from \"react\";\nimport {\n type AssistantToolUIProps,\n useAssistantToolUI,\n} from \"./useAssistantToolUI\";\n\nexport type AssistantToolUI = FC & {\n unstable_tool: AssistantToolUIProps<any, any>;\n};\n\nexport const makeAssistantToolUI = <\n TArgs extends Record<string, unknown>,\n TResult,\n>(\n tool: AssistantToolUIProps<TArgs, TResult>,\n) => {\n const ToolUI: AssistantToolUI = () => {\n useAssistantToolUI(tool);\n return null;\n };\n ToolUI.unstable_tool = tool;\n return ToolUI;\n};\n","\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useAssistantContext } from \"../context/react/AssistantContext\";\n\nexport const useAssistantInstructions = (instruction: string) => {\n const { useModelConfig } = useAssistantContext();\n const registerModelConfigProvider = useModelConfig(\n (s) => s.registerModelConfigProvider,\n );\n useEffect(() => {\n const config = {\n system: instruction,\n };\n return registerModelConfigProvider({ getModelConfig: () => config });\n }, [registerModelConfigProvider, instruction]);\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\n\nexport type UseActionBarCopyProps = {\n copiedDuration?: number | undefined;\n};\n\nexport const useActionBarCopy = ({\n copiedDuration = 3000,\n}: UseActionBarCopyProps = {}) => {\n const { useMessage, useMessageUtils, useEditComposer } = useMessageContext();\n\n const hasCopyableContent = useCombinedStore(\n [useMessage, useEditComposer],\n ({ message }, c) => {\n return (\n !c.isEditing &&\n (message.role !== \"assistant\" || message.status.type !== \"running\") &&\n message.content.some((c) => c.type === \"text\" && c.text.length > 0)\n );\n },\n );\n\n const callback = useCallback(() => {\n const { message } = useMessage.getState();\n const { setIsCopied } = useMessageUtils.getState();\n const { isEditing, text: composerValue } = useEditComposer.getState();\n\n const valueToCopy = isEditing\n ? composerValue\n : getThreadMessageText(message);\n\n navigator.clipboard.writeText(valueToCopy).then(() => {\n setIsCopied(true);\n setTimeout(() => setIsCopied(false), copiedDuration);\n });\n }, [useMessage, useMessageUtils, useEditComposer, copiedDuration]);\n\n if (!hasCopyableContent) return null;\n return callback;\n};\n","import { useMemo } from \"react\";\nimport {\n type CombinedSelector,\n createCombinedStore,\n} from \"./createCombinedStore\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\n\nexport const useCombinedStore = <T extends Array<unknown>, R>(\n stores: { [K in keyof T]: ReadonlyStore<T[K]> },\n selector: CombinedSelector<T, R>,\n): R => {\n // eslint-disable-next-line react-hooks/exhaustive-deps -- shallow-compare the store array\n const useCombined = useMemo(() => createCombinedStore<T, R>(stores), stores);\n return useCombined(selector);\n};\n","\"use client\";\n\nimport { useSyncExternalStore } from \"react\";\nimport type { Unsubscribe } from \"../../types/Unsubscribe\";\nimport { ReadonlyStore } from \"../../context/ReadonlyStore\";\n\nexport type CombinedSelector<T extends Array<unknown>, R> = (...args: T) => R;\n\nexport const createCombinedStore = <T extends Array<unknown>, R>(stores: {\n [K in keyof T]: ReadonlyStore<T[K]>;\n}) => {\n const subscribe = (callback: () => void): Unsubscribe => {\n const unsubscribes = stores.map((store) => store.subscribe(callback));\n return () => {\n for (const unsub of unsubscribes) {\n unsub();\n }\n };\n };\n\n return (selector: CombinedSelector<T, R>): R => {\n const getSnapshot = (): R =>\n selector(...(stores.map((store) => store.getState()) as T));\n\n return useSyncExternalStore(subscribe, getSnapshot, getSnapshot);\n };\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarEdit = () => {\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) => m.message.role !== \"user\" || c.isEditing,\n );\n\n const callback = useCallback(() => {\n const { edit } = useEditComposer.getState();\n edit();\n }, [useEditComposer]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarReload = () => {\n const { useThread, useThreadActions, useComposer, useViewport } =\n useThreadContext();\n const { useMessage } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useThread, useMessage],\n (t, m) => t.isRunning || t.isDisabled || m.message.role !== \"assistant\",\n );\n\n const callback = useCallback(() => {\n const { parentId } = useMessage.getState();\n useThreadActions.getState().startRun(parentId);\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n }, [useThreadActions, useComposer, useViewport, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useActionBarSpeak = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer, useMessageUtils } = useMessageContext();\n\n const hasSpeakableContent = useCombinedStore(\n [useMessage, useEditComposer],\n ({ message }, c) => {\n return (\n !c.isEditing &&\n (message.role !== \"assistant\" || message.status.type !== \"running\") &&\n message.content.some((c) => c.type === \"text\" && c.text.length > 0)\n );\n },\n );\n\n const callback = useCallback(async () => {\n const { message } = useMessage.getState();\n const utt = useThreadActions.getState().speak(message.id);\n useMessageUtils.getState().addUtterance(utt);\n }, [useThreadActions, useMessage, useMessageUtils]);\n\n if (!hasSpeakableContent) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useActionBarStopSpeaking = () => {\n const { useMessageUtils } = useMessageContext();\n\n const isSpeaking = useMessageUtils((u) => u.isSpeaking);\n\n const callback = useCallback(async () => {\n useMessageUtils.getState().stopSpeaking();\n }, [useMessageUtils]);\n\n if (!isSpeaking) return null;\n\n return callback;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useBranchPickerCount = () => {\n const { useMessage } = useMessageContext();\n const branchCount = useMessage((s) => s.branches.length);\n return branchCount;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useBranchPickerNext = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) =>\n c.isEditing || m.branches.indexOf(m.message.id) + 1 >= m.branches.length,\n );\n\n const callback = useCallback(() => {\n const { message, branches } = useMessage.getState();\n useThreadActions\n .getState()\n .switchToBranch(branches[branches.indexOf(message.id) + 1]!);\n }, [useThreadActions, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\n\nexport const useBranchPickerNumber = () => {\n const { useMessage } = useMessageContext();\n const branchIdx = useMessage((s) => s.branches.indexOf(s.message.id));\n return branchIdx + 1;\n};\n","import { useCallback } from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useBranchPickerPrevious = () => {\n const { useThreadActions } = useThreadContext();\n const { useMessage, useEditComposer } = useMessageContext();\n\n const disabled = useCombinedStore(\n [useMessage, useEditComposer],\n (m, c) => c.isEditing || m.branches.indexOf(m.message.id) <= 0,\n );\n\n const callback = useCallback(() => {\n const { message, branches } = useMessage.getState();\n useThreadActions\n .getState()\n .switchToBranch(branches[branches.indexOf(message.id) - 1]!);\n }, [useThreadActions, useMessage]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useCallback } from \"react\";\nimport { useComposerContext } from \"../../context\";\n\nexport const useComposerCancel = () => {\n const { useComposer } = useComposerContext();\n\n const disabled = useComposer((c) => !c.canCancel);\n\n const callback = useCallback(() => {\n const { cancel } = useComposer.getState();\n cancel();\n }, [useComposer]);\n\n if (disabled) return null;\n return callback;\n};\n","\"use client\";\nimport { useComposerContext } from \"../../context/react/ComposerContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\n\ntype ComposerIfFilters = {\n editing: boolean | undefined;\n};\n\nexport type UseComposerIfProps = RequireAtLeastOne<ComposerIfFilters>;\n\nexport const useComposerIf = (props: UseComposerIfProps) => {\n const { useComposer } = useComposerContext();\n return useComposer((composer) => {\n if (props.editing === true && !composer.isEditing) return false;\n if (props.editing === false && composer.isEditing) return false;\n\n return true;\n });\n};\n","import { useCallback } from \"react\";\nimport { useComposerContext, useThreadContext } from \"../../context\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport const useComposerSend = () => {\n const {\n useThread,\n useViewport,\n useComposer: useNewComposer,\n } = useThreadContext();\n const { useComposer } = useComposerContext();\n\n const disabled = useCombinedStore(\n [useThread, useComposer],\n (t, c) => t.isRunning || !c.isEditing || c.text.length === 0,\n );\n\n const callback = useCallback(() => {\n const composerState = useComposer.getState();\n if (!composerState.isEditing) return;\n\n composerState.send();\n\n useViewport.getState().scrollToBottom();\n useNewComposer.getState().focus();\n }, [useNewComposer, useComposer, useViewport]);\n\n if (disabled) return null;\n return callback;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { UIContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartDisplay = () => {\n const { useContentPart } = useContentPartContext();\n\n const display = useContentPart((c) => {\n if (c.part.type !== \"ui\")\n throw new Error(\n \"This component can only be used inside ui content parts.\",\n );\n\n return c as UIContentPartState;\n });\n\n return display;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { ImageContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartImage = () => {\n const { useContentPart } = useContentPartContext();\n\n const image = useContentPart((c) => {\n if (c.part.type !== \"image\")\n throw new Error(\n \"ContentPartImage can only be used inside image content parts.\",\n );\n\n return c as ImageContentPartState;\n });\n\n return image;\n};\n","import { useContentPartContext } from \"../../context/react/ContentPartContext\";\nimport { TextContentPartState } from \"../../context/stores/ContentPart\";\n\nexport const useContentPartText = () => {\n const { useContentPart } = useContentPartContext();\n\n const text = useContentPart((c) => {\n if (c.part.type !== \"text\")\n throw new Error(\n \"ContentPartText can only be used inside text content parts.\",\n );\n\n return c as TextContentPartState;\n });\n\n return text;\n};\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\ntype MessageIfFilters = {\n user: boolean | undefined;\n assistant: boolean | undefined;\n system: boolean | undefined;\n hasBranches: boolean | undefined;\n copied: boolean | undefined;\n lastOrHover: boolean | undefined;\n speaking: boolean | undefined;\n};\nexport type UseMessageIfProps = RequireAtLeastOne<MessageIfFilters>;\n\nexport const useMessageIf = (props: UseMessageIfProps) => {\n const { useMessage, useMessageUtils } = useMessageContext();\n\n return useCombinedStore(\n [useMessage, useMessageUtils],\n ({ message, branches, isLast }, { isCopied, isHovering, isSpeaking }) => {\n if (props.hasBranches === true && branches.length < 2) return false;\n\n if (props.user && message.role !== \"user\") return false;\n if (props.assistant && message.role !== \"assistant\") return false;\n if (props.system && message.role !== \"system\") return false;\n\n if (props.lastOrHover === true && !isHovering && !isLast) return false;\n\n if (props.copied === true && !isCopied) return false;\n if (props.copied === false && isCopied) return false;\n \n if (props.speaking === true && !isSpeaking) return false;\n if (props.speaking === false && isSpeaking) return false;\n\n return true;\n },\n );\n};\n","\"use client\";\n\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport type { RequireAtLeastOne } from \"../../utils/RequireAtLeastOne\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\ntype ThreadIfFilters = {\n empty: boolean | undefined;\n running: boolean | undefined;\n disabled: boolean | undefined;\n};\n\nexport type UseThreadIfProps = RequireAtLeastOne<ThreadIfFilters>;\n\nexport const useThreadIf = (props: UseThreadIfProps) => {\n const { useThread, useThreadMessages } = useThreadContext();\n return useCombinedStore(\n [useThread, useThreadMessages],\n (thread, messages) => {\n if (props.empty === true && messages.length !== 0) return false;\n if (props.empty === false && messages.length === 0) return false;\n if (props.running === true && !thread.isRunning) return false;\n if (props.running === false && thread.isRunning) return false;\n if (props.disabled === true && thread.isDisabled) return false;\n if (props.disabled === false && thread.isDisabled) return false;\n\n return true;\n },\n );\n};\n","import { useThreadIf } from \"./useThreadIf\";\n\nexport const useThreadEmpty = () => {\n return useThreadIf({ empty: true });\n};\n","import { useCallback } from \"react\";\nimport { useThreadContext } from \"../../context\";\n\nexport const useThreadScrollToBottom = () => {\n const { useComposer, useViewport } = useThreadContext();\n\n const isAtBottom = useViewport((s) => s.isAtBottom);\n\n const handleScrollToBottom = useCallback(() => {\n useViewport.getState().scrollToBottom();\n useComposer.getState().focus();\n }, [useViewport, useComposer]);\n\n if (isAtBottom) return null;\n return handleScrollToBottom;\n};\n","import { useCallback } from \"react\";\nimport { useThreadContext } from \"../../context\";\nimport { useAppendMessage } from \"../../hooks\";\n\nexport type UseApplyThreadSuggestionProps = {\n prompt: string;\n method: \"replace\";\n autoSend?: boolean | undefined;\n};\n\nexport const useThreadSuggestion = ({\n prompt,\n autoSend,\n}: UseApplyThreadSuggestionProps) => {\n const { useThread, useComposer } = useThreadContext();\n\n const append = useAppendMessage();\n const disabled = useThread((t) => t.isDisabled);\n const callback = useCallback(() => {\n const thread = useThread.getState();\n const composer = useComposer.getState();\n if (autoSend && !thread.isRunning) {\n append(prompt);\n composer.setText(\"\");\n } else {\n composer.setText(prompt);\n }\n }, [useThread, useComposer, autoSend, append, prompt]);\n\n if (disabled) return null;\n return callback;\n};\n","export { ActionBarPrimitiveRoot as Root } from \"./ActionBarRoot\";\nexport { ActionBarPrimitiveCopy as Copy } from \"./ActionBarCopy\";\nexport { ActionBarPrimitiveReload as Reload } from \"./ActionBarReload\";\nexport { ActionBarPrimitiveEdit as Edit } from \"./ActionBarEdit\";\nexport { ActionBarPrimitiveSpeak as Speak } from \"./ActionBarSpeak\";\nexport { ActionBarPrimitiveStopSpeaking as StopSpeaking } from \"./ActionBarStopSpeaking\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport {\n useActionBarFloatStatus,\n HideAndFloatStatus,\n UseActionBarFloatStatusProps,\n} from \"./useActionBarFloatStatus\";\n\ntype ActionBarPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ActionBarPrimitiveRootProps = PrimitiveDivProps &\n UseActionBarFloatStatusProps;\n\nexport const ActionBarPrimitiveRoot = forwardRef<\n ActionBarPrimitiveRootElement,\n ActionBarPrimitiveRootProps\n>(({ hideWhenRunning, autohide, autohideFloat, ...rest }, ref) => {\n const hideAndfloatStatus = useActionBarFloatStatus({\n hideWhenRunning,\n autohide,\n autohideFloat,\n });\n\n if (hideAndfloatStatus === HideAndFloatStatus.Hidden) return null;\n\n return (\n <Primitive.div\n {...(hideAndfloatStatus === HideAndFloatStatus.Floating\n ? { \"data-floating\": \"true\" }\n : null)}\n {...rest}\n ref={ref}\n />\n );\n});\n\nActionBarPrimitiveRoot.displayName = \"ActionBarPrimitive.Root\";\n","\"use client\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useCombinedStore } from \"../../utils/combined/useCombinedStore\";\n\nexport enum HideAndFloatStatus {\n Hidden = \"hidden\",\n Floating = \"floating\",\n Normal = \"normal\",\n}\n\nexport type UseActionBarFloatStatusProps = {\n hideWhenRunning?: boolean | undefined;\n autohide?: \"always\" | \"not-last\" | \"never\" | undefined;\n autohideFloat?: \"always\" | \"single-branch\" | \"never\" | undefined;\n};\n\nexport const useActionBarFloatStatus = ({\n hideWhenRunning,\n autohide,\n autohideFloat,\n}: UseActionBarFloatStatusProps) => {\n const { useThread } = useThreadContext();\n const { useMessage, useMessageUtils } = useMessageContext();\n\n return useCombinedStore(\n [useThread, useMessage, useMessageUtils],\n (t, m, mu) => {\n if (hideWhenRunning && t.isRunning) return HideAndFloatStatus.Hidden;\n\n const autohideEnabled =\n autohide === \"always\" || (autohide === \"not-last\" && !m.isLast);\n\n // normal status\n if (!autohideEnabled) return HideAndFloatStatus.Normal;\n\n // hidden status\n if (!mu.isHovering) return HideAndFloatStatus.Hidden;\n\n // floating status\n if (\n autohideFloat === \"always\" ||\n (autohideFloat === \"single-branch\" && m.branches.length <= 1)\n )\n return HideAndFloatStatus.Floating;\n\n return HideAndFloatStatus.Normal;\n },\n );\n};\n","\"use client\";\n\nimport { ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\ntype ActionButtonCallback<TProps> = (props: TProps) => null | (() => void);\n\ntype PrimitiveButtonElement = ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\n\nexport type ActionButtonProps<THook> = PrimitiveButtonProps &\n (THook extends (props: infer TProps) => unknown ? TProps : never);\n\nexport const createActionButton = <TProps,>(\n displayName: string,\n useActionButton: ActionButtonCallback<TProps>,\n forwardProps: (keyof NonNullable<TProps>)[] = [],\n) => {\n const ActionButton = forwardRef<\n PrimitiveButtonElement,\n PrimitiveButtonProps & TProps\n >((props, forwardedRef) => {\n const forwardedProps = {} as TProps;\n const primitiveProps = {} as PrimitiveButtonProps;\n\n (Object.keys(props) as Array<keyof typeof props>).forEach((key) => {\n if (forwardProps.includes(key as keyof TProps)) {\n (forwardedProps as any)[key] = props[key];\n } else {\n (primitiveProps as any)[key] = props[key];\n }\n });\n\n const callback = useActionButton(forwardedProps as TProps);\n return (\n <Primitive.button\n type=\"button\"\n disabled={!callback}\n {...primitiveProps}\n ref={forwardedRef}\n onClick={composeEventHandlers(primitiveProps.onClick, () => {\n callback?.();\n })}\n />\n );\n });\n\n ActionButton.displayName = displayName;\n\n return ActionButton;\n};\n","\"use client\";\n\nimport { useActionBarCopy } from \"../../primitive-hooks/actionBar/useActionBarCopy\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveCopyProps = ActionButtonProps<\n typeof useActionBarCopy\n>;\n\nexport const ActionBarPrimitiveCopy = createActionButton(\n \"ActionBarPrimitive.Copy\",\n useActionBarCopy,\n [\"copiedDuration\"],\n);\n","\"use client\";\n\nimport { useActionBarReload } from \"../../primitive-hooks/actionBar/useActionBarReload\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveReloadProps = ActionButtonProps<\n typeof useActionBarReload\n>;\n\nexport const ActionBarPrimitiveReload = createActionButton(\n \"ActionBarPrimitive.Reload\",\n useActionBarReload,\n);\n","\"use client\";\n\nimport { useActionBarEdit } from \"../../primitive-hooks/actionBar/useActionBarEdit\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveEditProps = ActionButtonProps<\n typeof useActionBarEdit\n>;\n\nexport const ActionBarPrimitiveEdit = createActionButton(\n \"ActionBarPrimitive.Edit\",\n useActionBarEdit,\n);\n","\"use client\";\n\nimport { useActionBarSpeak } from \"../../primitive-hooks/actionBar/useActionBarSpeak\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type ActionBarPrimitiveSpeakProps = ActionButtonProps<\n typeof useActionBarSpeak\n>;\n\nexport const ActionBarPrimitiveSpeak = createActionButton(\n \"ActionBarPrimitive.Speak\",\n useActionBarSpeak,\n);\n","\"use client\";\n\nimport { forwardRef } from \"react\";\nimport { useActionBarStopSpeaking } from \"../../primitive-hooks/actionBar/useActionBarStopSpeaking\";\nimport { ActionButtonProps } from \"../../utils/createActionButton\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\nexport type ActionBarPrimitiveStopSpeakingProps = ActionButtonProps<\n typeof useActionBarStopSpeaking\n>;\n\nexport const ActionBarPrimitiveStopSpeaking = forwardRef<\n HTMLButtonElement,\n Partial<ActionBarPrimitiveStopSpeakingProps>\n>((props, ref) => {\n const callback = useActionBarStopSpeaking();\n\n // TODO this stops working if the user is not hovering over an older message\n useEscapeKeydown((e) => {\n if (callback) {\n e.preventDefault();\n callback();\n }\n });\n\n return (\n <Primitive.button\n type=\"button\"\n disabled={!callback}\n {...props}\n ref={ref}\n onClick={composeEventHandlers(props.onClick, () => {\n callback?.();\n })}\n />\n );\n});\n","export { AssistantModalPrimitiveRoot as Root } from \"./AssistantModalRoot\";\nexport { AssistantModalPrimitiveTrigger as Trigger } from \"./AssistantModalTrigger\";\nexport { AssistantModalPrimitiveContent as Content } from \"./AssistantModalContent\";\nexport { AssistantModalPrimitiveAnchor as Anchor } from \"./AssistantModalAnchor\";\n","\"use client\";\n\nimport { FC, useState } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useOnComposerFocus } from \"../../utils/hooks/useOnComposerFocus\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\nexport type AssistantModalPrimitiveRootProps = PopoverPrimitive.PopoverProps;\n\nconst useAssistantModalOpenState = (defaultOpen = false) => {\n const state = useState(defaultOpen);\n\n const [, setOpen] = state;\n useOnComposerFocus(() => {\n setOpen(true);\n });\n\n return state;\n};\n\nexport const AssistantModalPrimitiveRoot: FC<\n AssistantModalPrimitiveRootProps\n> = ({\n __scopeAssistantModal,\n defaultOpen,\n open,\n onOpenChange,\n ...rest\n}: ScopedProps<AssistantModalPrimitiveRootProps>) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n const [modalOpen, setOpen] = useAssistantModalOpenState(defaultOpen);\n\n return (\n <PopoverPrimitive.Root\n {...scope}\n open={open === undefined ? modalOpen : open}\n onOpenChange={composeEventHandlers(onOpenChange, setOpen)}\n {...rest}\n />\n );\n};\n\nAssistantModalPrimitiveRoot.displayName = \"AssistantModalPrimitive.Root\";\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEffect } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\n\nexport const useOnComposerFocus = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const { useComposer } = useThreadContext();\n useEffect(() => {\n return useComposer.getState().onFocus(() => {\n callbackRef();\n });\n }, [useComposer, callbackRef]);\n};\n","import * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport type { Scope } from \"@radix-ui/react-context\";\n\nexport type ScopedProps<P> = P & { __scopeAssistantModal?: Scope };\nexport const usePopoverScope = PopoverPrimitive.createPopoverScope();\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\ntype AssistantModalPrimitiveTriggerElement = ElementRef<\n typeof PopoverPrimitive.Trigger\n>;\nexport type AssistantModalPrimitiveTriggerProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Trigger\n>;\n\nexport const AssistantModalPrimitiveTrigger = forwardRef<\n AssistantModalPrimitiveTriggerElement,\n AssistantModalPrimitiveTriggerProps\n>(\n (\n {\n __scopeAssistantModal,\n ...rest\n }: ScopedProps<AssistantModalPrimitiveTriggerProps>,\n ref,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return <PopoverPrimitive.Trigger {...scope} {...rest} ref={ref} />;\n },\n);\n\nAssistantModalPrimitiveTrigger.displayName = \"AssistantModalPrimitive.Trigger\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\n\ntype AssistantModalPrimitiveContentElement = ElementRef<\n typeof PopoverPrimitive.Content\n>;\nexport type AssistantModalPrimitiveContentProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Content\n> & {\n dissmissOnInteractOutside?: boolean | undefined;\n};\n\nexport const AssistantModalPrimitiveContent = forwardRef<\n AssistantModalPrimitiveContentElement,\n AssistantModalPrimitiveContentProps\n>(\n (\n {\n __scopeAssistantModal,\n side,\n align,\n onInteractOutside,\n dissmissOnInteractOutside = false,\n ...props\n }: ScopedProps<AssistantModalPrimitiveContentProps>,\n forwardedRef,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return (\n <PopoverPrimitive.Portal {...scope}>\n <PopoverPrimitive.Content\n {...scope}\n {...props}\n ref={forwardedRef}\n side={side ?? \"top\"}\n align={align ?? \"end\"}\n onInteractOutside={composeEventHandlers(\n onInteractOutside,\n dissmissOnInteractOutside ? undefined : (e) => e.preventDefault(),\n )}\n />\n </PopoverPrimitive.Portal>\n );\n },\n);\n\nAssistantModalPrimitiveContent.displayName = \"AssistantModalPrimitive.Content\";\n","\"use client\";\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\nimport { ScopedProps, usePopoverScope } from \"./scope\";\n\ntype AssistantModalPrimitiveAnchorElement = ElementRef<\n typeof PopoverPrimitive.Anchor\n>;\ntype AssistantModalPrimitiveAnchorProps = ComponentPropsWithoutRef<\n typeof PopoverPrimitive.Anchor\n>;\n\nexport const AssistantModalPrimitiveAnchor = forwardRef<\n AssistantModalPrimitiveAnchorElement,\n AssistantModalPrimitiveAnchorProps\n>(\n (\n {\n __scopeAssistantModal,\n ...rest\n }: ScopedProps<AssistantModalPrimitiveAnchorProps>,\n ref,\n ) => {\n const scope = usePopoverScope(__scopeAssistantModal);\n\n return <PopoverPrimitive.Anchor {...scope} {...rest} ref={ref} />;\n },\n);\nAssistantModalPrimitiveAnchor.displayName = \"AssistantModalPrimitive.Anchor\";\n","export { BranchPickerPrimitiveNext as Next } from \"./BranchPickerNext\";\nexport { BranchPickerPrevious as Previous } from \"./BranchPickerPrevious\";\nexport { BranchPickerPrimitiveCount as Count } from \"./BranchPickerCount\";\nexport { BranchPickerPrimitiveNumber as Number } from \"./BranchPickerNumber\";\nexport { BranchPickerPrimitiveRoot as Root } from \"./BranchPickerRoot\";\n","\"use client\";\n\nimport { useBranchPickerNext } from \"../../primitive-hooks/branchPicker/useBranchPickerNext\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type BranchPickerPrimitiveNextProps = ActionButtonProps<\n typeof useBranchPickerNext\n>;\n\nexport const BranchPickerPrimitiveNext = createActionButton(\n \"BranchPickerPrimitive.Next\",\n useBranchPickerNext,\n);\n","\"use client\";\n\nimport { useBranchPickerPrevious } from \"../../primitive-hooks/branchPicker/useBranchPickerPrevious\";\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\n\nexport type BranchPickerPrimitivePreviousProps = ActionButtonProps<\n typeof useBranchPickerPrevious\n>;\n\nexport const BranchPickerPrevious = createActionButton(\n \"BranchPickerPrimitive.Previous\",\n useBranchPickerPrevious,\n);\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport { useBranchPickerCount } from \"../../primitive-hooks/branchPicker/useBranchPickerCount\";\n\nexport type BranchPickerPrimitiveCountProps = {};\n\nexport const BranchPickerPrimitiveCount: FC<\n BranchPickerPrimitiveCountProps\n> = () => {\n const branchCount = useBranchPickerCount();\n return <>{branchCount}</>;\n};\n\nBranchPickerPrimitiveCount.displayName = \"BranchPickerPrimitive.Count\";\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport { useBranchPickerNumber } from \"../../primitive-hooks/branchPicker/useBranchPickerNumber\";\n\nexport type BranchPickerPrimitiveNumberProps = {};\n\nexport const BranchPickerPrimitiveNumber: FC<\n BranchPickerPrimitiveNumberProps\n> = () => {\n const branchNumber = useBranchPickerNumber();\n return <>{branchNumber}</>;\n};\n\nBranchPickerPrimitiveNumber.displayName = \"BranchPickerPrimitive.Number\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { If } from \"../message\";\n\ntype BranchPickerPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type BranchPickerPrimitiveRootProps = PrimitiveDivProps & {\n hideWhenSingleBranch?: boolean | undefined;\n};\n\nexport const BranchPickerPrimitiveRoot = forwardRef<\n BranchPickerPrimitiveRootElement,\n BranchPickerPrimitiveRootProps\n>(({ hideWhenSingleBranch, ...rest }, ref) => {\n return (\n <If hasBranches={hideWhenSingleBranch ? true : undefined}>\n <Primitive.div {...rest} ref={ref} />\n </If>\n );\n});\n\nBranchPickerPrimitiveRoot.displayName = \"BranchPickerPrimitive.Root\";\n","export { MessagePrimitiveRoot as Root } from \"./MessageRoot\";\nexport { MessagePrimitiveIf as If } from \"./MessageIf\";\nexport { MessagePrimitiveContent as Content } from \"./MessageContent\";\nexport { MessagePrimitiveInProgress as InProgress } from \"./MessageInProgress\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n forwardRef,\n ComponentPropsWithoutRef,\n useCallback,\n} from \"react\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport { useManagedRef } from \"../../utils/hooks/useManagedRef\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\n\ntype MessagePrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nconst useIsHoveringRef = () => {\n const { useMessageUtils } = useMessageContext();\n\n const callbackRef = useCallback(\n (el: HTMLElement) => {\n const setIsHovering = useMessageUtils.getState().setIsHovering;\n\n const handleMouseEnter = () => {\n setIsHovering(true);\n };\n const handleMouseLeave = () => {\n setIsHovering(false);\n };\n\n el.addEventListener(\"mouseenter\", handleMouseEnter);\n el.addEventListener(\"mouseleave\", handleMouseLeave);\n\n return () => {\n el.removeEventListener(\"mouseenter\", handleMouseEnter);\n el.removeEventListener(\"mouseleave\", handleMouseLeave);\n setIsHovering(false);\n };\n },\n [useMessageUtils],\n );\n\n return useManagedRef(callbackRef);\n};\n\nexport type MessagePrimitiveRootProps = PrimitiveDivProps;\n\nexport const MessagePrimitiveRoot = forwardRef<\n MessagePrimitiveRootElement,\n MessagePrimitiveRootProps\n>(({ onMouseEnter, onMouseLeave, ...rest }, forwardRef) => {\n const isHoveringRef = useIsHoveringRef();\n const ref = useComposedRefs<HTMLDivElement>(forwardRef, isHoveringRef);\n\n return <Primitive.div {...rest} ref={ref} />;\n});\n\nMessagePrimitiveRoot.displayName = \"MessagePrimitive.Root\";\n","import { useCallback, useRef } from \"react\";\n\nexport const useManagedRef = <TNode>(\n callback: (node: TNode) => (() => void) | void,\n) => {\n const cleanupRef = useRef<(() => void) | void>();\n\n const ref = useCallback(\n (el: TNode | null) => {\n // Call the previous cleanup function\n if (cleanupRef.current) {\n cleanupRef.current();\n }\n\n // Call the new callback and store its cleanup function\n if (el) {\n cleanupRef.current = callback(el);\n }\n },\n [callback],\n );\n\n return ref;\n};\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseMessageIfProps,\n useMessageIf,\n} from \"../../primitive-hooks/message/useMessageIf\";\n\nexport type MessagePrimitiveIfProps = PropsWithChildren<UseMessageIfProps>;\n\nexport const MessagePrimitiveIf: FC<MessagePrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useMessageIf(query);\n return result ? children : null;\n};\n\nMessagePrimitiveIf.displayName = \"MessagePrimitive.If\";\n","\"use client\";\n\nimport { type ComponentType, type FC, memo } from \"react\";\nimport {\n useAssistantContext,\n useContentPartContext,\n useThreadContext,\n} from \"../../context\";\nimport { useMessageContext } from \"../../context/react/MessageContext\";\nimport {\n ContentPartProvider,\n EMPTY_CONTENT,\n} from \"../../context/providers/ContentPartProvider\";\nimport { ContentPartPrimitiveText } from \"../contentPart/ContentPartText\";\nimport { ContentPartPrimitiveImage } from \"../contentPart/ContentPartImage\";\nimport { ContentPartPrimitiveDisplay } from \"../contentPart/ContentPartDisplay\";\nimport type {\n ImageContentPartComponent,\n TextContentPartComponent,\n ToolCallContentPartComponent,\n ToolCallContentPartProps,\n UIContentPartComponent,\n} from \"../../types/ContentPartComponentTypes\";\nimport { ContentPartPrimitiveInProgress } from \"../contentPart/ContentPartInProgress\";\n\nexport type MessagePrimitiveContentProps = {\n components?:\n | {\n Empty?: TextContentPartComponent | undefined;\n Text?: TextContentPartComponent | undefined;\n Image?: ImageContentPartComponent | undefined;\n UI?: UIContentPartComponent | undefined;\n tools?:\n | {\n by_name?:\n | Record<string, ToolCallContentPartComponent | undefined>\n | undefined;\n Fallback?: ComponentType<ToolCallContentPartProps> | undefined;\n }\n | undefined;\n }\n | undefined;\n};\n\nconst ToolUIDisplay = ({\n UI,\n ...props\n}: {\n UI: ToolCallContentPartComponent | undefined;\n} & ToolCallContentPartProps) => {\n const { useToolUIs } = useAssistantContext();\n const Render = useToolUIs((s) => s.getToolUI(props.part.toolName)) ?? UI;\n if (!Render) return null;\n return <Render {...props} />;\n};\n\nconst defaultComponents = {\n Text: () => (\n <p style={{ whiteSpace: \"pre-line\" }}>\n <ContentPartPrimitiveText />\n <ContentPartPrimitiveInProgress>\n <span style={{ fontFamily: \"revert\" }}>{\" \\u25CF\"}</span>\n </ContentPartPrimitiveInProgress>\n </p>\n ),\n Image: () => <ContentPartPrimitiveImage />,\n UI: () => <ContentPartPrimitiveDisplay />,\n} satisfies MessagePrimitiveContentProps[\"components\"];\n\ntype MessageContentPartComponentProps = {\n components: MessagePrimitiveContentProps[\"components\"];\n};\n\nconst MessageContentPartComponent: FC<MessageContentPartComponentProps> = ({\n components: {\n Empty = defaultComponents.Text,\n Text = defaultComponents.Text,\n Image = defaultComponents.Image,\n UI = defaultComponents.UI,\n tools: { by_name = {}, Fallback = undefined } = {},\n } = {},\n}) => {\n const { useThreadActions } = useThreadContext();\n const { useMessage } = useMessageContext();\n const addToolResult = useThreadActions((t) => t.addToolResult);\n\n const { useContentPart } = useContentPartContext();\n const { part, status } = useContentPart();\n\n const type = part.type;\n switch (type) {\n case \"text\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n if (part === EMPTY_CONTENT) return <Empty part={part} status={status} />;\n\n return <Text part={part} status={status} />;\n\n case \"image\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n // eslint-disable-next-line jsx-a11y/alt-text\n return <Image part={part} status={status} />;\n\n case \"ui\":\n if (status.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n return <UI part={part} status={status} />;\n\n case \"tool-call\": {\n const Tool = by_name[part.toolName] || Fallback;\n const addResult = (result: any) =>\n addToolResult({\n messageId: useMessage.getState().message.id,\n toolName: part.toolName,\n toolCallId: part.toolCallId,\n result,\n });\n return (\n <ToolUIDisplay\n UI={Tool}\n part={part}\n status={status}\n addResult={addResult}\n />\n );\n }\n default:\n const unhandledType: never = type;\n throw new Error(`Unknown content part type: ${unhandledType}`);\n }\n};\n\ntype MessageContentPartProps = {\n partIndex: number;\n components: MessagePrimitiveContentProps[\"components\"];\n};\n\nconst MessageContentPartImpl: FC<MessageContentPartProps> = ({\n partIndex,\n components,\n}) => {\n return (\n <ContentPartProvider partIndex={partIndex}>\n <MessageContentPartComponent components={components} />\n </ContentPartProvider>\n );\n};\n\nconst MessageContentPart = memo(\n MessageContentPartImpl,\n (prev, next) =>\n prev.partIndex === next.partIndex &&\n prev.components?.Text === next.components?.Text &&\n prev.components?.Image === next.components?.Image &&\n prev.components?.UI === next.components?.UI &&\n prev.components?.tools === next.components?.tools,\n);\n\nexport const MessagePrimitiveContent: FC<MessagePrimitiveContentProps> = ({\n components,\n}) => {\n const { useMessage } = useMessageContext();\n\n const contentLength = useMessage((s) => s.message.content.length) || 1;\n\n return new Array(contentLength).fill(null).map((_, idx) => {\n const partIndex = idx; // use the index as key, as message is generally append only\n return (\n <MessageContentPart\n key={partIndex}\n partIndex={partIndex}\n components={components}\n />\n );\n });\n};\n\nMessagePrimitiveContent.displayName = \"MessagePrimitive.Content\";\n","\"use client\";\n\nimport { type FC, type PropsWithChildren, useEffect, useState } from \"react\";\nimport { StoreApi, create } from \"zustand\";\nimport { ContentPartContext } from \"../react/ContentPartContext\";\nimport type { ContentPartContextValue } from \"../react/ContentPartContext\";\nimport { useMessageContext } from \"../react/MessageContext\";\nimport type { MessageState } from \"../stores\";\nimport type { ContentPartState } from \"../stores/ContentPart\";\nimport {\n ContentPartStatus,\n ThreadAssistantContentPart,\n ThreadMessage,\n ThreadUserContentPart,\n ToolCallContentPartStatus,\n} from \"../../types/AssistantTypes\";\n\ntype ContentPartProviderProps = PropsWithChildren<{\n partIndex: number;\n}>;\n\nconst COMPLETE_STATUS: ContentPartStatus = {\n type: \"complete\",\n};\n\nconst toContentPartStatus = (\n message: ThreadMessage,\n partIndex: number,\n part: ThreadUserContentPart | ThreadAssistantContentPart,\n): ToolCallContentPartStatus => {\n if (message.role !== \"assistant\") return COMPLETE_STATUS;\n\n const isLastPart = partIndex === Math.max(0, message.content.length - 1);\n if (part.type !== \"tool-call\") {\n if (\n \"reason\" in message.status &&\n message.status.reason === \"tool-calls\" &&\n isLastPart\n )\n throw new Error(\n \"Encountered unexpected requires-action status. This is likely an internal bug in assistant-ui.\",\n );\n\n return isLastPart ? (message.status as ContentPartStatus) : COMPLETE_STATUS;\n }\n\n if (!!part.result) {\n return COMPLETE_STATUS;\n }\n\n return message.status as ToolCallContentPartStatus;\n};\n\nexport const EMPTY_CONTENT = Object.freeze({ type: \"text\", text: \"\" });\n\nconst getContentPartState = (\n { message }: MessageState,\n useContentPart: ContentPartContextValue[\"useContentPart\"] | undefined,\n partIndex: number,\n) => {\n let part = message.content[partIndex];\n if (!part) {\n // for empty messages, show an empty text content part\n if (message.content.length === 0 && partIndex === 0) {\n part = EMPTY_CONTENT;\n } else {\n return null;\n }\n }\n\n // if the content part is the same, don't update\n const status = toContentPartStatus(message, partIndex, part);\n const currentState = useContentPart?.getState();\n if (\n currentState &&\n currentState.part === part &&\n currentState.status === status\n )\n return null;\n\n return Object.freeze({ part, status });\n};\n\nconst useContentPartContext = (partIndex: number) => {\n const { useMessage } = useMessageContext();\n const [context] = useState<ContentPartContextValue>(() => {\n const useContentPart = create<ContentPartState>(\n () => getContentPartState(useMessage.getState(), undefined, partIndex)!,\n );\n\n return { useContentPart };\n });\n\n useEffect(() => {\n const syncContentPart = (message: MessageState) => {\n const newState = getContentPartState(\n message,\n context.useContentPart,\n partIndex,\n );\n if (!newState) return;\n (\n context.useContentPart as unknown as StoreApi<ContentPartState>\n ).setState(newState, true);\n };\n\n syncContentPart(useMessage.getState());\n return useMessage.subscribe(syncContentPart);\n }, [context, useMessage, partIndex]);\n\n return context;\n};\n\nexport const ContentPartProvider: FC<ContentPartProviderProps> = ({\n partIndex,\n children,\n}) => {\n const context = useContentPartContext(partIndex);\n\n return (\n <ContentPartContext.Provider value={context}>\n {children}\n </ContentPartContext.Provider>\n );\n};\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n forwardRef,\n ComponentPropsWithoutRef,\n ElementType,\n} from \"react\";\nimport { useContentPartText } from \"../../primitive-hooks/contentPart/useContentPartText\";\nimport { useSmooth } from \"../../utils/smooth/useSmooth\";\n\ntype ContentPartPrimitiveTextElement = ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = ComponentPropsWithoutRef<typeof Primitive.span>;\n\nexport type ContentPartPrimitiveTextProps = Omit<\n PrimitiveSpanProps,\n \"children\" | \"asChild\"\n> & {\n smooth?: boolean;\n component?: ElementType;\n};\n\nexport const ContentPartPrimitiveText = forwardRef<\n ContentPartPrimitiveTextElement,\n ContentPartPrimitiveTextProps\n>(({ smooth = true, component: Component = \"span\", ...rest }, forwardedRef) => {\n const {\n part: { text },\n status,\n } = useSmooth(useContentPartText(), smooth);\n\n return (\n <Component data-status={status.type} {...rest} ref={forwardedRef}>\n {text}\n </Component>\n );\n});\n\nContentPartPrimitiveText.displayName = \"ContentPartPrimitive.Text\";\n","import { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport { useContentPartImage } from \"../../primitive-hooks/contentPart/useContentPartImage\";\n\ntype ContentPartPrimitiveImageElement = ElementRef<typeof Primitive.img>;\ntype PrimitiveImageProps = ComponentPropsWithoutRef<typeof Primitive.img>;\n\nexport type ContentPartPrimitiveImageProps = PrimitiveImageProps;\n\nexport const ContentPartPrimitiveImage = forwardRef<\n ContentPartPrimitiveImageElement,\n ContentPartPrimitiveImageProps\n>((props, forwardedRef) => {\n const {\n part: { image },\n } = useContentPartImage();\n return <Primitive.img src={image} {...props} ref={forwardedRef} />;\n});\n\nContentPartPrimitiveImage.displayName = \"ContentPartPrimitive.Image\";\n","import type { FC } from \"react\";\nimport { useContentPartDisplay } from \"../../primitive-hooks/contentPart/useContentPartDisplay\";\n\nexport type ContentPartPrimitiveDisplayProps = {};\n\nexport const ContentPartPrimitiveDisplay: FC<\n ContentPartPrimitiveDisplayProps\n> = () => {\n const {\n part: { display },\n } = useContentPartDisplay();\n return display ?? null;\n};\n\nContentPartPrimitiveDisplay.displayName = \"ContentPartPrimitive.Display\";\n","import { FC, PropsWithChildren } from \"react\";\nimport { useContentPartContext } from \"../../context\";\n\nexport type ContentPartPrimitiveInProgressProps = PropsWithChildren;\n\n// TODO should this be renamed to IsRunning?\nexport const ContentPartPrimitiveInProgress: FC<\n ContentPartPrimitiveInProgressProps\n> = ({ children }) => {\n const { useContentPart } = useContentPartContext();\n const isInProgress = useContentPart((c) => c.status.type === \"running\");\n\n return isInProgress ? children : null;\n};\n\nContentPartPrimitiveInProgress.displayName = \"ContentPartPrimitive.InProgress\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { ComponentPropsWithoutRef, FC } from \"react\";\n\ntype PrimitiveSpanProps = ComponentPropsWithoutRef<typeof Primitive.span>;\n\nexport type MessagePrimitiveInProgressProps = PrimitiveSpanProps;\n\n/**\n * @deprecated Define a custom Text renderer via ContentPartPrimitiveInProgress instead.\n */\nexport const MessagePrimitiveInProgress: FC<\n MessagePrimitiveInProgressProps\n> = () => {\n return null;\n};\n\nMessagePrimitiveInProgress.displayName = \"MessagePrimitive.InProgress\";\n","export { ComposerPrimitiveRoot as Root } from \"./ComposerRoot\";\nexport { ComposerPrimitiveInput as Input } from \"./ComposerInput\";\nexport { ComposerPrimitiveSend as Send } from \"./ComposerSend\";\nexport { ComposerPrimitiveCancel as Cancel } from \"./ComposerCancel\";\nexport { ComposerPrimitiveIf as If } from \"./ComposerIf\";\n","\"use client\";\n\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport {\n type ElementRef,\n type FormEvent,\n forwardRef,\n ComponentPropsWithoutRef,\n} from \"react\";\nimport { useComposerSend } from \"../../primitive-hooks\";\n\ntype ComposerPrimitiveRootElement = ElementRef<typeof Primitive.form>;\ntype PrimitiveFormProps = ComponentPropsWithoutRef<typeof Primitive.form>;\n\nexport type ComposerPrimitiveRootProps = PrimitiveFormProps;\n\nexport const ComposerPrimitiveRoot = forwardRef<\n ComposerPrimitiveRootElement,\n ComposerPrimitiveRootProps\n>(({ onSubmit, ...rest }, forwardedRef) => {\n const send = useComposerSend();\n\n const handleSubmit = (e: FormEvent) => {\n e.preventDefault();\n\n if (!send) return;\n send();\n };\n\n return (\n <Primitive.form\n {...rest}\n ref={forwardedRef}\n onSubmit={composeEventHandlers(onSubmit, handleSubmit)}\n />\n );\n});\n\nComposerPrimitiveRoot.displayName = \"ComposerPrimitive.Root\";\n","\"use client\";\n\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport {\n type KeyboardEvent,\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n} from \"react\";\nimport TextareaAutosize, {\n type TextareaAutosizeProps,\n} from \"react-textarea-autosize\";\nimport { useComposerContext } from \"../../context/react/ComposerContext\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { useOnComposerFocus } from \"../../utils/hooks/useOnComposerFocus\";\n\nexport type ComposerPrimitiveInputProps = TextareaAutosizeProps & {\n asChild?: boolean | undefined;\n};\n\nexport const ComposerPrimitiveInput = forwardRef<\n HTMLTextAreaElement,\n ComposerPrimitiveInputProps\n>(\n (\n {\n autoFocus = false,\n asChild,\n disabled: disabledProp,\n onChange,\n onKeyDown,\n ...rest\n },\n forwardedRef,\n ) => {\n const { useThread } = useThreadContext();\n const { useComposer, type } = useComposerContext();\n\n const value = useComposer((c) => {\n if (!c.isEditing) return \"\";\n return c.text;\n });\n\n const Component = asChild ? Slot : TextareaAutosize;\n\n const isDisabled = useThread((t) => t.isDisabled) ?? disabledProp ?? false;\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const ref = useComposedRefs(forwardedRef, textareaRef);\n\n useEscapeKeydown((e) => {\n const composer = useComposer.getState();\n if (composer.canCancel) {\n composer.cancel();\n e.preventDefault();\n }\n });\n\n const handleKeyPress = (e: KeyboardEvent) => {\n if (isDisabled) return;\n\n // ignore IME composition events\n if (e.nativeEvent.isComposing) return;\n\n if (e.key === \"Enter\" && e.shiftKey === false) {\n const { isRunning } = useThread.getState();\n\n if (!isRunning) {\n e.preventDefault();\n\n textareaRef.current?.closest(\"form\")?.requestSubmit();\n }\n }\n };\n\n const autoFocusEnabled = autoFocus && !isDisabled;\n const focus = useCallback(() => {\n const textarea = textareaRef.current;\n if (!textarea || !autoFocusEnabled) return;\n\n textarea.focus({ preventScroll: true });\n textarea.setSelectionRange(\n textareaRef.current.value.length,\n textareaRef.current.value.length,\n );\n }, [autoFocusEnabled]);\n\n useEffect(() => focus(), [focus]);\n\n useOnComposerFocus(() => {\n if (type === \"new\") {\n focus();\n }\n });\n\n return (\n <Component\n name=\"input\"\n value={value}\n {...rest}\n ref={ref}\n disabled={isDisabled}\n onChange={composeEventHandlers(onChange, (e) => {\n const composerState = useComposer.getState();\n if (!composerState.isEditing) return;\n return composerState.setText(e.target.value);\n })}\n onKeyDown={composeEventHandlers(onKeyDown, handleKeyPress)}\n />\n );\n },\n);\n\nComposerPrimitiveInput.displayName = \"ComposerPrimitive.Input\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, ElementRef, forwardRef } from \"react\";\nimport { useComposerContext } from \"../../context\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\n\ntype ComposerPrimitiveSendElement = ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\n\nexport type ComposerPrimitiveSendProps = PrimitiveButtonProps;\n\nexport const ComposerPrimitiveSend = forwardRef<\n ComposerPrimitiveSendElement,\n ComposerPrimitiveSendProps\n>(({ disabled, ...rest }, ref) => {\n const { useComposer } = useComposerContext();\n const hasValue = useComposer((c) => c.isEditing && c.text.length > 0);\n\n return (\n <Primitive.button\n type=\"submit\"\n {...rest}\n ref={ref}\n disabled={disabled || !hasValue}\n />\n );\n});\n\nComposerPrimitiveSend.displayName = \"ComposerPrimitive.Send\";\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useComposerCancel } from \"../../primitive-hooks/composer/useComposerCancel\";\n\nexport type ComposerPrimitiveCancelProps = ActionButtonProps<\n typeof useComposerCancel\n>;\n\nexport const ComposerPrimitiveCancel = createActionButton(\n \"ComposerPrimitive.Cancel\",\n useComposerCancel,\n);\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseComposerIfProps,\n useComposerIf,\n} from \"../../primitive-hooks/composer/useComposerIf\";\n\nexport type ComposerPrimitiveIfProps = PropsWithChildren<UseComposerIfProps>;\n\nexport const ComposerPrimitiveIf: FC<ComposerPrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useComposerIf(query);\n return result ? children : null;\n};\n\nComposerPrimitiveIf.displayName = \"ComposerPrimitive.If\";\n","export { ContentPartPrimitiveText as Text } from \"./ContentPartText\";\nexport { ContentPartPrimitiveImage as Image } from \"./ContentPartImage\";\nexport { ContentPartPrimitiveDisplay as Display } from \"./ContentPartDisplay\";\nexport { ContentPartPrimitiveInProgress as InProgress } from \"./ContentPartInProgress\";\n","export { ThreadPrimitiveRoot as Root } from \"./ThreadRoot\";\nexport { ThreadPrimitiveEmpty as Empty } from \"./ThreadEmpty\";\nexport { ThreadPrimitiveIf as If } from \"./ThreadIf\";\nexport { ThreadPrimitiveViewport as Viewport } from \"./ThreadViewport\";\nexport { ThreadPrimitiveMessages as Messages } from \"./ThreadMessages\";\nexport { ThreadPrimitiveScrollToBottom as ScrollToBottom } from \"./ThreadScrollToBottom\";\nexport { ThreadPrimitiveSuggestion as Suggestion } from \"./ThreadSuggestion\";\n","\"use client\";\n\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\n\ntype ThreadPrimitiveRootElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ThreadPrimitiveRootProps = PrimitiveDivProps;\n\nexport const ThreadPrimitiveRoot = forwardRef<\n ThreadPrimitiveRootElement,\n ThreadPrimitiveRootProps\n>((props, ref) => {\n return <Primitive.div {...props} ref={ref} />;\n});\n\nThreadPrimitiveRoot.displayName = \"ThreadPrimitive.Root\";\n","\"use client\";\n\nimport type { FC, ReactNode } from \"react\";\nimport { useThreadEmpty } from \"../../primitive-hooks\";\n\nexport type ThreadPrimitiveEmptyProps = {\n children: ReactNode;\n};\n\nexport const ThreadPrimitiveEmpty: FC<ThreadPrimitiveEmptyProps> = ({\n children,\n}) => {\n const empty = useThreadEmpty();\n return empty ? children : null;\n};\n\nThreadPrimitiveEmpty.displayName = \"ThreadPrimitive.Empty\";\n","\"use client\";\n\nimport type { FC, PropsWithChildren } from \"react\";\nimport {\n UseThreadIfProps,\n useThreadIf,\n} from \"../../primitive-hooks/thread/useThreadIf\";\n\nexport type ThreadPrimitiveIfProps = PropsWithChildren<UseThreadIfProps>;\n\nexport const ThreadPrimitiveIf: FC<ThreadPrimitiveIfProps> = ({\n children,\n ...query\n}) => {\n const result = useThreadIf(query);\n return result ? children : null;\n};\n\nThreadPrimitiveIf.displayName = \"ThreadPrimitive.If\";\n","\"use client\";\n\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { type ElementRef, forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport {\n UseThreadViewportAutoScrollProps,\n useThreadViewportAutoScroll,\n} from \"../../primitive-hooks/thread/useThreadViewportAutoScroll\";\n\ntype ThreadPrimitiveViewportElement = ElementRef<typeof Primitive.div>;\ntype PrimitiveDivProps = ComponentPropsWithoutRef<typeof Primitive.div>;\n\nexport type ThreadPrimitiveViewportProps = PrimitiveDivProps &\n UseThreadViewportAutoScrollProps;\n\nexport const ThreadPrimitiveViewport = forwardRef<\n ThreadPrimitiveViewportElement,\n ThreadPrimitiveViewportProps\n>(({ autoScroll, onScroll, children, ...rest }, forwardedRef) => {\n const autoScrollRef = useThreadViewportAutoScroll<HTMLDivElement>({\n autoScroll,\n });\n\n const ref = useComposedRefs(forwardedRef, autoScrollRef);\n\n return (\n <Primitive.div {...rest} ref={ref}>\n {children}\n </Primitive.div>\n );\n});\n\nThreadPrimitiveViewport.displayName = \"ThreadPrimitive.Viewport\";\n","\"use client\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useRef } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { useOnResizeContent } from \"../../utils/hooks/useOnResizeContent\";\nimport { useOnScrollToBottom } from \"../../utils/hooks/useOnScrollToBottom\";\nimport { StoreApi } from \"zustand\";\nimport { ThreadViewportState } from \"../../context\";\nimport { useManagedRef } from \"../../utils/hooks/useManagedRef\";\n\nexport type UseThreadViewportAutoScrollProps = {\n autoScroll?: boolean | undefined;\n};\n\nexport const useThreadViewportAutoScroll = <TElement extends HTMLElement>({\n autoScroll = true,\n}: UseThreadViewportAutoScrollProps) => {\n const divRef = useRef<TElement>(null);\n\n const { useViewport } = useThreadContext();\n\n const lastScrollTop = useRef<number>(0);\n\n // bug: when ScrollToBottom's button changes its disabled state, the scroll stops\n // fix: delay the state change until the scroll is done\n const isScrollingToBottomRef = useRef(false);\n\n const scrollToBottom = (behavior: ScrollBehavior) => {\n const div = divRef.current;\n if (!div || !autoScroll) return;\n\n isScrollingToBottomRef.current = true;\n div.scrollTo({ top: div.scrollHeight, behavior });\n };\n\n const handleScroll = () => {\n const div = divRef.current;\n if (!div) return;\n\n const isAtBottom = useViewport.getState().isAtBottom;\n const newIsAtBottom =\n div.scrollHeight - div.scrollTop <= div.clientHeight + 1; // TODO figure out why +1 is needed\n\n if (!newIsAtBottom && lastScrollTop.current < div.scrollTop) {\n // ignore scroll down\n } else {\n if (newIsAtBottom) {\n isScrollingToBottomRef.current = false;\n }\n\n if (newIsAtBottom !== isAtBottom) {\n (useViewport as unknown as StoreApi<ThreadViewportState>).setState({\n isAtBottom: newIsAtBottom,\n });\n }\n }\n\n lastScrollTop.current = div.scrollTop;\n };\n\n const resizeRef = useOnResizeContent(() => {\n if (isScrollingToBottomRef.current || useViewport.getState().isAtBottom) {\n scrollToBottom(\"instant\");\n }\n\n handleScroll();\n });\n\n const scrollRef = useManagedRef<HTMLElement>((el) => {\n el.addEventListener(\"scroll\", handleScroll);\n return () => {\n el.removeEventListener(\"scroll\", handleScroll);\n };\n });\n\n const autoScrollRef = useComposedRefs<TElement>(resizeRef, scrollRef, divRef);\n\n useOnScrollToBottom(() => {\n scrollToBottom(\"auto\");\n });\n\n return autoScrollRef;\n};\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useCallback } from \"react\";\nimport { useManagedRef } from \"./useManagedRef\";\n\nexport const useOnResizeContent = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const refCallback = useCallback(\n (el: HTMLElement) => {\n const resizeObserver = new ResizeObserver(() => {\n callbackRef();\n });\n\n const mutationObserver = new MutationObserver((mutations) => {\n for (const mutation of mutations) {\n for (const node of mutation.addedNodes) {\n if (node instanceof Element) {\n resizeObserver.observe(node);\n }\n }\n\n for (const node of mutation.removedNodes) {\n if (node instanceof Element) {\n resizeObserver.unobserve(node);\n }\n }\n }\n\n callbackRef();\n });\n\n resizeObserver.observe(el);\n mutationObserver.observe(el, { childList: true });\n\n // Observe existing children\n for (const child of el.children) {\n resizeObserver.observe(child);\n }\n\n return () => {\n resizeObserver.disconnect();\n mutationObserver.disconnect();\n };\n },\n [callbackRef],\n );\n\n return useManagedRef(refCallback);\n};\n","import { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEffect } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\n\nexport const useOnScrollToBottom = (callback: () => void) => {\n const callbackRef = useCallbackRef(callback);\n\n const { useViewport } = useThreadContext();\n useEffect(() => {\n return useViewport.getState().onScrollToBottom(() => {\n callbackRef();\n });\n }, [useViewport, callbackRef]);\n};\n","\"use client\";\n\nimport { type ComponentType, type FC, memo } from \"react\";\nimport { useThreadContext } from \"../../context/react/ThreadContext\";\nimport { MessageProvider } from \"../../context/providers/MessageProvider\";\nimport { ComposerPrimitiveIf } from \"../composer/ComposerIf\";\nimport { MessagePrimitiveIf } from \"../message/MessageIf\";\n\nexport type ThreadPrimitiveMessagesProps = {\n components:\n | {\n Message: ComponentType;\n UserMessage?: ComponentType | undefined;\n EditComposer?: ComponentType | undefined;\n AssistantMessage?: ComponentType | undefined;\n SystemMessage?: ComponentType | undefined;\n }\n | {\n Message?: ComponentType | undefined;\n UserMessage: ComponentType;\n EditComposer?: ComponentType | undefined;\n AssistantMessage: ComponentType;\n SystemMessage?: ComponentType | undefined;\n };\n};\n\nconst DEFAULT_SYSTEM_MESSAGE = () => null;\n\nconst getComponents = (\n components: ThreadPrimitiveMessagesProps[\"components\"],\n) => {\n return {\n EditComposer:\n components.EditComposer ??\n components.UserMessage ??\n (components.Message as ComponentType),\n UserMessage:\n components.UserMessage ?? (components.Message as ComponentType),\n AssistantMessage:\n components.AssistantMessage ?? (components.Message as ComponentType),\n SystemMessage: components.SystemMessage ?? DEFAULT_SYSTEM_MESSAGE,\n };\n};\n\ntype ThreadMessageProps = {\n messageIndex: number;\n components: ThreadPrimitiveMessagesProps[\"components\"];\n};\n\nconst ThreadMessageImpl: FC<ThreadMessageProps> = ({\n messageIndex,\n components,\n}) => {\n const { UserMessage, EditComposer, AssistantMessage, SystemMessage } =\n getComponents(components);\n return (\n <MessageProvider messageIndex={messageIndex}>\n <MessagePrimitiveIf user>\n <ComposerPrimitiveIf editing={false}>\n <UserMessage />\n </ComposerPrimitiveIf>\n <ComposerPrimitiveIf editing>\n <EditComposer />\n </ComposerPrimitiveIf>\n </MessagePrimitiveIf>\n <MessagePrimitiveIf assistant>\n <AssistantMessage />\n </MessagePrimitiveIf>\n <MessagePrimitiveIf system>\n <SystemMessage />\n </MessagePrimitiveIf>\n </MessageProvider>\n );\n};\n\nconst ThreadMessage = memo(\n ThreadMessageImpl,\n (prev, next) =>\n prev.messageIndex === next.messageIndex &&\n prev.components.Message === next.components.Message &&\n prev.components.UserMessage === next.components.UserMessage &&\n prev.components.EditComposer === next.components.EditComposer &&\n prev.components.AssistantMessage === next.components.AssistantMessage &&\n prev.components.SystemMessage === next.components.SystemMessage,\n);\n\nexport const ThreadPrimitiveMessagesImpl: FC<ThreadPrimitiveMessagesProps> = ({\n components,\n}) => {\n const { useThreadMessages } = useThreadContext();\n\n const messagesLength = useThreadMessages((t) => t.length);\n if (messagesLength === 0) return null;\n\n return new Array(messagesLength).fill(null).map((_, idx) => {\n const messageIndex = idx; // keep the same key when switching branches for better a11y support\n return (\n <ThreadMessage\n key={messageIndex}\n messageIndex={messageIndex}\n components={components}\n />\n );\n });\n};\n\nThreadPrimitiveMessagesImpl.displayName = \"ThreadPrimitive.Messages\";\n\nexport const ThreadPrimitiveMessages = memo(\n ThreadPrimitiveMessagesImpl,\n (prev, next) =>\n prev.components?.Message === next.components?.Message &&\n prev.components?.UserMessage === next.components?.UserMessage &&\n prev.components?.EditComposer === next.components?.EditComposer &&\n prev.components?.AssistantMessage === next.components?.AssistantMessage &&\n prev.components?.SystemMessage === next.components?.SystemMessage,\n);\n","\"use client\";\n\nimport { type FC, type PropsWithChildren, useEffect, useState } from \"react\";\nimport { StoreApi, create } from \"zustand\";\nimport type {\n CoreUserContentPart,\n ThreadMessage,\n} from \"../../types/AssistantTypes\";\nimport { getThreadMessageText } from \"../../utils/getThreadMessageText\";\nimport { MessageContext } from \"../react/MessageContext\";\nimport type { MessageContextValue } from \"../react/MessageContext\";\nimport { useThreadContext } from \"../react/ThreadContext\";\nimport type { MessageState } from \"../stores/Message\";\nimport { makeEditComposerStore } from \"../stores/EditComposer\";\nimport { makeMessageUtilsStore } from \"../stores/MessageUtils\";\nimport { ThreadMessagesState } from \"../stores/ThreadMessages\";\n\ntype MessageProviderProps = PropsWithChildren<{\n messageIndex: number;\n}>;\n\nconst getIsLast = (messages: ThreadMessagesState, message: ThreadMessage) => {\n return messages[messages.length - 1]?.id === message.id;\n};\n\nconst getMessageState = (\n messages: ThreadMessagesState,\n getBranches: (messageId: string) => readonly string[],\n useMessage: MessageContextValue[\"useMessage\"] | undefined,\n messageIndex: number,\n) => {\n const parentId = messages[messageIndex - 1]?.id ?? null;\n const message = messages[messageIndex];\n if (!message) return null;\n\n const isLast = getIsLast(messages, message);\n const branches = getBranches(message.id);\n\n // if the message is the same, don't update\n const currentState = useMessage?.getState();\n if (\n currentState &&\n currentState.message === message &&\n currentState.parentId === parentId &&\n currentState.branches === branches &&\n currentState.isLast === isLast\n )\n return null;\n\n return Object.freeze({\n message,\n parentId,\n branches,\n isLast,\n });\n};\n\nconst useMessageContext = (messageIndex: number) => {\n const { useThreadMessages, useThreadActions } = useThreadContext();\n\n const [context] = useState<MessageContextValue>(() => {\n const useMessage = create<MessageState>(\n () =>\n getMessageState(\n useThreadMessages.getState(),\n useThreadActions.getState().getBranches,\n undefined,\n messageIndex,\n )!,\n );\n const useMessageUtils = makeMessageUtilsStore();\n const useEditComposer = makeEditComposerStore({\n onEdit: () => {\n const message = useMessage.getState().message;\n if (message.role !== \"user\")\n throw new Error(\n \"Tried to edit a non-user message. Editing is only supported for user messages. This is likely an internal bug in assistant-ui.\",\n );\n\n const text = getThreadMessageText(message);\n\n return text;\n },\n onSend: (text) => {\n const { message, parentId } = useMessage.getState();\n if (message.role !== \"user\")\n throw new Error(\n \"Tried to edit a non-user message. Editing is only supported for user messages. This is likely an internal bug in assistant-ui.\",\n );\n\n const nonTextParts = message.content.filter(\n (part): part is CoreUserContentPart =>\n part.type !== \"text\" && part.type !== \"ui\",\n );\n useThreadActions.getState().append({\n parentId,\n role: \"user\",\n content: [{ type: \"text\", text }, ...nonTextParts],\n });\n },\n });\n\n return { useMessage, useMessageUtils, useEditComposer };\n });\n\n useEffect(() => {\n const syncMessage = (thread: ThreadMessagesState) => {\n const newState = getMessageState(\n thread,\n useThreadActions.getState().getBranches,\n context.useMessage,\n messageIndex,\n );\n if (!newState) return;\n (context.useMessage as unknown as StoreApi<MessageState>).setState(\n newState,\n true,\n );\n };\n\n syncMessage(useThreadMessages.getState());\n\n return useThreadMessages.subscribe(syncMessage);\n }, [useThreadMessages, useThreadActions, context, messageIndex]);\n\n return context;\n};\n\nexport const MessageProvider: FC<MessageProviderProps> = ({\n messageIndex,\n children,\n}) => {\n const context = useMessageContext(messageIndex);\n\n return (\n <MessageContext.Provider value={context}>\n {children}\n </MessageContext.Provider>\n );\n};\n","import { create } from \"zustand\";\nimport { ReadonlyStore } from \"../ReadonlyStore\";\n\nexport type EditComposerState = Readonly<{\n // TODO \n /** @deprecated Use `text` instead. */\n value: string;\n /** @deprecated Use `setText` instead. */\n setValue: (value: string) => void;\n\n text: string;\n setText: (value: string) => void;\n\n canCancel: boolean;\n isEditing: boolean;\n\n edit: () => void;\n send: () => void;\n cancel: () => void;\n}>;\n\nexport const makeEditComposerStore = ({\n onEdit,\n onSend,\n}: {\n onEdit: () => string;\n onSend: (text: string) => void;\n}): ReadonlyStore<EditComposerState> =>\n create<EditComposerState>()((set, get) => ({\n get value() {\n return get().text;\n },\n setValue(value) {\n get().setText(value);\n },\n\n text: \"\",\n setText: (text) => {\n set({ text });\n },\n\n canCancel: false,\n isEditing: false,\n\n edit: () => {\n const text = onEdit();\n set({ isEditing: true, canCancel: true, text });\n },\n send: () => {\n const text = get().text;\n set({ isEditing: false, canCancel: false });\n onSend(text);\n },\n cancel: () => {\n set({ isEditing: false, canCancel: false });\n },\n }));\n","import { create } from \"zustand\";\nimport { SpeechSynthesisAdapter } from \"../../runtimes/speech/SpeechAdapterTypes\";\n\nexport type MessageUtilsState = Readonly<{\n isCopied: boolean;\n setIsCopied: (value: boolean) => void;\n isHovering: boolean;\n setIsHovering: (value: boolean) => void;\n\n isSpeaking: boolean;\n stopSpeaking: () => void;\n addUtterance: (utterance: SpeechSynthesisAdapter.Utterance) => void;\n}>;\n\nexport const makeMessageUtilsStore = () =>\n create<MessageUtilsState>((set) => {\n let utterance: SpeechSynthesisAdapter.Utterance | null = null;\n return {\n isCopied: false,\n setIsCopied: (value) => {\n set({ isCopied: value });\n },\n isHovering: false,\n setIsHovering: (value) => {\n set({ isHovering: value });\n },\n isSpeaking: false,\n stopSpeaking: () => {\n utterance?.cancel();\n },\n addUtterance: (utt) => {\n utterance = utt;\n set({ isSpeaking: true });\n utt.onEnd(() => {\n set({ isSpeaking: false });\n });\n },\n };\n });\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useThreadScrollToBottom } from \"../../primitive-hooks/thread/useThreadScrollToBottom\";\n\nexport type ThreadPrimitiveScrollToBottomProps = ActionButtonProps<\n typeof useThreadScrollToBottom\n>;\n\nexport const ThreadPrimitiveScrollToBottom = createActionButton(\n \"ThreadPrimitive.ScrollToBottom\",\n useThreadScrollToBottom,\n);\n","\"use client\";\n\nimport {\n ActionButtonProps,\n createActionButton,\n} from \"../../utils/createActionButton\";\nimport { useThreadSuggestion } from \"../../primitive-hooks/thread/useThreadSuggestion\";\n\nexport type ThreadPrimitiveSuggestionProps = ActionButtonProps<\n typeof useThreadSuggestion\n>;\n\nexport const ThreadPrimitiveSuggestion = createActionButton(\n \"ThreadPrimitive.Suggestion\",\n useThreadSuggestion,\n [\"prompt\", \"autoSend\", \"method\"],\n);\n","\"use client\";\n\nimport {\n ComponentType,\n FC,\n PropsWithChildren,\n ReactNode,\n createContext,\n useContext,\n} from \"react\";\n\nimport { AvatarProps } from \"./base/avatar\";\nimport { TextContentPartComponent, ToolCallContentPartProps } from \"../types\";\nimport { AssistantRuntime } from \"../runtimes\";\nimport { AssistantRuntimeProvider, useAssistantContext } from \"../context\";\nimport { AssistantToolUI } from \"../model-config\";\n\nexport type SuggestionConfig = {\n text?: ReactNode;\n prompt: string;\n};\n\nexport type ThreadWelcomeConfig = {\n message?: string | null | undefined;\n suggestions?: SuggestionConfig[] | undefined;\n};\n\nexport type UserMessageConfig = {\n allowEdit?: boolean | undefined;\n};\n\nexport type AssistantMessageConfig = {\n allowReload?: boolean | undefined;\n allowCopy?: boolean | undefined;\n allowSpeak?: boolean | undefined;\n components?:\n | {\n Text?: TextContentPartComponent | undefined;\n ToolFallback?: ComponentType<ToolCallContentPartProps> | undefined;\n }\n | undefined;\n};\n\nexport type BranchPickerConfig = {\n allowBranchPicker?: boolean | undefined;\n};\n\nexport type StringsConfig = {\n assistantModal?: {\n open: {\n button: {\n tooltip?: string | undefined;\n };\n };\n closed: {\n button: {\n tooltip?: string | undefined;\n };\n };\n };\n thread?: {\n scrollToBottom?: {\n tooltip?: string | undefined;\n };\n };\n userMessage?: {\n edit?: {\n tooltip?: string | undefined;\n };\n };\n assistantMessage?: {\n reload?: {\n tooltip?: string | undefined;\n };\n copy?: {\n tooltip?: string | undefined;\n };\n speak?: {\n tooltip?: string | undefined;\n stop?: {\n tooltip?: string | undefined;\n };\n };\n };\n branchPicker?: {\n previous?: {\n tooltip?: string | undefined;\n };\n next?: {\n tooltip?: string | undefined;\n };\n };\n composer?: {\n send?:\n | {\n tooltip?: string | undefined;\n }\n | undefined;\n cancel?:\n | {\n tooltip?: string | undefined;\n }\n | undefined;\n input?: {\n placeholder?: string | undefined;\n };\n };\n editComposer?: {\n send?: {\n label?: string | undefined;\n };\n cancel?: {\n label?: string | undefined;\n };\n };\n code?: {\n header?: {\n copy?: {\n tooltip?: string | undefined;\n };\n };\n };\n};\n\nconst ThreadConfigContext = createContext<ThreadConfig>({});\n\nexport type ThreadConfig = {\n runtime?: AssistantRuntime;\n\n assistantAvatar?: AvatarProps;\n\n welcome?: ThreadWelcomeConfig;\n assistantMessage?: AssistantMessageConfig;\n userMessage?: UserMessageConfig;\n\n branchPicker?: BranchPickerConfig;\n\n strings?: StringsConfig;\n\n tools?: AssistantToolUI[]; // TODO add AssistantTool support\n};\n\nexport const useThreadConfig = (): Omit<ThreadConfig, \"runtime\"> => {\n return useContext(ThreadConfigContext);\n};\n\nexport type ThreadConfigProviderProps = PropsWithChildren<{\n config?: ThreadConfig | undefined;\n}>;\n\nexport const ThreadConfigProvider: FC<ThreadConfigProviderProps> = ({\n children,\n config,\n}) => {\n const assistant = useAssistantContext({ optional: true });\n\n const configProvider =\n config && Object.keys(config ?? {}).length > 0 ? (\n <ThreadConfigContext.Provider value={config}>\n {children}\n </ThreadConfigContext.Provider>\n ) : (\n <>{children}</>\n );\n if (!config?.runtime) return configProvider;\n\n if (assistant) {\n throw new Error(\n \"You provided a runtime to <Thread> while simulataneously using <AssistantRuntimeProvider>. This is not allowed.\",\n );\n }\n return (\n <AssistantRuntimeProvider runtime={config.runtime}>\n {configProvider}\n </AssistantRuntimeProvider>\n );\n};\n\nThreadConfigProvider.displayName = \"ThreadConfigProvider\";\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\nimport {\n AudioLinesIcon,\n CheckIcon,\n CopyIcon,\n RefreshCwIcon,\n StopCircleIcon,\n} from \"lucide-react\";\nimport { ActionBarPrimitive, MessagePrimitive } from \"../primitives\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { useThreadContext } from \"../context\";\n\nconst useAllowCopy = (ensureCapability = false) => {\n const { assistantMessage: { allowCopy = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const copySupported = useThread((t) => t.capabilities.unstable_copy);\n return allowCopy && (!ensureCapability || copySupported);\n};\n\nconst useAllowSpeak = (ensureCapability = false) => {\n const { assistantMessage: { allowSpeak = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const speakSupported = useThread((t) => t.capabilities.speak);\n return allowSpeak && (!ensureCapability || speakSupported);\n};\n\nconst useAllowReload = (ensureCapability = false) => {\n const { assistantMessage: { allowReload = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const reloadSupported = useThread((t) => t.capabilities.reload);\n return allowReload && (!ensureCapability || reloadSupported);\n};\n\nconst AssistantActionBar: FC = () => {\n const allowCopy = useAllowCopy(true);\n const allowReload = useAllowReload(true);\n const allowSpeak = useAllowSpeak(true);\n if (!allowCopy && !allowReload && !allowSpeak) return null;\n return (\n <AssistantActionBarRoot\n hideWhenRunning\n autohide=\"not-last\"\n autohideFloat=\"single-branch\"\n >\n {allowSpeak && <AssistantActionBarSpeechControl />}\n {allowCopy && <AssistantActionBarCopy />}\n {allowReload && <AssistantActionBarReload />}\n </AssistantActionBarRoot>\n );\n};\n\nAssistantActionBar.displayName = \"AssistantActionBar\";\n\nconst AssistantActionBarRoot = withDefaults(ActionBarPrimitive.Root, {\n className: \"aui-assistant-action-bar-root\",\n});\n\nAssistantActionBarRoot.displayName = \"AssistantActionBarRoot\";\n\nconst AssistantActionBarCopy = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { copy: { tooltip = \"Copy\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n\n return (\n <ActionBarPrimitive.Copy asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? (\n <>\n <MessagePrimitive.If copied>\n <CheckIcon />\n </MessagePrimitive.If>\n <MessagePrimitive.If copied={false}>\n <CopyIcon />\n </MessagePrimitive.If>\n </>\n )}\n </TooltipIconButton>\n </ActionBarPrimitive.Copy>\n );\n});\n\nAssistantActionBarCopy.displayName = \"AssistantActionBarCopy\";\n\nconst AssistantActionBarSpeechControl: FC = () => {\n return (\n <>\n <MessagePrimitive.If speaking={false}>\n <AssistantActionBarSpeak />\n </MessagePrimitive.If>\n <MessagePrimitive.If speaking>\n <AssistantActionBarStopSpeaking />\n </MessagePrimitive.If>\n </>\n );\n};\n\nconst AssistantActionBarSpeak = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { speak: { tooltip = \"Read aloud\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n const allowSpeak = useAllowSpeak();\n if (!allowSpeak) return null;\n return (\n <ActionBarPrimitive.Speak asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <AudioLinesIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.Speak>\n );\n});\n\nAssistantActionBarSpeak.displayName = \"AssistantActionBarSpeak\";\n\nconst AssistantActionBarStopSpeaking = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: {\n speak: { stop: { tooltip: stopTooltip = \"Stop\" } = {} } = {},\n } = {},\n } = {},\n } = useThreadConfig();\n const allowSpeak = useAllowSpeak();\n if (!allowSpeak) return null;\n return (\n <ActionBarPrimitive.StopSpeaking asChild>\n <TooltipIconButton tooltip={stopTooltip} {...props} ref={ref}>\n {props.children ?? <StopCircleIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.StopSpeaking>\n );\n});\n\nAssistantActionBarStopSpeaking.displayName = \"AssistantActionBarStopSpeaking\";\n\nconst AssistantActionBarReload = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n assistantMessage: { reload: { tooltip = \"Refresh\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n const allowReload = useAllowReload();\n if (!allowReload) return null;\n return (\n <ActionBarPrimitive.Reload asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n <RefreshCwIcon />\n </TooltipIconButton>\n </ActionBarPrimitive.Reload>\n );\n});\n\nAssistantActionBarReload.displayName = \"AssistantActionBarReload\";\n\nconst exports = {\n Root: AssistantActionBarRoot,\n Reload: AssistantActionBarReload,\n Copy: AssistantActionBarCopy,\n Speak: AssistantActionBarSpeak,\n StopSpeaking: AssistantActionBarStopSpeaking,\n SpeechControl: AssistantActionBarSpeechControl,\n};\n\nexport default Object.assign(\n AssistantActionBar,\n exports,\n) as typeof AssistantActionBar & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { MessagePrimitive, MessagePrimitiveContentProps } from \"../primitives\";\nimport BranchPicker from \"./branch-picker\";\nimport { Avatar } from \"./base/avatar\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport AssistantActionBar from \"./assistant-action-bar\";\nimport ContentPart from \"./content-part\";\n\nconst AssistantMessage: FC = () => {\n return (\n <AssistantMessageRoot>\n <AssistantMessageAvatar />\n <AssistantMessageContent />\n <BranchPicker />\n <AssistantActionBar />\n </AssistantMessageRoot>\n );\n};\n\nAssistantMessage.displayName = \"AssistantMessage\";\n\nconst AssistantMessageAvatar: FC = () => {\n const { assistantAvatar: avatar = { fallback: \"A\" } } = useThreadConfig();\n return <Avatar {...avatar} />;\n};\n\nconst AssistantMessageRoot = withDefaults(MessagePrimitive.Root, {\n className: \"aui-assistant-message-root\",\n});\n\nAssistantMessageRoot.displayName = \"AssistantMessageRoot\";\n\nconst AssistantMessageContentWrapper = withDefaults(\"div\", {\n className: \"aui-assistant-message-content\",\n});\n\nexport type AssistantMessageContentProps = MessagePrimitiveContentProps &\n ComponentPropsWithoutRef<\"div\">;\n\nconst AssistantMessageContent = forwardRef<\n HTMLDivElement,\n AssistantMessageContentProps\n>(({ components: componentsProp, ...rest }, ref) => {\n const { tools, assistantMessage: { components = {} } = {} } =\n useThreadConfig();\n\n return (\n <AssistantMessageContentWrapper {...rest} ref={ref}>\n <MessagePrimitive.Content\n components={{\n ...componentsProp,\n Text: componentsProp?.Text ?? components.Text ?? ContentPart.Text,\n tools: {\n by_name: !tools\n ? undefined\n : Object.fromEntries(\n tools.map((t) => [\n t.unstable_tool.toolName,\n t.unstable_tool.render,\n ]),\n ),\n Fallback: components.ToolFallback,\n },\n }}\n />\n </AssistantMessageContentWrapper>\n );\n});\n\nAssistantMessageContent.displayName = \"AssistantMessageContent\";\n\nconst exports = {\n Root: AssistantMessageRoot,\n Avatar: AssistantMessageAvatar,\n Content: AssistantMessageContent,\n};\n\nexport default Object.assign(\n AssistantMessage,\n exports,\n) as typeof AssistantMessage & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { ChevronLeftIcon, ChevronRightIcon } from \"lucide-react\";\n\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { BranchPickerPrimitive } from \"../primitives\";\nimport { useThreadContext } from \"../context\";\n\nconst useAllowBranchPicker = () => {\n const { branchPicker: { allowBranchPicker = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const branchPickerSupported = useThread((t) => t.capabilities.edit);\n return branchPickerSupported && allowBranchPicker;\n};\n\nconst BranchPicker: FC = () => {\n const allowBranchPicker = useAllowBranchPicker();\n if (!allowBranchPicker) return null;\n return (\n <BranchPickerRoot hideWhenSingleBranch>\n <BranchPickerPrevious />\n <BranchPickerState />\n <BranchPickerNext />\n </BranchPickerRoot>\n );\n};\n\nBranchPicker.displayName = \"BranchPicker\";\n\nconst BranchPickerRoot = withDefaults(BranchPickerPrimitive.Root, {\n className: \"aui-branch-picker-root\",\n});\n\nBranchPickerRoot.displayName = \"BranchPickerRoot\";\n\nconst BranchPickerPrevious = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n branchPicker: { previous: { tooltip = \"Previous\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <BranchPickerPrimitive.Previous asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ChevronLeftIcon />}\n </TooltipIconButton>\n </BranchPickerPrimitive.Previous>\n );\n});\n\nBranchPickerPrevious.displayName = \"BranchPickerPrevious\";\n\nconst BranchPickerStateWrapper = withDefaults(\"span\", {\n className: \"aui-branch-picker-state\",\n});\n\nconst BranchPickerState = forwardRef<\n HTMLSpanElement,\n ComponentPropsWithoutRef<\"span\">\n>((props, ref) => {\n return (\n <BranchPickerStateWrapper {...props} ref={ref}>\n <BranchPickerPrimitive.Number /> / <BranchPickerPrimitive.Count />\n </BranchPickerStateWrapper>\n );\n});\n\nBranchPickerState.displayName = \"BranchPickerState\";\n\nconst BranchPickerNext = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { branchPicker: { next: { tooltip = \"Next\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <BranchPickerPrimitive.Next asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ChevronRightIcon />}\n </TooltipIconButton>\n </BranchPickerPrimitive.Next>\n );\n});\n\nBranchPickerNext.displayName = \"BranchPickerNext\";\n\nconst exports = {\n Root: BranchPickerRoot,\n Previous: BranchPickerPrevious,\n Next: BranchPickerNext,\n};\n\nexport default Object.assign(BranchPicker, exports) as typeof BranchPicker &\n typeof exports;\n","\"use client\";\n\nimport type { FC } from \"react\";\nimport * as AvatarPrimitive from \"@radix-ui/react-avatar\";\n\nimport { withDefaults } from \"../utils/withDefaults\";\n\nexport type AvatarProps = {\n src?: string | undefined;\n alt?: string | undefined;\n fallback?: string | undefined;\n};\n\nexport const Avatar: FC<AvatarProps> = ({ src, alt, fallback }) => {\n if (src == null && fallback == null) return null;\n\n return (\n <AvatarRoot>\n {src != null && <AvatarImage src={src} alt={alt} />}\n {fallback != null && <AvatarFallback>{fallback}</AvatarFallback>}\n </AvatarRoot>\n );\n};\n\nAvatar.displayName = \"Avatar\";\n\nexport const AvatarRoot = withDefaults(AvatarPrimitive.Root, {\n className: \"aui-avatar-root\",\n});\n\nAvatarRoot.displayName = \"AvatarRoot\";\n\nexport const AvatarImage = withDefaults(AvatarPrimitive.Image, {\n className: \"aui-avatar-image\",\n});\n\nAvatarImage.displayName = \"AvatarImage\";\n\nexport const AvatarFallback = withDefaults(AvatarPrimitive.Fallback, {\n className: \"aui-avatar-fallback\",\n});\n\nAvatarFallback.displayName = \"AvatarFallback\";\n","import { FC } from \"react\";\nimport { ContentPartPrimitive } from \"../primitives\";\nimport { useSmoothStatus, withSmoothContextProvider } from \"../utils/smooth\";\nimport classNames from \"classnames\";\n\nexport const Text: FC = () => {\n const status = useSmoothStatus();\n return (\n <ContentPartPrimitive.Text\n className={classNames(\n \"aui-text\",\n status.type === \"running\" && \"aui-text-running\",\n )}\n component=\"p\"\n />\n );\n};\n\nconst exports = { Text: withSmoothContextProvider(Text) };\n\nexport default exports;\n","\"use client\";\n\nimport { type FC, forwardRef } from \"react\";\nimport { BotIcon, ChevronDownIcon } from \"lucide-react\";\n\nimport {\n AssistantModalPrimitive,\n AssistantModalPrimitiveRootProps,\n} from \"../primitives\";\nimport Thread from \"./thread\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport {\n ThreadConfig,\n ThreadConfigProvider,\n ThreadConfigProviderProps,\n useThreadConfig,\n} from \"./thread-config\";\n\nconst AssistantModal: FC<ThreadConfig> = (config) => {\n return (\n <AssistantModalRoot config={config}>\n <AssistantModalTrigger />\n <AssistantModalContent>\n <Thread />\n </AssistantModalContent>\n </AssistantModalRoot>\n );\n};\n\nAssistantModal.displayName = \"AssistantModal\";\n\nconst AssistantModalRoot: FC<\n AssistantModalPrimitiveRootProps & ThreadConfigProviderProps\n> = ({ config, ...props }) => {\n return (\n <ThreadConfigProvider config={config}>\n <AssistantModalPrimitive.Root {...props} />\n </ThreadConfigProvider>\n );\n};\n\nAssistantModalRoot.displayName = \"AssistantModalRoot\";\n\nconst AssistantModalTrigger = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n return (\n <AssistantModalAnchor>\n <AssistantModalPrimitive.Trigger asChild>\n <AssistantModalButton {...props} ref={ref} />\n </AssistantModalPrimitive.Trigger>\n </AssistantModalAnchor>\n );\n});\n\nAssistantModalTrigger.displayName = \"AssistantModalTrigger\";\n\nconst AssistantModalAnchor = withDefaults(AssistantModalPrimitive.Anchor, {\n className: \"aui-root aui-modal-anchor\",\n});\n\nAssistantModalAnchor.displayName = \"AssistantModalAnchor\";\n\nconst ModalButtonStyled = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-modal-button\",\n});\n\ntype AssistantModalButtonProps = TooltipIconButtonProps & {\n \"data-state\"?: \"open\" | \"closed\";\n};\n\nconst AssistantModalButton = forwardRef<\n HTMLButtonElement,\n Partial<AssistantModalButtonProps>\n>(({ \"data-state\": state, ...rest }, ref) => {\n const {\n strings: {\n assistantModal: {\n open: {\n button: { tooltip: openTooltip = \"Close Assistant\" } = {},\n } = {},\n closed: {\n button: { tooltip: closedTooltip = \"Open Assistant\" } = {},\n } = {},\n } = {},\n } = {},\n } = useThreadConfig();\n const tooltip = state === \"open\" ? openTooltip : closedTooltip;\n\n return (\n <ModalButtonStyled\n side=\"left\"\n tooltip={tooltip}\n data-state={state}\n {...rest}\n ref={ref}\n >\n {rest.children ?? (\n <>\n <BotIcon\n data-state={state}\n className=\"aui-modal-button-closed-icon\"\n />\n <ChevronDownIcon\n data-state={state}\n className=\"aui-modal-button-open-icon\"\n />\n </>\n )}\n </ModalButtonStyled>\n );\n});\n\nAssistantModalButton.displayName = \"AssistantModalButton\";\n\nconst AssistantModalContent = withDefaults(AssistantModalPrimitive.Content, {\n className: \"aui-root aui-modal-content\",\n sideOffset: 16,\n});\n\nAssistantModalContent.displayName = \"AssistantModalContent\";\n\nconst exports = {\n Root: AssistantModalRoot,\n Trigger: AssistantModalTrigger,\n Content: AssistantModalContent,\n Button: AssistantModalButton,\n Anchor: AssistantModalAnchor,\n};\n\nexport default Object.assign(AssistantModal, exports) as typeof AssistantModal &\n typeof exports;\n","\"use client\";\n\nimport { ComponentType, forwardRef, type FC } from \"react\";\nimport { ArrowDownIcon } from \"lucide-react\";\n\nimport { withDefaults } from \"./utils/withDefaults\";\nimport Composer from \"./composer\";\nimport ThreadWelcome from \"./thread-welcome\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport AssistantMessage from \"./assistant-message\";\nimport UserMessage from \"./user-message\";\nimport EditComposer from \"./edit-composer\";\nimport {\n ThreadConfig,\n ThreadConfigProvider,\n ThreadConfigProviderProps,\n useThreadConfig,\n} from \"./thread-config\";\nimport { ThreadPrimitive, ThreadPrimitiveRootProps } from \"../primitives\";\n\nconst Thread: FC<ThreadConfig> = (config) => {\n return (\n <ThreadRoot config={config}>\n <ThreadViewport>\n <ThreadWelcome />\n <ThreadMessages />\n <ThreadViewportFooter>\n <ThreadScrollToBottom />\n <Composer />\n </ThreadViewportFooter>\n </ThreadViewport>\n </ThreadRoot>\n );\n};\n\nexport type ThreadRootProps = ThreadPrimitiveRootProps &\n ThreadConfigProviderProps;\n\nconst ThreadRootStyled = withDefaults(ThreadPrimitive.Root, {\n className: \"aui-root aui-thread-root\",\n});\n\nconst ThreadRoot = forwardRef<HTMLDivElement, ThreadRootProps>(\n ({ config, ...props }, ref) => {\n return (\n <ThreadConfigProvider config={config}>\n <ThreadRootStyled {...props} ref={ref} />\n </ThreadConfigProvider>\n );\n },\n);\n\nThreadRoot.displayName = \"ThreadRoot\";\n\nconst ThreadViewport = withDefaults(ThreadPrimitive.Viewport, {\n className: \"aui-thread-viewport\",\n});\n\nThreadViewport.displayName = \"ThreadViewport\";\n\nconst ThreadViewportFooter = withDefaults(\"div\", {\n className: \"aui-thread-viewport-footer\",\n});\n\nThreadViewportFooter.displayName = \"ThreadViewportFooter\";\n\nconst SystemMessage = () => null;\n\nconst ThreadMessages: FC<{\n components?: {\n UserMessage?: ComponentType | undefined;\n EditComposer?: ComponentType | undefined;\n AssistantMessage?: ComponentType | undefined;\n SystemMessage?: ComponentType | undefined;\n };\n}> = ({ components, ...rest }) => {\n return (\n <ThreadPrimitive.Messages\n components={{\n UserMessage: components?.UserMessage ?? UserMessage,\n EditComposer: components?.EditComposer ?? EditComposer,\n AssistantMessage: components?.AssistantMessage ?? AssistantMessage,\n SystemMessage: components?.SystemMessage ?? SystemMessage,\n }}\n {...rest}\n />\n );\n};\n\nThreadMessages.displayName = \"ThreadMessages\";\n\nconst ThreadScrollToBottomIconButton = withDefaults(TooltipIconButton, {\n variant: \"outline\",\n className: \"aui-thread-scroll-to-bottom\",\n});\n\nconst ThreadScrollToBottom = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: {\n thread: { scrollToBottom: { tooltip = \"Scroll to bottom\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ThreadPrimitive.ScrollToBottom asChild>\n <ThreadScrollToBottomIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <ArrowDownIcon />}\n </ThreadScrollToBottomIconButton>\n </ThreadPrimitive.ScrollToBottom>\n );\n});\n\nThreadScrollToBottom.displayName = \"ThreadScrollToBottom\";\n\nconst exports = {\n Root: ThreadRoot,\n Viewport: ThreadViewport,\n Messages: ThreadMessages,\n ScrollToBottom: ThreadScrollToBottom,\n ViewportFooter: ThreadViewportFooter,\n};\n\nexport default Object.assign(Thread, exports) as typeof Thread & typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\n\nimport { SendHorizontalIcon } from \"lucide-react\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { CircleStopIcon } from \"./base/CircleStopIcon\";\nimport { ComposerPrimitive, ThreadPrimitive } from \"../primitives\";\nimport { useThreadContext } from \"../context\";\n\nconst Composer: FC = () => {\n return (\n <ComposerRoot>\n <ComposerInput autoFocus />\n <ComposerAction />\n </ComposerRoot>\n );\n};\n\nComposer.displayName = \"Composer\";\n\nconst ComposerRoot = withDefaults(ComposerPrimitive.Root, {\n className: \"aui-composer-root\",\n});\n\nComposerRoot.displayName = \"ComposerRoot\";\n\nconst ComposerInputStyled = withDefaults(ComposerPrimitive.Input, {\n rows: 1,\n autoFocus: true,\n className: \"aui-composer-input\",\n});\n\nexport type ComposerInputProps = ComponentPropsWithoutRef<\n typeof ComposerInputStyled\n>;\nconst ComposerInput = forwardRef<HTMLTextAreaElement, ComposerInputProps>(\n (props, ref) => {\n const {\n strings: {\n composer: { input: { placeholder = \"Write a message...\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ComposerInputStyled placeholder={placeholder} {...props} ref={ref} />\n );\n },\n);\n\nComposerInput.displayName = \"ComposerInput\";\n\nconst useAllowCancel = () => {\n const { useThread } = useThreadContext();\n const cancelSupported = useThread((t) => t.capabilities.cancel);\n return cancelSupported;\n};\n\nconst ComposerAction: FC = () => {\n const allowCancel = useAllowCancel();\n if (!allowCancel) return <ComposerSend />;\n return (\n <>\n <ThreadPrimitive.If running={false}>\n <ComposerSend />\n </ThreadPrimitive.If>\n <ThreadPrimitive.If running>\n <ComposerCancel />\n </ThreadPrimitive.If>\n </>\n );\n};\n\nComposerAction.displayName = \"ComposerAction\";\n\nconst ComposerSendButton = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-composer-send\",\n});\n\nconst ComposerSend = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { composer: { send: { tooltip = \"Send\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Send asChild>\n <ComposerSendButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <SendHorizontalIcon />}\n </ComposerSendButton>\n </ComposerPrimitive.Send>\n );\n});\n\nComposerSend.displayName = \"ComposerSend\";\n\nconst ComposerCancelButton = withDefaults(TooltipIconButton, {\n variant: \"default\",\n className: \"aui-composer-cancel\",\n});\n\nconst ComposerCancel = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { composer: { cancel: { tooltip = \"Cancel\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Cancel asChild>\n <ComposerCancelButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <CircleStopIcon />}\n </ComposerCancelButton>\n </ComposerPrimitive.Cancel>\n );\n});\n\nComposerCancel.displayName = \"ComposerCancel\";\n\nconst exports = {\n Root: ComposerRoot,\n Input: ComposerInput,\n Action: ComposerAction,\n Send: ComposerSend,\n Cancel: ComposerCancel,\n};\n\nexport default Object.assign(Composer, exports) as typeof Composer &\n typeof exports;\n","import { FC } from \"react\";\n\nexport const CircleStopIcon: FC = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 16 16\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n >\n <rect width=\"10\" height=\"10\" x=\"3\" y=\"3\" rx=\"2\" />\n </svg>\n );\n};\n\nCircleStopIcon.displayName = \"CircleStopIcon\";\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { Avatar } from \"./base/avatar\";\nimport { SuggestionConfig, useThreadConfig } from \"./thread-config\";\nimport { ThreadPrimitive } from \"../primitives\";\n\nconst ThreadWelcome: FC = () => {\n return (\n <ThreadWelcomeRoot>\n <ThreadWelcomeCenter>\n <ThreadWelcomeAvatar />\n <ThreadWelcomeMessage />\n </ThreadWelcomeCenter>\n <ThreadWelcomeSuggestions />\n </ThreadWelcomeRoot>\n );\n};\n\nThreadWelcome.displayName = \"ThreadWelcome\";\n\nconst ThreadWelcomeRootStyled = withDefaults(\"div\", {\n className: \"aui-thread-welcome-root\",\n});\n\nconst ThreadWelcomeCenter = withDefaults(\"div\", {\n className: \"aui-thread-welcome-center\",\n});\n\ntype ThreadWelcomeRootProps = ComponentPropsWithoutRef<\"div\">;\n\nconst ThreadWelcomeRoot = forwardRef<HTMLDivElement, ThreadWelcomeRootProps>(\n (props, ref) => {\n return (\n <ThreadPrimitive.Empty>\n <ThreadWelcomeRootStyled {...props} ref={ref} />\n </ThreadPrimitive.Empty>\n );\n },\n);\n\nThreadWelcomeRoot.displayName = \"ThreadWelcomeRoot\";\n\nconst ThreadWelcomeAvatar: FC = () => {\n const { assistantAvatar: avatar = { fallback: \"A\" } } = useThreadConfig();\n return <Avatar {...avatar} />;\n};\n\nconst ThreadWelcomeMessageStyled = withDefaults(\"p\", {\n className: \"aui-thread-welcome-message\",\n});\n\nexport type ThreadWelcomeMessageProps = Omit<\n ComponentPropsWithoutRef<typeof ThreadWelcomeMessageStyled>,\n \"children\"\n> & { message?: string | undefined };\n\nconst ThreadWelcomeMessage = forwardRef<\n HTMLParagraphElement,\n ThreadWelcomeMessageProps\n>(({ message: messageProp, ...rest }, ref) => {\n const { welcome: { message = \"How can I help you today?\" } = {} } =\n useThreadConfig();\n return (\n <ThreadWelcomeMessageStyled {...rest} ref={ref}>\n {messageProp ?? message}\n </ThreadWelcomeMessageStyled>\n );\n});\n\nThreadWelcomeMessage.displayName = \"ThreadWelcomeMessage\";\n\nconst ThreadWelcomeSuggestionContainer = withDefaults(\"div\", {\n className: \"aui-thread-welcome-suggestion-container\",\n});\n\nconst ThreadWelcomeSuggestionStyled = withDefaults(ThreadPrimitive.Suggestion, {\n className: \"aui-thread-welcome-suggestion\",\n});\n\nexport type ThreadWelcomeSuggestionProps = {\n suggestion: SuggestionConfig;\n};\n\nconst ThreadWelcomeSuggestion: FC<ThreadWelcomeSuggestionProps> = ({\n suggestion: { text, prompt },\n}) => {\n return (\n <ThreadWelcomeSuggestionStyled\n prompt={prompt}\n method=\"replace\"\n autoSend\n >\n <span className=\"aui-thread-welcome-suggestion-text\">{text ?? prompt}</span>\n </ThreadWelcomeSuggestionStyled>\n );\n};\n\nconst ThreadWelcomeSuggestions: FC = () => {\n const { welcome: { suggestions } = {} } = useThreadConfig();\n return (\n <ThreadWelcomeSuggestionContainer>\n {suggestions?.map((suggestion, idx) => {\n const key = `${suggestion.prompt}-${idx}`;\n return <ThreadWelcomeSuggestion key={key} suggestion={suggestion} />;\n })}\n </ThreadWelcomeSuggestionContainer>\n );\n};\n\nThreadWelcomeSuggestions.displayName = \"ThreadWelcomeSuggestions\";\n\nconst exports = {\n Root: ThreadWelcomeRoot,\n Center: ThreadWelcomeCenter,\n Avatar: ThreadWelcomeAvatar,\n Message: ThreadWelcomeMessage,\n Suggestions: ThreadWelcomeSuggestions,\n Suggestion: ThreadWelcomeSuggestion,\n};\n\nexport default Object.assign(ThreadWelcome, exports) as typeof ThreadWelcome &\n typeof exports;\n","\"use client\";\n\nimport { ComponentPropsWithoutRef, forwardRef, type FC } from \"react\";\n\nimport BranchPicker from \"./branch-picker\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport UserActionBar from \"./user-action-bar\";\nimport ContentPart from \"./content-part\";\nimport { MessagePrimitive, MessagePrimitiveContentProps } from \"../primitives\";\n\nconst UserMessage: FC = () => {\n return (\n <UserMessageRoot>\n <UserActionBar />\n <UserMessageContent />\n <BranchPicker />\n </UserMessageRoot>\n );\n};\n\nUserMessage.displayName = \"UserMessage\";\n\nconst UserMessageRoot = withDefaults(MessagePrimitive.Root, {\n className: \"aui-user-message-root\",\n});\n\nUserMessageRoot.displayName = \"UserMessageRoot\";\n\nconst UserMessageContentWrapper = withDefaults(\"div\", {\n className: \"aui-user-message-content\",\n});\n\nexport type UserMessageContentProps = MessagePrimitiveContentProps &\n ComponentPropsWithoutRef<\"div\">;\n\nconst UserMessageContent = forwardRef<HTMLDivElement, UserMessageContentProps>(\n ({ components, ...props }, ref) => {\n return (\n <UserMessageContentWrapper {...props} ref={ref}>\n <MessagePrimitive.Content\n components={{\n ...components,\n Text: components?.Text ?? ContentPart.Text,\n }}\n />\n </UserMessageContentWrapper>\n );\n },\n);\n\nUserMessageContent.displayName = \"UserMessageContent\";\n\nconst exports = {\n Root: UserMessageRoot,\n Content: UserMessageContent,\n};\n\nexport default Object.assign(UserMessage, exports) as typeof UserMessage &\n typeof exports;\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\nimport { PencilIcon } from \"lucide-react\";\n\nimport {\n TooltipIconButton,\n TooltipIconButtonProps,\n} from \"./base/tooltip-icon-button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { useThreadContext } from \"../context\";\nimport { ActionBarPrimitive } from \"../primitives\";\n\nconst useAllowEdit = (ensureCapability = false) => {\n const { userMessage: { allowEdit = true } = {} } = useThreadConfig();\n const { useThread } = useThreadContext();\n const editSupported = useThread((t) => t.capabilities.edit);\n return allowEdit && (!ensureCapability || editSupported);\n};\n\nconst UserActionBar: FC = () => {\n const allowEdit = useAllowEdit(true);\n if (!allowEdit) return null;\n return (\n <UserActionBarRoot hideWhenRunning autohide=\"not-last\">\n <UserActionBarEdit />\n </UserActionBarRoot>\n );\n};\n\nUserActionBar.displayName = \"UserActionBar\";\n\nconst UserActionBarRoot = withDefaults(ActionBarPrimitive.Root, {\n className: \"aui-user-action-bar-root\",\n});\n\nUserActionBarRoot.displayName = \"UserActionBarRoot\";\n\nconst UserActionBarEdit = forwardRef<\n HTMLButtonElement,\n Partial<TooltipIconButtonProps>\n>((props, ref) => {\n const {\n strings: { userMessage: { edit: { tooltip = \"Edit\" } = {} } = {} } = {},\n } = useThreadConfig();\n const allowEdit = useAllowEdit();\n if (!allowEdit) return null;\n return (\n <ActionBarPrimitive.Edit asChild>\n <TooltipIconButton tooltip={tooltip} {...props} ref={ref}>\n {props.children ?? <PencilIcon />}\n </TooltipIconButton>\n </ActionBarPrimitive.Edit>\n );\n});\n\nUserActionBarEdit.displayName = \"UserActionBarEdit\";\n\nconst exports = {\n Root: UserActionBarRoot,\n Edit: UserActionBarEdit,\n};\n\nexport default Object.assign(UserActionBar, exports) as typeof UserActionBar &\n typeof exports;\n","\"use client\";\n\nimport { forwardRef, type FC } from \"react\";\n\nimport { Button, ButtonProps } from \"./base/button\";\nimport { withDefaults } from \"./utils/withDefaults\";\nimport { useThreadConfig } from \"./thread-config\";\nimport { ComposerPrimitive } from \"../primitives\";\n\nconst EditComposer: FC = () => {\n return (\n <EditComposerRoot>\n <EditComposerInput />\n\n <EditComposerFooter>\n <EditComposerCancel />\n <EditComposerSend />\n </EditComposerFooter>\n </EditComposerRoot>\n );\n};\n\nEditComposer.displayName = \"EditComposer\";\n\nconst EditComposerRoot = withDefaults(ComposerPrimitive.Root, {\n className: \"aui-edit-composer-root\",\n});\n\nEditComposerRoot.displayName = \"EditComposerRoot\";\n\nconst EditComposerInput = withDefaults(ComposerPrimitive.Input, {\n className: \"aui-edit-composer-input\",\n});\n\nEditComposerInput.displayName = \"EditComposerInput\";\n\nconst EditComposerFooter = withDefaults(\"div\", {\n className: \"aui-edit-composer-footer\",\n});\n\nEditComposerFooter.displayName = \"EditComposerFooter\";\n\nconst EditComposerCancel = forwardRef<HTMLButtonElement, Partial<ButtonProps>>(\n (props, ref) => {\n const {\n strings: {\n editComposer: { cancel: { label = \"Cancel\" } = {} } = {},\n } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Cancel asChild>\n <Button variant=\"ghost\" {...props} ref={ref}>\n {props.children ?? label}\n </Button>\n </ComposerPrimitive.Cancel>\n );\n },\n);\n\nEditComposerCancel.displayName = \"EditComposerCancel\";\n\nconst EditComposerSend = forwardRef<HTMLButtonElement, Partial<ButtonProps>>(\n (props, ref) => {\n const {\n strings: { editComposer: { send: { label = \"Send\" } = {} } = {} } = {},\n } = useThreadConfig();\n return (\n <ComposerPrimitive.Send asChild>\n <Button {...props} ref={ref}>\n {props.children ?? label}\n </Button>\n </ComposerPrimitive.Send>\n );\n },\n);\n\nEditComposerSend.displayName = \"EditComposerSend\";\n\nconst exports = {\n Root: EditComposerRoot,\n Input: EditComposerInput,\n Footer: EditComposerFooter,\n Cancel: EditComposerCancel,\n Send: EditComposerSend,\n};\n\nexport default Object.assign(EditComposer, exports) as typeof EditComposer &\n typeof exports;\n"]}
|