@aomi-labs/widget-lib 0.2.0 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/components/aomi-frame.tsx","../src/components/assistant-ui/thread.tsx","../src/components/ui/button.tsx","../src/lib/utils.ts","../src/components/assistant-ui/markdown-text.tsx","../src/components/assistant-ui/tooltip-icon-button.tsx","../src/components/ui/tooltip.tsx","../src/components/assistant-ui/tool-fallback.tsx","../src/components/assistant-ui/attachment.tsx","../src/components/ui/dialog.tsx","../src/components/ui/avatar.tsx","../src/lib/thread-context.tsx","../src/components/assistant-ui/threadlist-sidebar.tsx","../src/components/ui/sidebar.tsx","../src/hooks/use-mobile.ts","../src/components/ui/input.tsx","../src/components/ui/separator.tsx","../src/components/ui/sheet.tsx","../src/components/ui/skeleton.tsx","../src/components/assistant-ui/thread-list.tsx","../src/components/ui/breadcrumb.tsx","../src/components/assistant-ui/runtime.tsx","../src/lib/backend-api.ts","../src/lib/conversion.ts","../src/utils/wallet.ts","../src/components/assistant-ui/base-sidebar.tsx","../src/components/ui/card.tsx","../src/components/ui/badge.tsx","../src/components/ui/label.tsx"],"sourcesContent":["// @aomi-labs/widget-lib - Main Entry Point\n\n// ============================================\n// Main Frame Component\n// ============================================\nexport { AomiFrame } from \"./components/aomi-frame\";\n\n// ============================================\n// Runtime & Context Providers\n// ============================================\nexport {\n AomiRuntimeProvider,\n useRuntimeActions,\n} from \"./components/assistant-ui/runtime\";\nexport {\n ThreadContextProvider,\n useThreadContext,\n} from \"./lib/thread-context\";\n\n// ============================================\n// Assistant UI Components\n// ============================================\nexport { Thread } from \"./components/assistant-ui/thread\";\nexport { ThreadList } from \"./components/assistant-ui/thread-list\";\nexport { BaseSidebar } from \"./components/assistant-ui/base-sidebar\";\nexport { ThreadListSidebar } from \"./components/assistant-ui/threadlist-sidebar\";\nexport { MarkdownText } from \"./components/assistant-ui/markdown-text\";\nexport { ToolFallback } from \"./components/assistant-ui/tool-fallback\";\nexport { TooltipIconButton } from \"./components/assistant-ui/tooltip-icon-button\";\nexport {\n UserMessageAttachments,\n ComposerAttachments,\n} from \"./components/assistant-ui/attachment\";\n\n// ============================================\n// UI Components (shadcn-style)\n// ============================================\nexport { Button, buttonVariants } from \"./components/ui/button\";\nexport {\n Card,\n CardHeader,\n CardTitle,\n CardDescription,\n CardContent,\n CardFooter,\n} from \"./components/ui/card\";\nexport {\n Dialog,\n DialogTrigger,\n DialogPortal,\n DialogClose,\n DialogOverlay,\n DialogContent,\n DialogHeader,\n DialogFooter,\n DialogTitle,\n DialogDescription,\n} from \"./components/ui/dialog\";\nexport { Avatar, AvatarImage, AvatarFallback } from \"./components/ui/avatar\";\nexport {\n Tooltip,\n TooltipTrigger,\n TooltipContent,\n TooltipProvider,\n} from \"./components/ui/tooltip\";\nexport { Badge, badgeVariants } from \"./components/ui/badge\";\nexport { Input } from \"./components/ui/input\";\nexport { Label } from \"./components/ui/label\";\nexport { Separator } from \"./components/ui/separator\";\nexport { Skeleton } from \"./components/ui/skeleton\";\nexport {\n Breadcrumb,\n BreadcrumbList,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbPage,\n BreadcrumbSeparator,\n BreadcrumbEllipsis,\n} from \"./components/ui/breadcrumb\";\nexport {\n Sheet,\n SheetTrigger,\n SheetClose,\n SheetContent,\n SheetHeader,\n SheetFooter,\n SheetTitle,\n SheetDescription,\n} from \"./components/ui/sheet\";\nexport {\n Sidebar,\n SidebarProvider,\n useSidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarTrigger,\n SidebarRail,\n SidebarInset,\n SidebarSeparator,\n SidebarGroup,\n SidebarGroupLabel,\n SidebarGroupAction,\n SidebarGroupContent,\n SidebarMenuSub,\n SidebarMenuSubItem,\n SidebarMenuSubButton,\n SidebarMenuAction,\n SidebarMenuBadge,\n} from \"./components/ui/sidebar\";\n\n// ============================================\n// Wallet Types & Utilities\n// ============================================\nexport type { WalletButtonState, WalletFooterProps } from \"./utils/wallet\";\nexport { formatAddress, getNetworkName } from \"./utils/wallet\";\n\n// ============================================\n// Hooks\n// ============================================\nexport { useIsMobile } from \"./hooks/use-mobile\";\n\n// ============================================\n// Utilities\n// ============================================\nexport { cn } from \"./lib/utils\";\n","\"use client\";\n\nimport { useState, useCallback, type CSSProperties, type ReactNode } from \"react\";\nimport { Thread } from \"@/components/assistant-ui/thread\";\nimport { ThreadListSidebar } from \"@/components/assistant-ui/threadlist-sidebar\";\nimport {\n SidebarInset,\n SidebarProvider,\n SidebarTrigger,\n} from \"@/components/ui/sidebar\";\nimport { Separator } from \"@/components/ui/separator\";\nimport {\n Breadcrumb,\n BreadcrumbItem,\n BreadcrumbList,\n BreadcrumbSeparator,\n} from \"@/components/ui/breadcrumb\";\nimport { cn } from \"@/lib/utils\";\nimport { AomiRuntimeProvider } from \"@/components/assistant-ui/runtime\";\nimport { ThreadContextProvider, useCurrentThreadMetadata, useThreadContext } from \"@/lib/thread-context\";\nimport {\n WalletSystemMessageEmitter,\n type WalletButtonState,\n type WalletFooterProps,\n} from \"@/utils/wallet\";\n\ntype AomiFrameProps = {\n width?: CSSProperties[\"width\"];\n height?: CSSProperties[\"height\"];\n className?: string;\n style?: CSSProperties;\n /** Render prop for wallet footer - receives wallet state and setter from lib */\n walletFooter?: (props: WalletFooterProps) => ReactNode;\n /** Additional content to render inside the frame */\n children?: ReactNode;\n};\n\nexport const AomiFrame = ({\n width = \"100%\",\n height = \"80vh\",\n className,\n style,\n walletFooter,\n children,\n}: AomiFrameProps) => {\n const backendUrl = process.env.NEXT_PUBLIC_BACKEND_URL ?? \"http://localhost:8080\";\n const frameStyle: CSSProperties = { width, height, ...style };\n\n // Local wallet state (replaces Zustand)\n const [wallet, setWalletState] = useState<WalletButtonState>({\n isConnected: false,\n address: undefined,\n chainId: undefined,\n ensName: undefined,\n });\n\n const setWallet = useCallback((data: Partial<WalletButtonState>) => {\n setWalletState((prev) => ({ ...prev, ...data }));\n }, []);\n\n return (\n <ThreadContextProvider>\n <AomiRuntimeProvider backendUrl={backendUrl} publicKey={wallet.address}>\n {/* Internal: watches wallet state and sends system messages */}\n <WalletSystemMessageEmitter wallet={wallet} />\n <FrameShell\n className={className}\n frameStyle={frameStyle}\n walletFooter={walletFooter}\n wallet={wallet}\n setWallet={setWallet}\n >\n {children}\n </FrameShell>\n </AomiRuntimeProvider>\n </ThreadContextProvider>\n );\n};\n\ntype FrameShellProps = {\n className?: string;\n frameStyle: CSSProperties;\n walletFooter?: (props: WalletFooterProps) => ReactNode;\n wallet: WalletButtonState;\n setWallet: (data: Partial<WalletButtonState>) => void;\n children?: ReactNode;\n};\n\nconst FrameShell = ({\n className,\n frameStyle,\n walletFooter,\n wallet,\n setWallet,\n children,\n}: FrameShellProps) => {\n const currentTitle = useCurrentThreadMetadata()?.title ?? \"New Chat\";\n const { currentThreadId, threadViewKey } = useThreadContext();\n\n return (\n <SidebarProvider>\n {children}\n <div\n className={cn(\n \"flex h-full w-full overflow-hidden rounded-2xl bg-white shadow-2xl dark:bg-neutral-950\",\n className\n )}\n style={frameStyle}\n >\n <ThreadListSidebar footer={walletFooter?.({ wallet, setWallet })} />\n <SidebarInset className=\"relative\">\n <header className=\"flex h-14 mt-1 shrink-0 items-center gap-2 border-b px-3\">\n <SidebarTrigger />\n <Separator orientation=\"vertical\" className=\"mr-2 h-4\" />\n <Breadcrumb>\n <BreadcrumbList>\n <BreadcrumbItem className=\"hidden md:block\">\n {currentTitle}\n </BreadcrumbItem>\n <BreadcrumbSeparator className=\"hidden md:block\" />\n </BreadcrumbList>\n </Breadcrumb>\n </header>\n <div className=\"flex-1 overflow-hidden\">\n <Thread key={`${currentThreadId}-${threadViewKey}`} />\n </div>\n </SidebarInset>\n </div>\n </SidebarProvider>\n );\n};\n","import {\n AlertCircleIcon,\n ArrowDownIcon,\n ArrowUpIcon,\n CheckIcon,\n ChevronLeftIcon,\n ChevronRightIcon,\n CopyIcon,\n PencilIcon,\n RefreshCwIcon,\n Square,\n} from \"lucide-react\";\n\nimport {\n ActionBarPrimitive,\n BranchPickerPrimitive,\n ComposerPrimitive,\n ErrorPrimitive,\n MessagePrimitive,\n ThreadPrimitive,\n} from \"@assistant-ui/react\";\n\nimport type { FC } from \"react\";\nimport { useEffect } from \"react\";\nimport { LazyMotion, MotionConfig, domAnimation } from \"motion/react\";\nimport * as m from \"motion/react-m\";\n\nimport { Button } from \"@/components/ui/button\";\nimport { MarkdownText } from \"@/components/assistant-ui/markdown-text\";\nimport { ToolFallback } from \"@/components/assistant-ui/tool-fallback\";\nimport { TooltipIconButton } from \"@/components/assistant-ui/tooltip-icon-button\";\nimport {\n ComposerAddAttachment,\n ComposerAttachments,\n UserMessageAttachments,\n} from \"@/components/assistant-ui/attachment\";\n\nimport { cn } from \"@/lib/utils\";\nimport { useThreadContext } from \"@/lib/thread-context\";\nimport { useAssistantApi } from \"@assistant-ui/react\";\n\nexport const Thread: FC = () => {\n const api = useAssistantApi();\n const { threadViewKey } = useThreadContext();\n\n useEffect(() => {\n try {\n const composer = api.composer();\n composer.setText(\"\");\n void composer.clearAttachments?.();\n } catch (error) {\n console.error(\"Failed to reset composer input:\", error);\n }\n }, [api, threadViewKey]);\n\n return (\n <LazyMotion features={domAnimation}>\n <MotionConfig reducedMotion=\"user\">\n <ThreadPrimitive.Root\n className=\"aui-root aui-thread-root @container flex h-full flex-col bg-background\"\n style={{\n [\"--thread-max-width\" as string]: \"44rem\",\n }}\n >\n <ThreadPrimitive.Viewport className=\"aui-thread-viewport relative flex flex-1 flex-col overflow-x-auto overflow-y-scroll px-4\">\n <ThreadPrimitive.If empty>\n <ThreadWelcome />\n </ThreadPrimitive.If>\n\n <ThreadPrimitive.Messages\n components={{\n UserMessage,\n EditComposer,\n AssistantMessage,\n SystemMessage,\n }}\n />\n\n <ThreadPrimitive.If empty={false}>\n <div className=\"aui-thread-viewport-spacer min-h-8 grow\" />\n </ThreadPrimitive.If>\n\n <Composer />\n </ThreadPrimitive.Viewport>\n </ThreadPrimitive.Root>\n </MotionConfig>\n </LazyMotion>\n );\n};\n\nconst ThreadScrollToBottom: FC = () => {\n return (\n <ThreadPrimitive.ScrollToBottom asChild>\n <TooltipIconButton\n tooltip=\"Scroll to bottom\"\n variant=\"outline\"\n className=\"aui-thread-scroll-to-bottom absolute -top-12 z-10 self-center rounded-full p-4 disabled:invisible dark:bg-background dark:hover:bg-accent\"\n >\n <ArrowDownIcon />\n </TooltipIconButton>\n </ThreadPrimitive.ScrollToBottom>\n );\n};\n\nconst ThreadWelcome: FC = () => {\n return (\n <div className=\"aui-thread-welcome-root mx-auto my-auto flex w-full max-w-[var(--thread-max-width)] flex-grow flex-col\">\n <div className=\"aui-thread-welcome-center flex w-full flex-grow flex-col items-center justify-center\">\n <div className=\"aui-thread-welcome-message flex size-full flex-col justify-center px-8\">\n <m.div\n initial={{ opacity: 0, y: 10 }}\n animate={{ opacity: 1, y: 0 }}\n exit={{ opacity: 0, y: 10 }}\n className=\"aui-thread-welcome-message-motion-1 text-2xl font-semibold\"\n >\n Hello there!\n </m.div>\n <m.div\n initial={{ opacity: 0, y: 10 }}\n animate={{ opacity: 1, y: 0 }}\n exit={{ opacity: 0, y: 10 }}\n transition={{ delay: 0.1 }}\n className=\"aui-thread-welcome-message-motion-2 text-2xl text-muted-foreground/65\"\n >\n How can I help you today?\n </m.div>\n </div>\n </div>\n <ThreadSuggestions />\n </div>\n );\n};\n\nconst ThreadSuggestions: FC = () => {\n return (\n <div className=\"aui-thread-welcome-suggestions grid w-full gap-2 pb-4 @md:grid-cols-2\">\n {[\n {\n title: \"Show my wallet balances\",\n label: \"and positions\",\n action: \"Show my wallet balances and positions\",\n },\n {\n title: \"Swap 1 ETH to USDC\",\n label: \"with the best price\",\n action: \"Swap 1 ETH to USDC with the best price\",\n },\n {\n title: \"Stake half of my ETH\",\n label: \"in the highest yield pool\",\n action: \"Stake half of my ETH in the highest yield pool\",\n },\n {\n title: \"Bridge 100 USDC\",\n label: \"from Ethereum to Arbitrum\",\n action: \"Bridge 100 USDC from Ethereum to Arbitrum\",\n },\n ].map((suggestedAction, index) => (\n <m.div\n initial={{ opacity: 0, y: 20 }}\n animate={{ opacity: 1, y: 0 }}\n exit={{ opacity: 0, y: 20 }}\n transition={{ delay: 0.05 * index }}\n key={`suggested-action-${suggestedAction.title}-${index}`}\n className=\"aui-thread-welcome-suggestion-display [&:nth-child(n+3)]:hidden @md:[&:nth-child(n+3)]:block\"\n >\n <ThreadPrimitive.Suggestion\n prompt={suggestedAction.action}\n send\n asChild\n >\n <Button\n variant=\"ghost\"\n className=\"aui-thread-welcome-suggestion h-auto w-full flex-1 flex-wrap items-start justify-start gap-1 rounded-3xl border px-5 py-4 text-left text-sm @md:flex-col dark:hover:bg-accent/60\"\n aria-label={suggestedAction.action}\n >\n <span className=\"aui-thread-welcome-suggestion-text-1 font-medium\">\n {suggestedAction.title}\n </span>\n <span className=\"aui-thread-welcome-suggestion-text-2 text-muted-foreground\">\n {suggestedAction.label}\n </span>\n </Button>\n </ThreadPrimitive.Suggestion>\n </m.div>\n ))}\n </div>\n );\n};\n\nconst Composer: FC = () => {\n return (\n <div className=\"aui-composer-wrapper sticky bottom-0 mx-auto flex w-full max-w-[var(--thread-max-width)] flex-col gap-4 overflow-visible rounded-t-3xl bg-background pb-4 md:pb-6\">\n <ThreadScrollToBottom />\n <ComposerPrimitive.Root className=\"aui-composer-root relative flex w-full flex-col rounded-4xl border bg-white px-1 pt-2 shadow-[0_9px_9px_0px_rgba(0,0,0,0.01),0_2px_5px_0px_rgba(0,0,0,0.06)] dark:border-muted-foreground/15\">\n <ComposerAttachments />\n <ComposerPrimitive.Input\n placeholder=\"Send a message...\"\n className=\"aui-composer-input ml-3 mt-2 max-h-32 min-h-16 w-full resize-none bg-transparent px-3.5 pt-1.5 pb-3 text-sm outline-none placeholder:text-muted-foreground focus:outline-primary\"\n rows={1}\n autoFocus\n aria-label=\"Message input\"\n />\n <ComposerAction />\n </ComposerPrimitive.Root>\n </div>\n );\n};\n\nconst ComposerAction: FC = () => {\n return (\n <div className=\"aui-composer-action-wrapper relative mx-1 mt-2 mb-2 flex items-center justify-between\">\n <ComposerAddAttachment />\n\n <ThreadPrimitive.If running={false}>\n <ComposerPrimitive.Send asChild>\n <TooltipIconButton\n tooltip=\"Send message\"\n side=\"bottom\"\n type=\"submit\"\n variant=\"default\"\n size=\"icon\"\n className=\"aui-composer-send mr-3 mb-3 size-[34px] rounded-full p-1\"\n aria-label=\"Send message\"\n >\n <ArrowUpIcon className=\"aui-composer-send-icon size-5\" />\n </TooltipIconButton>\n </ComposerPrimitive.Send>\n </ThreadPrimitive.If>\n\n <ThreadPrimitive.If running>\n <ComposerPrimitive.Cancel asChild>\n <Button\n type=\"button\"\n variant=\"default\"\n size=\"icon\"\n className=\"aui-composer-cancel size-[34px] rounded-full border border-muted-foreground/60 hover:bg-primary/75 dark:border-muted-foreground/90\"\n aria-label=\"Stop generating\"\n >\n <Square className=\"aui-composer-cancel-icon size-3.5 fill-white dark:fill-black\" />\n </Button>\n </ComposerPrimitive.Cancel>\n </ThreadPrimitive.If>\n </div>\n );\n};\n\nconst MessageError: FC = () => {\n return (\n <MessagePrimitive.Error>\n <ErrorPrimitive.Root className=\"aui-message-error-root mt-2 rounded-md border border-destructive bg-destructive/10 p-3 text-sm text-destructive dark:bg-destructive/5 dark:text-red-200\">\n <ErrorPrimitive.Message className=\"aui-message-error-message line-clamp-2\" />\n </ErrorPrimitive.Root>\n </MessagePrimitive.Error>\n );\n};\n\nconst AssistantMessage: FC = () => {\n return (\n <MessagePrimitive.Root asChild>\n <div\n className=\"aui-assistant-message-root relative mx-auto w-full max-w-[var(--thread-max-width)] animate-in py-4 duration-150 ease-out fade-in slide-in-from-bottom-1 last:mb-24\"\n data-role=\"assistant\"\n >\n <div className=\"aui-assistant-message-content text-sm mx-2 leading-5 break-words text-foreground\">\n <MessagePrimitive.Parts\n components={{\n Text: MarkdownText,\n tools: { Fallback: ToolFallback },\n }}\n />\n <MessageError />\n </div>\n\n <div className=\"aui-assistant-message-footer mt-2 ml-2 flex\">\n <BranchPicker />\n <AssistantActionBar />\n </div>\n </div>\n </MessagePrimitive.Root>\n );\n};\n\nconst AssistantActionBar: FC = () => {\n return (\n <ActionBarPrimitive.Root\n hideWhenRunning\n autohide=\"not-last\"\n autohideFloat=\"single-branch\"\n className=\"aui-assistant-action-bar-root col-start-3 row-start-2 -ml-1 flex gap-1 text-muted-foreground data-floating:absolute data-floating:rounded-md data-floating:border data-floating:bg-background data-floating:p-1 data-floating:shadow-sm\"\n >\n <ActionBarPrimitive.Copy asChild>\n <TooltipIconButton tooltip=\"Copy\">\n <MessagePrimitive.If copied>\n <CheckIcon />\n </MessagePrimitive.If>\n <MessagePrimitive.If copied={false}>\n <CopyIcon />\n </MessagePrimitive.If>\n </TooltipIconButton>\n </ActionBarPrimitive.Copy>\n <ActionBarPrimitive.Reload asChild>\n <TooltipIconButton tooltip=\"Refresh\">\n <RefreshCwIcon />\n </TooltipIconButton>\n </ActionBarPrimitive.Reload>\n </ActionBarPrimitive.Root>\n );\n};\n\nconst UserMessage: FC = () => {\n return (\n <MessagePrimitive.Root asChild>\n <div\n className=\"aui-user-message-root mx-auto grid w-full max-w-[var(--thread-max-width)] animate-in auto-rows-auto grid-cols-[minmax(72px,1fr)_auto] gap-y-2 px-2 py-4 duration-150 ease-out fade-in slide-in-from-bottom-1 first:mt-3 last:mb-5 [&:where(>*)]:col-start-2\"\n data-role=\"user\"\n >\n <UserMessageAttachments />\n\n <div className=\"aui-user-message-content-wrapper relative col-start-2 min-w-0\">\n <div className=\"aui-user-message-content text-sm rounded-3xl bg-muted px-5 py-2.5 break-words text-foreground\">\n <MessagePrimitive.Parts />\n </div>\n <div className=\"aui-user-action-bar-wrapper absolute top-1/2 left-0 -translate-x-full -translate-y-1/2 pr-2\">\n <UserActionBar />\n </div>\n </div>\n\n <BranchPicker className=\"aui-user-branch-picker col-span-full col-start-1 row-start-3 -mr-1 justify-end\" />\n </div>\n </MessagePrimitive.Root>\n );\n};\n\nconst UserActionBar: FC = () => {\n return (\n <ActionBarPrimitive.Root\n hideWhenRunning\n autohide=\"not-last\"\n className=\"aui-user-action-bar-root flex flex-col items-end\"\n >\n <ActionBarPrimitive.Edit asChild>\n <TooltipIconButton tooltip=\"Edit\" className=\"aui-user-action-edit p-4\">\n <PencilIcon />\n </TooltipIconButton>\n </ActionBarPrimitive.Edit>\n </ActionBarPrimitive.Root>\n );\n};\n\nconst EditComposer: FC = () => {\n return (\n <div className=\"aui-edit-composer-wrapper mx-auto flex w-full max-w-[var(--thread-max-width)] flex-col gap-4 px-2 first:mt-4\">\n <ComposerPrimitive.Root className=\"aui-edit-composer-root ml-auto flex w-full max-w-7/8 flex-col rounded-xl bg-muted\">\n <ComposerPrimitive.Input\n className=\"aui-edit-composer-input flex min-h-[60px] w-full resize-none bg-transparent p-4 text-foreground outline-none\"\n autoFocus\n />\n\n <div className=\"aui-edit-composer-footer mx-3 mb-3 flex items-center justify-center gap-2 self-end\">\n <ComposerPrimitive.Cancel asChild>\n <Button variant=\"ghost\" size=\"sm\" aria-label=\"Cancel edit\">\n Cancel\n </Button>\n </ComposerPrimitive.Cancel>\n <ComposerPrimitive.Send asChild>\n <Button size=\"sm\" aria-label=\"Update message\">\n Update\n </Button>\n </ComposerPrimitive.Send>\n </div>\n </ComposerPrimitive.Root>\n </div>\n );\n};\n\nconst BranchPicker: FC<BranchPickerPrimitive.Root.Props> = ({\n className,\n ...rest\n}) => {\n return (\n <BranchPickerPrimitive.Root\n hideWhenSingleBranch\n className={cn(\n \"aui-branch-picker-root mr-2 -ml-2 inline-flex items-center text-xs text-muted-foreground\",\n className,\n )}\n {...rest}\n >\n <BranchPickerPrimitive.Previous asChild>\n <TooltipIconButton tooltip=\"Previous\">\n <ChevronLeftIcon />\n </TooltipIconButton>\n </BranchPickerPrimitive.Previous>\n <span className=\"aui-branch-picker-state font-medium\">\n <BranchPickerPrimitive.Number /> / <BranchPickerPrimitive.Count />\n </span>\n <BranchPickerPrimitive.Next asChild>\n <TooltipIconButton tooltip=\"Next\">\n <ChevronRightIcon />\n </TooltipIconButton>\n </BranchPickerPrimitive.Next>\n </BranchPickerPrimitive.Root>\n );\n};\n\nconst SystemMessage: FC = () => {\n return (\n <MessagePrimitive.Root asChild>\n <div\n className=\"aui-system-message-root mx-auto w-full max-w-[var(--thread-max-width)] px-2 py-4 animate-in fade-in slide-in-from-bottom-1\"\n data-role=\"system\"\n >\n <div className=\"aui-system-message-card flex w-full flex-wrap items-start gap-3 rounded-3xl border px-5 py-4 text-left text-sm bg-background/70 dark:bg-muted/30\">\n <AlertCircleIcon className=\"aui-system-message-icon mt-0.5 size-4 shrink-0 text-blue-500 dark:text-blue-300\" />\n <div className=\"aui-system-message-body flex flex-col gap-1\">\n <span className=\"aui-system-message-title font-medium text-foreground\">\n System notice\n </span>\n <div className=\"aui-system-message-content leading-relaxed text-muted-foreground\">\n <MessagePrimitive.Parts components={{ Text: MarkdownText }} />\n </div>\n </div>\n </div>\n </div>\n </MessagePrimitive.Root>\n );\n};\n","import * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n {\n variants: {\n variant: {\n default:\n \"bg-primary text-primary-foreground shadow-xs hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50\",\n secondary:\n \"bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80\",\n ghost:\n \"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-9 px-4 py-2 has-[>svg]:px-3\",\n sm: \"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5\",\n lg: \"h-10 rounded-md px-6 has-[>svg]:px-4\",\n icon: \"size-9\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n },\n);\n\nfunction Button({\n className,\n variant,\n size,\n asChild = false,\n ...props\n}: React.ComponentProps<\"button\"> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean;\n }) {\n const Comp = asChild ? Slot : \"button\";\n\n return (\n <Comp\n data-slot=\"button\"\n className={cn(buttonVariants({ variant, size, className }))}\n {...props}\n />\n );\n}\n\nexport { Button, buttonVariants };\n","import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\n\nexport function generateSessionId(): string {\n // Use crypto.randomUUID if available (modern browsers), otherwise fallback\n if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n return crypto.randomUUID();\n }\n // Fallback UUID v4 implementation\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {\n const r = Math.random() * 16 | 0;\n const v = c == 'x' ? r : (r & 0x3 | 0x8);\n return v.toString(16);\n });\n}","\"use client\";\n\nimport \"@assistant-ui/react-markdown/styles/dot.css\";\n\nimport {\n type CodeHeaderProps,\n MarkdownTextPrimitive,\n unstable_memoizeMarkdownComponents as memoizeMarkdownComponents,\n useIsMarkdownCodeBlock,\n} from \"@assistant-ui/react-markdown\";\nimport remarkGfm from \"remark-gfm\";\nimport { type FC, memo, useState } from \"react\";\nimport { CheckIcon, CopyIcon } from \"lucide-react\";\n\nimport { TooltipIconButton } from \"@/components/assistant-ui/tooltip-icon-button\";\nimport { cn } from \"@/lib/utils\";\n\nconst MarkdownTextImpl = () => {\n return (\n <MarkdownTextPrimitive\n remarkPlugins={[remarkGfm]}\n className=\"aui-md\"\n components={defaultComponents}\n />\n );\n};\n\nexport const MarkdownText = memo(MarkdownTextImpl);\n\nconst CodeHeader: FC<CodeHeaderProps> = ({ language, code }) => {\n const { isCopied, copyToClipboard } = useCopyToClipboard();\n const onCopy = () => {\n if (!code || isCopied) return;\n copyToClipboard(code);\n };\n\n return (\n <div className=\"aui-code-header-root mt-4 flex items-center justify-between gap-4 rounded-t-lg bg-muted-foreground/15 px-4 py-2 text-sm font-semibold text-foreground dark:bg-muted-foreground/20\">\n <span className=\"aui-code-header-language lowercase [&>span]:text-xs\">\n {language}\n </span>\n <TooltipIconButton tooltip=\"Copy\" onClick={onCopy}>\n {!isCopied && <CopyIcon />}\n {isCopied && <CheckIcon />}\n </TooltipIconButton>\n </div>\n );\n};\n\nconst useCopyToClipboard = ({\n copiedDuration = 3000,\n}: {\n copiedDuration?: number;\n} = {}) => {\n const [isCopied, setIsCopied] = useState<boolean>(false);\n\n const copyToClipboard = (value: string) => {\n if (!value) return;\n\n navigator.clipboard.writeText(value).then(() => {\n setIsCopied(true);\n setTimeout(() => setIsCopied(false), copiedDuration);\n });\n };\n\n return { isCopied, copyToClipboard };\n};\n\nconst defaultComponents = memoizeMarkdownComponents({\n h1: ({ className, ...props }) => (\n <h1\n className={cn(\n \"aui-md-h1 mb-8 scroll-m-20 text-4xl font-extrabold tracking-tight last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n h2: ({ className, ...props }) => (\n <h2\n className={cn(\n \"aui-md-h2 mt-8 mb-4 scroll-m-20 text-3xl font-semibold tracking-tight first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n h3: ({ className, ...props }) => (\n <h3\n className={cn(\n \"aui-md-h3 mt-6 mb-4 scroll-m-20 text-2xl font-semibold tracking-tight first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n h4: ({ className, ...props }) => (\n <h4\n className={cn(\n \"aui-md-h4 mt-6 mb-4 scroll-m-20 text-xl font-semibold tracking-tight first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n h5: ({ className, ...props }) => (\n <h5\n className={cn(\n \"aui-md-h5 my-4 text-lg font-semibold first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n h6: ({ className, ...props }) => (\n <h6\n className={cn(\n \"aui-md-h6 my-4 font-semibold first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n p: ({ className, ...props }) => (\n <p\n className={cn(\n \"aui-md-p mt-5 mb-5 leading-7 first:mt-0 last:mb-0\",\n className,\n )}\n {...props}\n />\n ),\n a: ({ className, ...props }) => (\n <a\n className={cn(\n \"aui-md-a font-medium text-primary underline underline-offset-4\",\n className,\n )}\n {...props}\n />\n ),\n blockquote: ({ className, ...props }) => (\n <blockquote\n className={cn(\"aui-md-blockquote border-l-2 pl-6 italic\", className)}\n {...props}\n />\n ),\n ul: ({ className, ...props }) => (\n <ul\n className={cn(\"aui-md-ul my-5 ml-6 list-disc [&>li]:mt-2\", className)}\n {...props}\n />\n ),\n ol: ({ className, ...props }) => (\n <ol\n className={cn(\"aui-md-ol my-5 ml-6 list-decimal [&>li]:mt-2\", className)}\n {...props}\n />\n ),\n hr: ({ className, ...props }) => (\n <hr className={cn(\"aui-md-hr my-5 border-b\", className)} {...props} />\n ),\n table: ({ className, ...props }) => (\n <table\n className={cn(\n \"aui-md-table my-5 w-full border-separate border-spacing-0 overflow-y-auto\",\n className,\n )}\n {...props}\n />\n ),\n th: ({ className, ...props }) => (\n <th\n className={cn(\n \"aui-md-th bg-muted px-4 py-2 text-left font-bold first:rounded-tl-lg last:rounded-tr-lg [&[align=center]]:text-center [&[align=right]]:text-right\",\n className,\n )}\n {...props}\n />\n ),\n td: ({ className, ...props }) => (\n <td\n className={cn(\n \"aui-md-td border-b border-l px-4 py-2 text-left last:border-r [&[align=center]]:text-center [&[align=right]]:text-right\",\n className,\n )}\n {...props}\n />\n ),\n tr: ({ className, ...props }) => (\n <tr\n className={cn(\n \"aui-md-tr m-0 border-b p-0 first:border-t [&:last-child>td:first-child]:rounded-bl-lg [&:last-child>td:last-child]:rounded-br-lg\",\n className,\n )}\n {...props}\n />\n ),\n sup: ({ className, ...props }) => (\n <sup\n className={cn(\"aui-md-sup [&>a]:text-xs [&>a]:no-underline\", className)}\n {...props}\n />\n ),\n pre: ({ className, ...props }) => (\n <pre\n className={cn(\n \"aui-md-pre overflow-x-auto !rounded-t-none rounded-b-lg bg-accent p-6 text-black text-[12px]\",\n className,\n )}\n {...props}\n />\n ),\n code: function Code({ className, ...props }) {\n const isCodeBlock = useIsMarkdownCodeBlock();\n return (\n <code\n className={cn(\n !isCodeBlock &&\n \"aui-md-inline-code rounded border bg-muted text-[12px]\",\n className,\n )}\n {...props}\n />\n );\n },\n CodeHeader,\n});\n","\"use client\";\n\nimport { ComponentPropsWithRef, forwardRef } from \"react\";\nimport { Slottable } from \"@radix-ui/react-slot\";\n\nimport {\n Tooltip,\n TooltipContent,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\";\nimport { Button } from \"@/components/ui/button\";\nimport { cn } from \"@/lib/utils\";\n\nexport type TooltipIconButtonProps = ComponentPropsWithRef<typeof Button> & {\n tooltip: string;\n side?: \"top\" | \"bottom\" | \"left\" | \"right\";\n};\n\nexport const TooltipIconButton = forwardRef<\n HTMLButtonElement,\n TooltipIconButtonProps\n>(({ children, tooltip, side = \"bottom\", className, ...rest }, ref) => {\n return (\n <Tooltip>\n <TooltipTrigger asChild>\n <Button\n variant=\"ghost\"\n size=\"icon\"\n {...rest}\n className={cn(\"aui-button-icon size-6 p-1\", className)}\n ref={ref}\n >\n <Slottable>{children}</Slottable>\n <span className=\"aui-sr-only 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 React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction TooltipProvider({\n delayDuration = 0,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Provider>) {\n return (\n <TooltipPrimitive.Provider\n data-slot=\"tooltip-provider\"\n delayDuration={delayDuration}\n {...props}\n />\n );\n}\n\nfunction Tooltip({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Root>) {\n return (\n <TooltipProvider>\n <TooltipPrimitive.Root data-slot=\"tooltip\" {...props} />\n </TooltipProvider>\n );\n}\n\nfunction TooltipTrigger({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {\n return <TooltipPrimitive.Trigger data-slot=\"tooltip-trigger\" {...props} />;\n}\n\nfunction TooltipContent({\n className,\n sideOffset = 0,\n children,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Content>) {\n return (\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n data-slot=\"tooltip-content\"\n sideOffset={sideOffset}\n className={cn(\n \"z-50 w-fit origin-(--radix-tooltip-content-transform-origin) animate-in rounded-md bg-primary px-3 py-1.5 text-xs text-balance text-primary-foreground fade-in-0 zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95\",\n className,\n )}\n {...props}\n >\n {children}\n <TooltipPrimitive.Arrow className=\"z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px] bg-primary fill-primary\" />\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n );\n}\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n","import type { ToolCallMessagePartComponent } from \"@assistant-ui/react\";\nimport { CheckIcon, ChevronDownIcon, ChevronUpIcon } from \"lucide-react\";\nimport { useState } from \"react\";\nimport { Button } from \"@/components/ui/button\";\n\nexport const ToolFallback: ToolCallMessagePartComponent = ({\n toolName,\n argsText,\n result,\n}) => {\n const [isCollapsed, setIsCollapsed] = useState(true);\n return (\n <div className=\"aui-tool-fallback-root mb-4 flex w-full flex-col gap-3 rounded-lg border py-3\">\n <div className=\"aui-tool-fallback-header flex items-center gap-2 px-4\">\n <CheckIcon className=\"aui-tool-fallback-icon size-4\" />\n <p className=\"aui-tool-fallback-title flex-grow\">\n Used tool: <b>{toolName}</b>\n </p>\n <Button onClick={() => setIsCollapsed(!isCollapsed)}>\n {isCollapsed ? <ChevronUpIcon /> : <ChevronDownIcon />}\n </Button>\n </div>\n {!isCollapsed && (\n <div className=\"aui-tool-fallback-content flex flex-col gap-2 border-t pt-2 bg-muted\">\n <div className=\"aui-tool-fallback-args-root px-4\">\n <pre className=\"aui-tool-fallback-args-value whitespace-pre-wrap\">\n {argsText}\n </pre>\n </div>\n {result !== undefined && (\n <div className=\"aui-tool-fallback-result-root border-t border-dashed px-4 pt-2\">\n <p className=\"aui-tool-fallback-result-header font-semibold\">\n Result:\n </p>\n <pre className=\"aui-tool-fallback-result-content whitespace-pre-wrap text-[012px]\">\n {typeof result === \"string\"\n ? result\n : JSON.stringify(result, null, 2)}\n </pre>\n </div>\n )}\n </div>\n )}\n </div>\n );\n};\n","\"use client\";\n\nimport { PropsWithChildren, useEffect, useState, type FC } from \"react\";\nimport Image from \"next/image\";\nimport { XIcon, PlusIcon, FileText } from \"lucide-react\";\nimport {\n AttachmentPrimitive,\n ComposerPrimitive,\n MessagePrimitive,\n useAssistantState,\n useAssistantApi,\n} from \"@assistant-ui/react\";\nimport { useShallow } from \"zustand/shallow\";\nimport {\n Tooltip,\n TooltipContent,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\";\nimport {\n Dialog,\n DialogTitle,\n DialogContent,\n DialogTrigger,\n} from \"@/components/ui/dialog\";\nimport { Avatar, AvatarImage, AvatarFallback } from \"@/components/ui/avatar\";\nimport { TooltipIconButton } from \"@/components/assistant-ui/tooltip-icon-button\";\nimport { cn } from \"@/lib/utils\";\n\nconst useFileSrc = (file: File | undefined) => {\n const [src, setSrc] = useState<string | undefined>(undefined);\n\n useEffect(() => {\n if (!file) {\n setSrc(undefined);\n return;\n }\n\n const objectUrl = URL.createObjectURL(file);\n setSrc(objectUrl);\n\n return () => {\n URL.revokeObjectURL(objectUrl);\n };\n }, [file]);\n\n return src;\n};\n\nconst useAttachmentSrc = () => {\n const { file, src } = useAssistantState(\n useShallow(({ attachment }): { file?: File; src?: string } => {\n if (attachment.type !== \"image\") return {};\n if (attachment.file) return { file: attachment.file };\n const src = attachment.content?.filter((c) => c.type === \"image\")[0]\n ?.image;\n if (!src) return {};\n return { src };\n }),\n );\n\n return useFileSrc(file) ?? src;\n};\n\ntype AttachmentPreviewProps = {\n src: string;\n};\n\nconst AttachmentPreview: FC<AttachmentPreviewProps> = ({ src }) => {\n const [isLoaded, setIsLoaded] = useState(false);\n return (\n <Image\n src={src}\n alt=\"Image Preview\"\n width={1}\n height={1}\n className={\n isLoaded\n ? \"aui-attachment-preview-image-loaded block h-auto max-h-[80vh] w-auto max-w-full object-contain\"\n : \"aui-attachment-preview-image-loading hidden\"\n }\n onLoadingComplete={() => setIsLoaded(true)}\n priority={false}\n />\n );\n};\n\nconst AttachmentPreviewDialog: FC<PropsWithChildren> = ({ children }) => {\n const src = useAttachmentSrc();\n\n if (!src) return children;\n\n return (\n <Dialog>\n <DialogTrigger\n className=\"aui-attachment-preview-trigger cursor-pointer transition-colors hover:bg-accent/50\"\n asChild\n >\n {children}\n </DialogTrigger>\n <DialogContent className=\"aui-attachment-preview-dialog-content p-2 sm:max-w-3xl [&_svg]:text-background [&>button]:rounded-full [&>button]:bg-foreground/60 [&>button]:p-1 [&>button]:opacity-100 [&>button]:!ring-0 [&>button]:hover:[&_svg]:text-destructive\">\n <DialogTitle className=\"aui-sr-only sr-only\">\n Image Attachment Preview\n </DialogTitle>\n <div className=\"aui-attachment-preview relative mx-auto flex max-h-[80dvh] w-full items-center justify-center overflow-hidden bg-background\">\n <AttachmentPreview src={src} />\n </div>\n </DialogContent>\n </Dialog>\n );\n};\n\nconst AttachmentThumb: FC = () => {\n const isImage = useAssistantState(\n ({ attachment }) => attachment.type === \"image\",\n );\n const src = useAttachmentSrc();\n\n return (\n <Avatar className=\"aui-attachment-tile-avatar h-full w-full rounded-none\">\n <AvatarImage\n src={src}\n alt=\"Attachment preview\"\n className=\"aui-attachment-tile-image object-cover\"\n />\n <AvatarFallback delayMs={isImage ? 200 : 0}>\n <FileText className=\"aui-attachment-tile-fallback-icon size-8 text-muted-foreground\" />\n </AvatarFallback>\n </Avatar>\n );\n};\n\nconst AttachmentUI: FC = () => {\n const api = useAssistantApi();\n const isComposer = api.attachment.source === \"composer\";\n\n const isImage = useAssistantState(\n ({ attachment }) => attachment.type === \"image\",\n );\n const typeLabel = useAssistantState(({ attachment }) => {\n const type = attachment.type;\n switch (type) {\n case \"image\":\n return \"Image\";\n case \"document\":\n return \"Document\";\n case \"file\":\n return \"File\";\n default:\n const _exhaustiveCheck: never = type;\n throw new Error(`Unknown attachment type: ${_exhaustiveCheck}`);\n }\n });\n\n return (\n <Tooltip>\n <AttachmentPrimitive.Root\n className={cn(\n \"aui-attachment-root relative\",\n isImage &&\n \"aui-attachment-root-composer only:[&>#attachment-tile]:size-24\",\n )}\n >\n <AttachmentPreviewDialog>\n <TooltipTrigger asChild>\n <div\n className={cn(\n \"aui-attachment-tile size-14 cursor-pointer overflow-hidden rounded-[14px] border bg-muted transition-opacity hover:opacity-75\",\n isComposer &&\n \"aui-attachment-tile-composer border-foreground/20\",\n )}\n role=\"button\"\n id=\"attachment-tile\"\n aria-label={`${typeLabel} attachment`}\n >\n <AttachmentThumb />\n </div>\n </TooltipTrigger>\n </AttachmentPreviewDialog>\n {isComposer && <AttachmentRemove />}\n </AttachmentPrimitive.Root>\n <TooltipContent side=\"top\">\n <AttachmentPrimitive.Name />\n </TooltipContent>\n </Tooltip>\n );\n};\n\nconst AttachmentRemove: FC = () => {\n return (\n <AttachmentPrimitive.Remove asChild>\n <TooltipIconButton\n tooltip=\"Remove file\"\n className=\"aui-attachment-tile-remove absolute top-1.5 right-1.5 size-3.5 rounded-full bg-white text-muted-foreground opacity-100 shadow-sm hover:!bg-white [&_svg]:text-black hover:[&_svg]:text-destructive\"\n side=\"top\"\n >\n <XIcon className=\"aui-attachment-remove-icon size-3 dark:stroke-[2.5px]\" />\n </TooltipIconButton>\n </AttachmentPrimitive.Remove>\n );\n};\n\nexport const UserMessageAttachments: FC = () => {\n return (\n <div className=\"aui-user-message-attachments-end col-span-full col-start-1 row-start-1 flex w-full flex-row justify-end gap-2\">\n <MessagePrimitive.Attachments components={{ Attachment: AttachmentUI }} />\n </div>\n );\n};\n\nexport const ComposerAttachments: FC = () => {\n return (\n <div className=\"aui-composer-attachments mb-2 flex w-full flex-row items-center gap-2 overflow-x-auto px-1.5 pt-0.5 pb-1 empty:hidden\">\n <ComposerPrimitive.Attachments\n components={{ Attachment: AttachmentUI }}\n />\n </div>\n );\n};\n\nexport const ComposerAddAttachment: FC = () => {\n return (\n <ComposerPrimitive.AddAttachment asChild>\n <TooltipIconButton\n tooltip=\"Add Attachment\"\n side=\"bottom\"\n variant=\"ghost\"\n size=\"icon\"\n className=\"aui-composer-add-attachment size-[34px] rounded-full p-1 text-xs font-semibold hover:bg-muted-foreground/15 dark:border-muted-foreground/15 dark:hover:bg-muted-foreground/30\"\n aria-label=\"Add Attachment\"\n >\n <PlusIcon className=\"aui-attachment-add-icon size-5 stroke-[1.5px]\" />\n </TooltipIconButton>\n </ComposerPrimitive.AddAttachment>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\";\nimport { XIcon } from \"lucide-react\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Dialog({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Root>) {\n return <DialogPrimitive.Root data-slot=\"dialog\" {...props} />;\n}\n\nfunction DialogTrigger({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Trigger>) {\n return <DialogPrimitive.Trigger data-slot=\"dialog-trigger\" {...props} />;\n}\n\nfunction DialogPortal({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Portal>) {\n return <DialogPrimitive.Portal data-slot=\"dialog-portal\" {...props} />;\n}\n\nfunction DialogClose({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Close>) {\n return <DialogPrimitive.Close data-slot=\"dialog-close\" {...props} />;\n}\n\nfunction DialogOverlay({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Overlay>) {\n return (\n <DialogPrimitive.Overlay\n data-slot=\"dialog-overlay\"\n className={cn(\n \"fixed inset-0 z-50 bg-black/50 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:animate-in data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction DialogContent({\n className,\n children,\n showCloseButton = true,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Content> & {\n showCloseButton?: boolean;\n}) {\n return (\n <DialogPortal data-slot=\"dialog-portal\">\n <DialogOverlay />\n <DialogPrimitive.Content\n data-slot=\"dialog-content\"\n className={cn(\n \"fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border bg-background p-6 shadow-lg duration-200 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:fade-in-0 data-[state=open]:zoom-in-95 sm:max-w-lg\",\n className,\n )}\n {...props}\n >\n {children}\n {showCloseButton && (\n <DialogPrimitive.Close\n data-slot=\"dialog-close\"\n className=\"absolute top-4 right-4 rounded-xs opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:ring-2 focus:ring-ring focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\"\n >\n <XIcon />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n )}\n </DialogPrimitive.Content>\n </DialogPortal>\n );\n}\n\nfunction DialogHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-header\"\n className={cn(\"flex flex-col gap-2 text-center sm:text-left\", className)}\n {...props}\n />\n );\n}\n\nfunction DialogFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-footer\"\n className={cn(\n \"flex flex-col-reverse gap-2 sm:flex-row sm:justify-end\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction DialogTitle({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Title>) {\n return (\n <DialogPrimitive.Title\n data-slot=\"dialog-title\"\n className={cn(\"text-lg leading-none font-semibold\", className)}\n {...props}\n />\n );\n}\n\nfunction DialogDescription({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Description>) {\n return (\n <DialogPrimitive.Description\n data-slot=\"dialog-description\"\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n );\n}\n\nexport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as AvatarPrimitive from \"@radix-ui/react-avatar\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Avatar({\n className,\n ...props\n}: React.ComponentProps<typeof AvatarPrimitive.Root>) {\n return (\n <AvatarPrimitive.Root\n data-slot=\"avatar\"\n className={cn(\n \"relative flex size-8 shrink-0 overflow-hidden rounded-full\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction AvatarImage({\n className,\n ...props\n}: React.ComponentProps<typeof AvatarPrimitive.Image>) {\n return (\n <AvatarPrimitive.Image\n data-slot=\"avatar-image\"\n className={cn(\"aspect-square size-full\", className)}\n {...props}\n />\n );\n}\n\nfunction AvatarFallback({\n className,\n ...props\n}: React.ComponentProps<typeof AvatarPrimitive.Fallback>) {\n return (\n <AvatarPrimitive.Fallback\n data-slot=\"avatar-fallback\"\n className={cn(\n \"flex size-full items-center justify-center rounded-full bg-muted\",\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Avatar, AvatarImage, AvatarFallback };\n","\"use client\";\n\nimport { createContext, useContext, useState, ReactNode, useCallback } from \"react\";\nimport type { ThreadMessageLike } from \"@assistant-ui/react\";\n\n/**\n * Generate a UUID v4 session ID (matches backend's generate_session_id)\n */\nfunction generateSessionId(): string {\n return crypto.randomUUID();\n}\n\n/**\n * Thread Context Value\n *\n * Manages global state for multi-thread support:\n * - Current active thread ID\n * - Message history for all threads\n * - Thread metadata (title, archived status)\n */\nexport type ThreadContextValue = {\n // Current thread\n currentThreadId: string;\n setCurrentThreadId: (id: string) => void;\n threadViewKey: number;\n bumpThreadViewKey: () => void;\n\n // Thread messages (Map: threadId -> messages)\n threads: Map<string, ThreadMessageLike[]>;\n setThreads: React.Dispatch<React.SetStateAction<Map<string, ThreadMessageLike[]>>>;\n\n // Thread metadata (Map: threadId -> { title, status })\n threadMetadata: Map<string, ThreadMetadata>;\n setThreadMetadata: React.Dispatch<React.SetStateAction<Map<string, ThreadMetadata>>>;\n\n // Thread counter for sequential titles\n threadCnt: number;\n setThreadCnt: React.Dispatch<React.SetStateAction<number>>;\n\n // Helper methods\n getThreadMessages: (threadId: string) => ThreadMessageLike[];\n setThreadMessages: (threadId: string, messages: ThreadMessageLike[]) => void;\n getThreadMetadata: (threadId: string) => ThreadMetadata | undefined;\n updateThreadMetadata: (threadId: string, updates: Partial<ThreadMetadata>) => void;\n};\n\nexport type ThreadMetadata = {\n title: string;\n status: \"regular\" | \"archived\" | \"pending\";\n lastActiveAt?: string | number;\n};\n\n/**\n * Thread Context\n *\n * IMPORTANT: Do not use this directly. Use the useThreadContext hook instead.\n */\nconst ThreadContext = createContext<ThreadContextValue | null>(null);\n\n/**\n * Hook to access Thread Context\n *\n * Must be used within a ThreadContextProvider\n *\n * @example\n * ```tsx\n * const { currentThreadId, setCurrentThreadId } = useThreadContext();\n * ```\n */\nexport function useThreadContext(): ThreadContextValue {\n const context = useContext(ThreadContext);\n if (!context) {\n throw new Error(\n \"useThreadContext must be used within ThreadContextProvider. \" +\n \"Wrap your app with <ThreadContextProvider>...</ThreadContextProvider>\"\n );\n }\n return context;\n}\n\n/**\n * Thread Context Provider Props\n */\nexport type ThreadContextProviderProps = {\n children: ReactNode;\n /**\n * Initial thread ID to set as current\n * @default Generated UUID v4 (matches backend's generate_session_id)\n */\n initialThreadId?: string;\n};\n\n/**\n * Thread Context Provider\n *\n * Provides global state for multi-thread management.\n * Should be placed high in your component tree, typically in your root layout.\n *\n * @example\n * ```tsx\n * // app/layout.tsx\n * export default function Layout({ children }) {\n * return (\n * <ThreadContextProvider>\n * <AomiRuntimeProvider>\n * {children}\n * </AomiRuntimeProvider>\n * </ThreadContextProvider>\n * );\n * }\n * ```\n */\nexport function ThreadContextProvider({\n children,\n initialThreadId,\n}: ThreadContextProviderProps) {\n\n // Generate UUID v4 on initialization if no initialThreadId provided\n const [generateThreadId] = useState(() => {\n const id = initialThreadId || generateSessionId();\n console.log('🔵 [ThreadContext] Initialized with thread ID:', id);\n return id;\n });\n\n const [threadCnt, setThreadCnt] = useState<number>(1); // For sequential \"Chat N\" titles\n\n // Thread messages storage\n const [threads, setThreads] = useState<Map<string, ThreadMessageLike[]>>(\n () => new Map([[generateThreadId, []]])\n );\n\n // Thread metadata storage\n const [threadMetadata, setThreadMetadata] = useState<Map<string, ThreadMetadata>>(\n () =>\n new Map([\n [\n generateThreadId,\n { title: \"New Chat\", status: \"pending\", lastActiveAt: new Date().toISOString() },\n ],\n ])\n );\n\n // Ensure a thread has placeholder metadata/messages before use\n const ensureThreadExists = useCallback(\n (threadId: string) => {\n setThreadMetadata((prev) => {\n if (prev.has(threadId)) return prev;\n const next = new Map(prev);\n next.set(threadId, { title: \"New Chat\", status: \"regular\", lastActiveAt: new Date().toISOString() });\n return next;\n });\n\n setThreads((prev) => {\n if (prev.has(threadId)) return prev;\n const next = new Map(prev);\n next.set(threadId, []);\n return next;\n });\n },\n []\n );\n\n // Current thread ID\n const [currentThreadId, _setCurrentThreadId] = useState(generateThreadId);\n const [threadViewKey, setThreadViewKey] = useState(0);\n\n const bumpThreadViewKey = useCallback(() => {\n setThreadViewKey((prev) => prev + 1);\n }, []);\n\n const setCurrentThreadId = useCallback(\n (threadId: string) => {\n ensureThreadExists(threadId);\n _setCurrentThreadId(threadId);\n },\n [ensureThreadExists]\n );\n\n // Helper: Get messages for a specific thread\n const getThreadMessages = useCallback(\n (threadId: string): ThreadMessageLike[] => {\n return threads.get(threadId) || [];\n },\n [threads]\n );\n\n // Helper: Set messages for a specific thread\n const setThreadMessages = useCallback(\n (threadId: string, messages: ThreadMessageLike[]) => {\n setThreads((prev) => {\n const next = new Map(prev);\n next.set(threadId, messages);\n return next;\n });\n },\n []\n );\n\n // Helper: Get metadata for a specific thread\n const getThreadMetadata = useCallback(\n (threadId: string): ThreadMetadata | undefined => {\n return threadMetadata.get(threadId);\n },\n [threadMetadata]\n );\n\n // Helper: Update metadata for a specific thread\n const updateThreadMetadata = useCallback(\n (threadId: string, updates: Partial<ThreadMetadata>) => {\n setThreadMetadata((prev) => {\n const existing = prev.get(threadId);\n if (!existing) {\n console.warn(`Thread metadata not found for threadId: ${threadId}`);\n return prev;\n }\n\n const next = new Map(prev);\n next.set(threadId, { ...existing, ...updates });\n return next;\n });\n },\n []\n );\n\n const value: ThreadContextValue = {\n currentThreadId,\n setCurrentThreadId,\n threadViewKey,\n bumpThreadViewKey,\n threads,\n setThreads,\n threadMetadata,\n setThreadMetadata,\n threadCnt,\n setThreadCnt,\n getThreadMessages,\n setThreadMessages,\n getThreadMetadata,\n updateThreadMetadata,\n };\n\n return (\n <ThreadContext.Provider value={value}>\n {children}\n </ThreadContext.Provider>\n );\n}\n\n/**\n * Hook to get current thread messages\n *\n * Convenience hook that returns messages for the current thread\n *\n * @example\n * ```tsx\n * const messages = useCurrentThreadMessages();\n * ```\n */\nexport function useCurrentThreadMessages(): ThreadMessageLike[] {\n const { currentThreadId, getThreadMessages } = useThreadContext();\n return getThreadMessages(currentThreadId);\n}\n\n/**\n * Hook to get current thread metadata\n *\n * Convenience hook that returns metadata for the current thread\n *\n * @example\n * ```tsx\n * const metadata = useCurrentThreadMetadata();\n * console.log(metadata.title, metadata.status);\n * ```\n */\nexport function useCurrentThreadMetadata(): ThreadMetadata | undefined {\n const { currentThreadId, getThreadMetadata } = useThreadContext();\n return getThreadMetadata(currentThreadId);\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport Link from \"next/link\";\nimport Image from \"next/image\";\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarRail,\n} from \"@/components/ui/sidebar\";\nimport { ThreadList } from \"@/components/assistant-ui/thread-list\";\n\ntype ThreadListSidebarProps = React.ComponentProps<typeof Sidebar> & {\n /** Optional footer component (e.g., WalletFooter from consumer app) */\n footer?: React.ReactNode;\n};\n\nexport function ThreadListSidebar({\n footer,\n ...props\n}: ThreadListSidebarProps) {\n return (\n <Sidebar\n collapsible=\"offcanvas\"\n variant=\"inset\"\n className=\"relative\"\n {...props}\n >\n <SidebarHeader className=\"aomi-sidebar-header\">\n <div className=\"aomi-sidebar-header-content flex items-center justify-between\">\n <SidebarMenu>\n <SidebarMenuItem>\n <SidebarMenuButton size=\"lg\" asChild>\n <Link\n href=\"https://aomi.dev\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <div className=\"aomi-sidebar-header-icon-wrapper flex aspect-square size-8 items-center justify-center rounded-lg bg-white\">\n <Image\n src=\"/assets/images/a.svg\"\n alt=\"Logo\"\n width={28}\n height={28}\n className=\"aomi-sidebar-header-icon size-7 ml-3\"\n priority\n />\n </div>\n </Link>\n </SidebarMenuButton>\n </SidebarMenuItem>\n </SidebarMenu>\n </div>\n </SidebarHeader>\n <SidebarContent className=\"aomi-sidebar-content\">\n <ThreadList />\n </SidebarContent>\n <SidebarRail />\n {footer && (\n <SidebarFooter className=\"aomi-sidebar-footer border-t border-sm py-4\">\n {footer}\n </SidebarFooter>\n )}\n </Sidebar>\n );\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, VariantProps } from \"class-variance-authority\";\nimport { PanelLeftIcon } from \"lucide-react\";\n\nimport { useIsMobile } from \"@/hooks/use-mobile\";\nimport { cn } from \"@/lib/utils\";\nimport { Button } from \"@/components/ui/button\";\nimport { Input } from \"@/components/ui/input\";\nimport { Separator } from \"@/components/ui/separator\";\nimport {\n Sheet,\n SheetContent,\n SheetDescription,\n SheetHeader,\n SheetTitle,\n} from \"@/components/ui/sheet\";\nimport { Skeleton } from \"@/components/ui/skeleton\";\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\";\n\nconst SIDEBAR_COOKIE_NAME = \"sidebar_state\";\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7;\nconst SIDEBAR_WIDTH = \"16rem\";\nconst SIDEBAR_WIDTH_MOBILE = \"18rem\";\nconst SIDEBAR_WIDTH_ICON = \"3rem\";\nconst SIDEBAR_KEYBOARD_SHORTCUT = \"b\";\nconst SIDEBAR_MIN_WIDTH = 100; // px\nconst SIDEBAR_MAX_WIDTH = 200; // px\n\ntype SidebarContextProps = {\n state: \"expanded\" | \"collapsed\";\n open: boolean;\n setOpen: (open: boolean) => void;\n openMobile: boolean;\n setOpenMobile: (open: boolean) => void;\n isMobile: boolean;\n toggleSidebar: () => void;\n sidebarWidth: number;\n setSidebarWidth: (width: number) => void;\n};\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null);\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext);\n if (!context) {\n throw new Error(\"useSidebar must be used within a SidebarProvider.\");\n }\n\n return context;\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n}: React.ComponentProps<\"div\"> & {\n defaultOpen?: boolean;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n}) {\n const isMobile = useIsMobile();\n const [openMobile, setOpenMobile] = React.useState(false);\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen);\n const open = openProp ?? _open;\n\n // Sidebar width state (in pixels)\n const [sidebarWidth, setSidebarWidth] = React.useState(256); // 16rem = 256px\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === \"function\" ? value(open) : value;\n if (setOpenProp) {\n setOpenProp(openState);\n } else {\n _setOpen(openState);\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`;\n },\n [setOpenProp, open],\n );\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open);\n }, [isMobile, setOpen, setOpenMobile]);\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n event.key === SIDEBAR_KEYBOARD_SHORTCUT &&\n (event.metaKey || event.ctrlKey)\n ) {\n event.preventDefault();\n toggleSidebar();\n }\n };\n\n window.addEventListener(\"keydown\", handleKeyDown);\n return () => window.removeEventListener(\"keydown\", handleKeyDown);\n }, [toggleSidebar]);\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? \"expanded\" : \"collapsed\";\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n open,\n setOpen,\n isMobile,\n openMobile,\n setOpenMobile,\n toggleSidebar,\n sidebarWidth,\n setSidebarWidth,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar, sidebarWidth],\n );\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n \"--sidebar-width\": `${sidebarWidth}px`,\n \"--sidebar-width-icon\": SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn(\n \"group/sidebar-wrapper flex h-full w-full has-data-[variant=offcanvas]:bg-sidebar\",\n className,\n )}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n );\n}\n\nfunction Sidebar({\n side = \"left\",\n variant = \"sidebar\",\n collapsible = \"offcanvas\",\n className,\n children,\n ...props\n}: React.ComponentProps<\"div\"> & {\n side?: \"left\" | \"right\";\n variant?: \"sidebar\" | \"floating\" | \"inset\";\n collapsible?: \"offcanvas\" | \"icon\" | \"none\";\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar();\n\n if (collapsible === \"none\") {\n return (\n <div\n data-slot=\"sidebar\"\n className={cn(\n \"flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground\",\n className,\n )}\n {...props}\n >\n {children}\n </div>\n );\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"w-(--sidebar-width) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden\"\n style={\n {\n \"--sidebar-width\": SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n );\n }\n\n\n return (\n <div\n className={cn(\n \"relative group peer hidden text-sidebar-foreground md:block\",\n \"w-[var(--sidebar-width)]\",\n \"data-[collapsible=offcanvas]:w-0\",\n \"transition-[width] duration-200 ease-linear\",\n )}\n data-state={state}\n data-collapsible={state === \"collapsed\" ? collapsible : \"\"}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n \"relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear\",\n \"group-data-[collapsible=offcanvas]:w-0\",\n \"group-data-[side=right]:rotate-180\",\n variant === \"floating\" || variant === \"inset\"\n ? \"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]\"\n : \"group-data-[collapsible=icon]:w-(--sidebar-width-icon)\",\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n \"fixed inset-y-0 z-10 hidden h-full w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex\",\n side === \"left\"\n ? \"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]\"\n : \"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]\",\n // Adjust the padding for floating and inset variants.\n variant === \"floating\" || variant === \"inset\"\n ? \"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]\"\n : \"group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l\",\n className,\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className=\"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow-sm\"\n >\n {children}\n </div>\n </div>\n </div>\n );\n}\n\nfunction SidebarTrigger({\n className,\n onClick,\n ...props\n}: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar();\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n size=\"icon\"\n className={cn(\"size-7\", className)}\n onClick={(event) => {\n onClick?.(event);\n toggleSidebar();\n }}\n {...props}\n >\n <PanelLeftIcon />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n );\n}\n\nfunction SidebarRail({ className, ...props }: React.ComponentProps<\"button\">) {\n const { toggleSidebar, sidebarWidth, setSidebarWidth, setOpen } = useSidebar();\n const isDraggingRef = React.useRef(false);\n const startXRef = React.useRef(0);\n const startWidthRef = React.useRef(0);\n const hasDraggedRef = React.useRef(false);\n const rafRef = React.useRef<number | null>(null);\n\n const handleMouseDown = React.useCallback(\n (e: React.MouseEvent) => {\n e.preventDefault();\n isDraggingRef.current = true;\n hasDraggedRef.current = false;\n startXRef.current = e.clientX;\n startWidthRef.current = sidebarWidth;\n document.body.style.cursor = \"ew-resize\";\n document.body.style.userSelect = \"none\";\n },\n [sidebarWidth]\n );\n\n React.useEffect(() => {\n const handleMouseMove = (e: MouseEvent) => {\n if (!isDraggingRef.current) return;\n\n // Cancel any pending RAF\n if (rafRef.current) {\n cancelAnimationFrame(rafRef.current);\n }\n\n rafRef.current = requestAnimationFrame(() => {\n const deltaX = e.clientX - startXRef.current;\n if (Math.abs(deltaX) > 5) {\n hasDraggedRef.current = true;\n }\n\n const rawWidth = startWidthRef.current + deltaX;\n\n if (rawWidth < SIDEBAR_MIN_WIDTH) {\n setOpen(false);\n } else {\n setOpen(true);\n setSidebarWidth(Math.min(SIDEBAR_MAX_WIDTH, rawWidth));\n }\n });\n };\n\n const handleMouseUp = () => {\n if (!isDraggingRef.current) return;\n isDraggingRef.current = false;\n document.body.style.cursor = \"\";\n document.body.style.userSelect = \"\";\n if (rafRef.current) {\n cancelAnimationFrame(rafRef.current);\n }\n };\n\n document.addEventListener(\"mousemove\", handleMouseMove);\n document.addEventListener(\"mouseup\", handleMouseUp);\n\n return () => {\n document.removeEventListener(\"mousemove\", handleMouseMove);\n document.removeEventListener(\"mouseup\", handleMouseUp);\n };\n }, [setSidebarWidth, setOpen]);\n\n const handleClick = React.useCallback(() => {\n if (!hasDraggedRef.current) {\n toggleSidebar();\n }\n }, [toggleSidebar]);\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onMouseDown={handleMouseDown}\n onClick={handleClick}\n title=\"Drag to resize, click to toggle\"\n className={cn(\n \"absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear group-data-[side=left]:-right-4 group-data-[side=right]:left-0 after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border sm:flex\",\n \"cursor-ew-resize\",\n \"group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full hover:group-data-[collapsible=offcanvas]:bg-sidebar\",\n \"[[data-side=left][data-collapsible=offcanvas]_&]:-right-2\",\n \"[[data-side=right][data-collapsible=offcanvas]_&]:-left-2\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarInset({ className, ...props }: React.ComponentProps<\"main\">) {\n return (\n <main\n data-slot=\"sidebar-inset\"\n className={cn(\"relative flex w-full flex-1 flex-col bg-background\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarInput({\n className,\n ...props\n}: React.ComponentProps<typeof Input>) {\n return (\n <Input\n data-slot=\"sidebar-input\"\n data-sidebar=\"input\"\n className={cn(\"h-8 w-full bg-background shadow-none\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-header\"\n data-sidebar=\"header\"\n className={cn(\"flex flex-col gap-2 p-2\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-footer\"\n data-sidebar=\"footer\"\n className={cn(\"flex mr-2 flex-col gap-2 p-2\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof Separator>) {\n return (\n <Separator\n data-slot=\"sidebar-separator\"\n data-sidebar=\"separator\"\n className={cn(\"mx-2 w-auto bg-sidebar-border\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn(\n \"flex mr-2 min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-group\"\n data-sidebar=\"group\"\n className={cn(\"relative flex w-full min-w-0 flex-col p-2\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarGroupLabel({\n className,\n asChild = false,\n ...props\n}: React.ComponentProps<\"div\"> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"div\";\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n \"flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 ring-sidebar-ring outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n \"group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarGroupAction({\n className,\n asChild = false,\n ...props\n}: React.ComponentProps<\"button\"> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"button\";\n\n return (\n <Comp\n data-slot=\"sidebar-group-action\"\n data-sidebar=\"group-action\"\n className={cn(\n \"absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 md:after:hidden\",\n \"group-data-[collapsible=icon]:hidden\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarGroupContent({\n className,\n ...props\n}: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-group-content\"\n data-sidebar=\"group-content\"\n className={cn(\"w-full text-sm\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarMenu({ className, ...props }: React.ComponentProps<\"ul\">) {\n return (\n <ul\n data-slot=\"sidebar-menu\"\n data-sidebar=\"menu\"\n className={cn(\"flex w-full min-w-0 flex-col gap-1\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarMenuItem({ className, ...props }: React.ComponentProps<\"li\">) {\n return (\n <li\n data-slot=\"sidebar-menu-item\"\n data-sidebar=\"menu-item\"\n className={cn(\"group/menu-item relative\", className)}\n {...props}\n />\n );\n}\n\nconst sidebarMenuButtonVariants = cva(\n \"peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-hidden ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-data-[sidebar=menu-action]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0\",\n {\n variants: {\n variant: {\n default: \"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground\",\n outline:\n \"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]\",\n },\n size: {\n default: \"h-8 text-sm\",\n sm: \"h-7 text-xs\",\n lg: \"h-12 text-sm group-data-[collapsible=icon]:p-0!\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n },\n);\n\nfunction SidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = \"default\",\n size = \"default\",\n tooltip,\n className,\n ...props\n}: React.ComponentProps<\"button\"> & {\n asChild?: boolean;\n isActive?: boolean;\n tooltip?: string | React.ComponentProps<typeof TooltipContent>;\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? Slot : \"button\";\n const { isMobile, state } = useSidebar();\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n );\n\n if (!tooltip) {\n return button;\n }\n\n if (typeof tooltip === \"string\") {\n tooltip = {\n children: tooltip,\n };\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent\n side=\"right\"\n align=\"center\"\n hidden={state !== \"collapsed\" || isMobile}\n {...tooltip}\n />\n </Tooltip>\n );\n}\n\nfunction SidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<\"button\"> & {\n asChild?: boolean;\n showOnHover?: boolean;\n}) {\n const Comp = asChild ? Slot : \"button\";\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n \"absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform peer-hover/menu-button:text-sidebar-accent-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 md:after:hidden\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n showOnHover &&\n \"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground data-[state=open]:opacity-100 md:opacity-0\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarMenuBadge({\n className,\n ...props\n}: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sidebar-menu-badge\"\n data-sidebar=\"menu-badge\"\n className={cn(\n \"pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium text-sidebar-foreground tabular-nums select-none\",\n \"peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<\"div\"> & {\n showIcon?: boolean;\n}) {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`;\n }, []);\n\n return (\n <div\n data-slot=\"sidebar-menu-skeleton\"\n data-sidebar=\"menu-skeleton\"\n className={cn(\"flex h-8 items-center gap-2 rounded-md px-2\", className)}\n {...props}\n >\n {showIcon && (\n <Skeleton\n className=\"size-4 rounded-md\"\n data-sidebar=\"menu-skeleton-icon\"\n />\n )}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n \"--skeleton-width\": width,\n } as React.CSSProperties\n }\n />\n </div>\n );\n}\n\nfunction SidebarMenuSub({ className, ...props }: React.ComponentProps<\"ul\">) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n \"mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SidebarMenuSubItem({\n className,\n ...props\n}: React.ComponentProps<\"li\">) {\n return (\n <li\n data-slot=\"sidebar-menu-sub-item\"\n data-sidebar=\"menu-sub-item\"\n className={cn(\"group/menu-sub-item relative\", className)}\n {...props}\n />\n );\n}\n\nfunction SidebarMenuSubButton({\n asChild = false,\n size = \"md\",\n isActive = false,\n className,\n ...props\n}: React.ComponentProps<\"a\"> & {\n asChild?: boolean;\n size?: \"sm\" | \"md\";\n isActive?: boolean;\n}) {\n const Comp = asChild ? Slot : \"a\";\n\n return (\n <Comp\n data-slot=\"sidebar-menu-sub-button\"\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n \"flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground ring-sidebar-ring outline-hidden hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground\",\n \"data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground\",\n size === \"sm\" && \"text-xs\",\n size === \"md\" && \"text-sm\",\n \"group-data-[collapsible=icon]:hidden\",\n className,\n )}\n {...props}\n />\n );\n}\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupAction,\n SidebarGroupContent,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarInput,\n SidebarInset,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuBadge,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSkeleton,\n SidebarMenuSub,\n SidebarMenuSubButton,\n SidebarMenuSubItem,\n SidebarProvider,\n SidebarRail,\n SidebarSeparator,\n SidebarTrigger,\n useSidebar,\n};\n","import * as React from \"react\";\n\nconst MOBILE_BREAKPOINT = 768;\n\nexport function useIsMobile() {\n const [isMobile, setIsMobile] = React.useState<boolean | undefined>(\n undefined,\n );\n\n React.useEffect(() => {\n const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`);\n const onChange = () => {\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);\n };\n mql.addEventListener(\"change\", onChange);\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);\n return () => mql.removeEventListener(\"change\", onChange);\n }, []);\n\n return !!isMobile;\n}\n","import * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Input({ className, type, ...props }: React.ComponentProps<\"input\">) {\n return (\n <input\n type={type}\n data-slot=\"input\"\n className={cn(\n \"flex h-9 w-full min-w-0 rounded-md border-sm border-input bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none selection:bg-primary selection:text-primary-foreground file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm dark:bg-input/30\",\n \"focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50\",\n \"aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40\",\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Input };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Separator({\n className,\n orientation = \"horizontal\",\n decorative = true,\n ...props\n}: React.ComponentProps<typeof SeparatorPrimitive.Root>) {\n return (\n <SeparatorPrimitive.Root\n data-slot=\"separator\"\n decorative={decorative}\n orientation={orientation}\n className={cn(\n \"shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px\",\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Separator };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as SheetPrimitive from \"@radix-ui/react-dialog\";\nimport { XIcon } from \"lucide-react\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Sheet({ ...props }: React.ComponentProps<typeof SheetPrimitive.Root>) {\n return <SheetPrimitive.Root data-slot=\"sheet\" {...props} />;\n}\n\nfunction SheetTrigger({\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Trigger>) {\n return <SheetPrimitive.Trigger data-slot=\"sheet-trigger\" {...props} />;\n}\n\nfunction SheetClose({\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Close>) {\n return <SheetPrimitive.Close data-slot=\"sheet-close\" {...props} />;\n}\n\nfunction SheetPortal({\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Portal>) {\n return <SheetPrimitive.Portal data-slot=\"sheet-portal\" {...props} />;\n}\n\nfunction SheetOverlay({\n className,\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Overlay>) {\n return (\n <SheetPrimitive.Overlay\n data-slot=\"sheet-overlay\"\n className={cn(\n \"fixed inset-0 z-50 bg-black/50 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:animate-in data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction SheetContent({\n className,\n children,\n side = \"right\",\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Content> & {\n side?: \"top\" | \"right\" | \"bottom\" | \"left\";\n}) {\n return (\n <SheetPortal>\n <SheetOverlay />\n <SheetPrimitive.Content\n data-slot=\"sheet-content\"\n className={cn(\n \"fixed z-50 flex flex-col gap-4 bg-background shadow-lg transition ease-in-out data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:animate-in data-[state=open]:duration-500\",\n side === \"right\" &&\n \"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm\",\n side === \"left\" &&\n \"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm\",\n side === \"top\" &&\n \"inset-x-0 top-0 h-auto border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top\",\n side === \"bottom\" &&\n \"inset-x-0 bottom-0 h-auto border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom\",\n className,\n )}\n {...props}\n >\n {children}\n <SheetPrimitive.Close className=\"absolute top-4 right-4 rounded-xs opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:ring-2 focus:ring-ring focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none data-[state=open]:bg-secondary\">\n <XIcon className=\"size-4\" />\n <span className=\"sr-only\">Close</span>\n </SheetPrimitive.Close>\n </SheetPrimitive.Content>\n </SheetPortal>\n );\n}\n\nfunction SheetHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sheet-header\"\n className={cn(\"flex flex-col gap-1.5 p-4\", className)}\n {...props}\n />\n );\n}\n\nfunction SheetFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"sheet-footer\"\n className={cn(\"mt-auto flex flex-col gap-2 p-4\", className)}\n {...props}\n />\n );\n}\n\nfunction SheetTitle({\n className,\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Title>) {\n return (\n <SheetPrimitive.Title\n data-slot=\"sheet-title\"\n className={cn(\"font-semibold text-foreground\", className)}\n {...props}\n />\n );\n}\n\nfunction SheetDescription({\n className,\n ...props\n}: React.ComponentProps<typeof SheetPrimitive.Description>) {\n return (\n <SheetPrimitive.Description\n data-slot=\"sheet-description\"\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n );\n}\n\nexport {\n Sheet,\n SheetTrigger,\n SheetClose,\n SheetContent,\n SheetHeader,\n SheetFooter,\n SheetTitle,\n SheetDescription,\n};\n","import { cn } from \"@/lib/utils\";\n\nfunction Skeleton({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"skeleton\"\n className={cn(\"animate-pulse rounded-md bg-accent\", className)}\n {...props}\n />\n );\n}\n\nexport { Skeleton };\n","import type { FC } from \"react\";\nimport {\n ThreadListItemPrimitive,\n ThreadListPrimitive,\n useAssistantState,\n} from \"@assistant-ui/react\";\nimport { PlusIcon, TrashIcon } from \"lucide-react\";\n\nimport { Button } from \"@/components/ui/button\";\nimport { TooltipIconButton } from \"@/components/assistant-ui/tooltip-icon-button\";\nimport { Skeleton } from \"@/components/ui/skeleton\";\n\nexport const ThreadList: FC = () => {\n return (\n <ThreadListPrimitive.Root className=\"aui-root aui-thread-list-root flex flex-col items-stretch gap-1.5\">\n <ThreadListNew />\n <ThreadListItems />\n </ThreadListPrimitive.Root>\n );\n};\n\nconst ThreadListNew: FC = () => {\n return (\n <ThreadListPrimitive.New asChild>\n <Button\n className=\"aui-thread-list-new flex items-center justify-start gap-1 rounded-lg px-2.5 py-2 text-start hover:bg-muted data-active:bg-muted\"\n variant=\"ghost\"\n >\n <PlusIcon />\n New Chat\n </Button>\n </ThreadListPrimitive.New>\n );\n};\n\nconst ThreadListItems: FC = () => {\n const isLoading = useAssistantState(({ threads }) => threads.isLoading);\n\n if (isLoading) {\n return <ThreadListSkeleton />;\n }\n\n return <ThreadListPrimitive.Items components={{ ThreadListItem }} />;\n};\n\nconst ThreadListSkeleton: FC = () => {\n return (\n <>\n {Array.from({ length: 5 }, (_, i) => (\n <div\n key={i}\n role=\"status\"\n aria-label=\"Loading threads\"\n aria-live=\"polite\"\n className=\"aui-thread-list-skeleton-wrapper flex items-center gap-2 rounded-md px-3 py-2\"\n >\n <Skeleton className=\"aui-thread-list-skeleton h-[22px] flex-grow\" />\n </div>\n ))}\n </>\n );\n};\n\nconst ThreadListItem: FC = () => {\n return (\n <ThreadListItemPrimitive.Root className=\"aui-thread-list-item flex items-center gap-2 rounded-lg transition-all hover:bg-muted focus-visible:bg-muted focus-visible:ring-2 focus-visible:ring-ring focus-visible:outline-none data-active:bg-muted\">\n <ThreadListItemPrimitive.Trigger className=\"aui-thread-list-item-trigger flex-grow px-3 py-2 text-start\">\n <ThreadListItemTitle />\n </ThreadListItemPrimitive.Trigger>\n <ThreadListItemDelete />\n </ThreadListItemPrimitive.Root>\n );\n};\n\nconst ThreadListItemTitle: FC = () => {\n return (\n <span className=\"aui-thread-list-item-title text-sm\">\n <ThreadListItemPrimitive.Title fallback=\"New Chat\" />\n </span>\n );\n};\n\nconst ThreadListItemDelete: FC = () => {\n return (\n <ThreadListItemPrimitive.Delete asChild>\n <TooltipIconButton\n className=\"aui-thread-list-item-delete mr-3 ml-auto size-4 p-0 text-foreground hover:text-primary\"\n variant=\"ghost\"\n tooltip=\"Delete thread\"\n onClick={(event) => {\n const confirmed = window.confirm(\n \"Delete this chat? This action cannot be undone.\"\n );\n if (!confirmed) {\n event.preventDefault();\n event.stopPropagation();\n }\n }}\n >\n <TrashIcon />\n </TooltipIconButton>\n </ThreadListItemPrimitive.Delete>\n );\n};\n","import * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { ChevronRight, MoreHorizontal } from \"lucide-react\";\n\nimport { cn } from \"@/lib/utils\";\n\nfunction Breadcrumb({ ...props }: React.ComponentProps<\"nav\">) {\n return <nav aria-label=\"breadcrumb\" data-slot=\"breadcrumb\" {...props} />;\n}\n\nfunction BreadcrumbList({ className, ...props }: React.ComponentProps<\"ol\">) {\n return (\n <ol\n data-slot=\"breadcrumb-list\"\n className={cn(\n \"flex flex-wrap items-center gap-1.5 text-sm break-words text-muted-foreground sm:gap-2.5\",\n className,\n )}\n {...props}\n />\n );\n}\n\nfunction BreadcrumbItem({ className, ...props }: React.ComponentProps<\"li\">) {\n return (\n <li\n data-slot=\"breadcrumb-item\"\n className={cn(\"inline-flex items-center gap-1.5\", className)}\n {...props}\n />\n );\n}\n\nfunction BreadcrumbLink({\n asChild,\n className,\n ...props\n}: React.ComponentProps<\"a\"> & {\n asChild?: boolean;\n}) {\n const Comp = asChild ? Slot : \"a\";\n\n return (\n <Comp\n data-slot=\"breadcrumb-link\"\n className={cn(\"transition-colors hover:text-foreground\", className)}\n {...props}\n />\n );\n}\n\nfunction BreadcrumbPage({ className, ...props }: React.ComponentProps<\"span\">) {\n return (\n <span\n data-slot=\"breadcrumb-page\"\n role=\"link\"\n aria-disabled=\"true\"\n aria-current=\"page\"\n className={cn(\"font-normal text-foreground\", className)}\n {...props}\n />\n );\n}\n\nfunction BreadcrumbSeparator({\n children,\n className,\n ...props\n}: React.ComponentProps<\"li\">) {\n return (\n <li\n data-slot=\"breadcrumb-separator\"\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn(\"[&>svg]:size-3.5\", className)}\n {...props}\n >\n {children ?? <ChevronRight />}\n </li>\n );\n}\n\nfunction BreadcrumbEllipsis({\n className,\n ...props\n}: React.ComponentProps<\"span\">) {\n return (\n <span\n data-slot=\"breadcrumb-ellipsis\"\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn(\"flex size-9 items-center justify-center\", className)}\n {...props}\n >\n <MoreHorizontal className=\"size-4\" />\n <span className=\"sr-only\">More</span>\n </span>\n );\n}\n\nexport {\n Breadcrumb,\n BreadcrumbList,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbPage,\n BreadcrumbSeparator,\n BreadcrumbEllipsis,\n};\n","\"use client\";\n\nimport type { ReactNode } from \"react\";\nimport { createContext, useCallback, useContext, useEffect, useRef, useState } from \"react\";\nimport {\n AssistantRuntimeProvider,\n useExternalStoreRuntime,\n type AppendMessage,\n type ThreadMessageLike,\n type ExternalStoreThreadListAdapter,\n type ExternalStoreThreadData,\n} from \"@assistant-ui/react\";\nimport { BackendApi, type SessionMessage } from \"@/lib/backend-api\";\nimport { constructSystemMessage, constructThreadMessage } from \"@/lib/conversion\";\nimport { useThreadContext, type ThreadMetadata } from \"@/lib/thread-context\";\ntype RuntimeActions = {\n sendSystemMessage: (message: string) => Promise<void>;\n};\nconst RuntimeActionsContext = createContext<RuntimeActions | undefined>(undefined);\n\nconst isTempThreadId = (id: string) => id.startsWith(\"temp-\");\nconst parseTimestamp = (value?: string | number) => {\n if (value === undefined || value === null) return 0;\n if (typeof value === \"number\") {\n // Accept both ms and seconds since backend may send either\n return Number.isFinite(value) ? (value < 1e12 ? value * 1000 : value) : 0;\n }\n\n // Numeric strings like \"1725654321\" are not parsed by Date.parse, so coerce first\n const numeric = Number(value);\n if (!Number.isNaN(numeric)) {\n return numeric < 1e12 ? numeric * 1000 : numeric;\n }\n\n const ts = Date.parse(value);\n return Number.isNaN(ts) ? 0 : ts;\n};\nconst isPlaceholderTitle = (title?: string) => {\n const normalized = title?.trim() ?? \"\";\n return !normalized || normalized.startsWith(\"#[\");\n};\n\nexport const useRuntimeActions = () => {\n const context = useContext(RuntimeActionsContext);\n if (!context) {\n throw new Error(\"useRuntimeActions must be used within AomiRuntimeProvider\");\n }\n return context;\n};\n\nexport function AomiRuntimeProvider({\n children,\n backendUrl = \"http://localhost:8080\",\n publicKey,\n}: Readonly<{\n children: ReactNode;\n backendUrl?: string;\n publicKey?: string;\n}>) {\n // ==================== Thread Context Integration ====================\n const {\n currentThreadId,\n setCurrentThreadId,\n bumpThreadViewKey,\n threads,\n setThreads,\n threadMetadata,\n setThreadMetadata,\n threadCnt,\n setThreadCnt,\n getThreadMessages,\n setThreadMessages,\n updateThreadMetadata,\n } = useThreadContext();\n\n // ==================== State ====================\n const [isRunning, setIsRunning] = useState(false);\n const backendApiRef = useRef(new BackendApi(backendUrl));\n const pollingIntervalRef = useRef<ReturnType<typeof setInterval> | null>(null);\n const pendingSystemMessagesRef = useRef<Map<string, string[]>>(new Map());\n // Queue for chat messages sent before backend ID is available\n const pendingChatMessagesRef = useRef<Map<string, string[]>>(new Map());\n // Track in-flight creation to avoid duplicate backend requests\n const creatingThreadIdRef = useRef<string | null>(null);\n const createThreadPromiseRef = useRef<Promise<void> | null>(null);\n const findPendingThreadId = useCallback(() => {\n if (creatingThreadIdRef.current) return creatingThreadIdRef.current;\n for (const [id, meta] of threadMetadata.entries()) {\n if (meta.status === \"pending\") return id;\n }\n return null;\n }, [threadMetadata]);\n\n // Get messages for current thread\n const currentMessages = getThreadMessages(currentThreadId);\n\n // Ref to track current thread ID for async callbacks (avoids stale closures)\n const currentThreadIdRef = useRef(currentThreadId);\n useEffect(() => {\n currentThreadIdRef.current = currentThreadId;\n }, [currentThreadId]);\n\n // Ref to track threads that were just created and should skip initial fetch\n // This prevents the fetchState from clearing input when switching from temp to real thread\n const skipInitialFetchRef = useRef<Set<string>>(new Set());\n\n // Ref to map temp thread IDs to their real backend IDs\n // This allows us to keep using tempId in the UI while using backendId for API calls\n const tempToBackendIdRef = useRef<Map<string, string>>(new Map());\n\n // Helper to resolve a thread ID to its backend ID (handles temp -> real mapping)\n const resolveThreadId = useCallback((threadId: string): string => {\n return tempToBackendIdRef.current.get(threadId) || threadId;\n }, []);\n\n // Helper to find a temp thread ID for a given backend ID (reverse lookup)\n const findTempIdForBackendId = useCallback((backendId: string): string | undefined => {\n for (const [tempId, bId] of tempToBackendIdRef.current.entries()) {\n if (bId === backendId) return tempId;\n }\n return undefined;\n }, []);\n\n // Check if a thread is ready for API calls (either not temp, or temp with backend ID)\n const isThreadReady = useCallback((threadId: string): boolean => {\n if (!isTempThreadId(threadId)) return true;\n return tempToBackendIdRef.current.has(threadId);\n }, []);\n\n // ==================== Message Processing ====================\n const applyMessages = useCallback((msgs?: SessionMessage[] | null) => {\n if (!msgs) return;\n\n // Don't overwrite messages if there are pending chat messages waiting to be sent\n // This prevents the UI from losing user messages while waiting for backend ID\n const hasPendingMessages = pendingChatMessagesRef.current.has(currentThreadId) && \n (pendingChatMessagesRef.current.get(currentThreadId)?.length ?? 0) > 0;\n if (hasPendingMessages) {\n console.log(\"Skipping applyMessages - pending messages exist for thread:\", currentThreadId);\n return;\n }\n\n const threadMessages: ThreadMessageLike[] = [];\n\n for (const msg of msgs) {\n if (msg.sender === \"system\") {\n const systemMessage = constructSystemMessage(msg);\n if (systemMessage) {\n threadMessages.push(systemMessage);\n }\n continue;\n }\n const threadMessage = constructThreadMessage(msg);\n if (threadMessage) {\n threadMessages.push(threadMessage);\n }\n }\n\n setThreadMessages(currentThreadId, threadMessages);\n }, [currentThreadId, setThreadMessages]);\n\n // ==================== Backend API ====================\n useEffect(() => {\n backendApiRef.current = new BackendApi(backendUrl);\n }, [backendUrl]);\n\n // ==================== Polling Logic ====================\n const stopPolling = useCallback(() => {\n if (pollingIntervalRef.current) {\n clearInterval(pollingIntervalRef.current);\n pollingIntervalRef.current = null;\n }\n }, []);\n\n const startPolling = useCallback(() => {\n if (!isThreadReady(currentThreadId)) return;\n if (pollingIntervalRef.current) return;\n const backendThreadId = resolveThreadId(currentThreadId);\n setIsRunning(true);\n pollingIntervalRef.current = setInterval(async () => {\n try {\n const state = await backendApiRef.current.fetchState(backendThreadId);\n if (state.session_exists === false) {\n setIsRunning(false);\n stopPolling();\n return;\n }\n applyMessages(state.messages);\n\n if (!state.is_processing) {\n setIsRunning(false);\n stopPolling();\n }\n } catch (error) {\n console.error(\"Polling error:\", error);\n stopPolling();\n setIsRunning(false);\n }\n }, 500);\n }, [currentThreadId, applyMessages, stopPolling, isThreadReady, resolveThreadId]);\n\n // ==================== Load Initial Thread State ====================\n useEffect(() => {\n const fetchInitialState = async () => {\n // For temp threads without a backend ID yet, skip fetching\n if (isTempThreadId(currentThreadId) && !tempToBackendIdRef.current.has(currentThreadId)) {\n setIsRunning(false);\n return;\n }\n\n // Skip initial fetch for newly created threads (switched from temp to real)\n // This prevents fetchState from clearing input when the thread was just created\n if (skipInitialFetchRef.current.has(currentThreadId)) {\n skipInitialFetchRef.current.delete(currentThreadId);\n setIsRunning(false);\n return;\n }\n\n const backendThreadId = resolveThreadId(currentThreadId);\n\n try {\n const state = await backendApiRef.current.fetchState(backendThreadId);\n if (state.session_exists === false) {\n setIsRunning(false);\n return;\n }\n applyMessages(state.messages);\n\n if (state.is_processing) {\n setIsRunning(true);\n startPolling();\n } else {\n setIsRunning(false);\n }\n } catch (error) {\n console.error(\"Failed to fetch initial state:\", error);\n }\n };\n\n void fetchInitialState();\n return () => {\n stopPolling();\n };\n }, [currentThreadId, applyMessages, startPolling, stopPolling, resolveThreadId]);\n\n // ==================== Load Thread List from Backend ====================\n useEffect(() => {\n if (!publicKey) return;\n\n const fetchThreadList = async () => {\n try {\n const threadList = await backendApiRef.current.fetchThreads(publicKey);\n const newMetadata = new Map(threadMetadata);\n\n // Track highest chat number\n let maxChatNum = threadCnt;\n\n for (const thread of threadList) {\n const rawTitle = thread.title ?? \"\";\n const title = isPlaceholderTitle(rawTitle) ? \"\" : rawTitle;\n const lastActive =\n thread.last_active_at ||\n thread.updated_at ||\n thread.created_at ||\n newMetadata.get(thread.session_id)?.lastActiveAt ||\n new Date().toISOString();\n newMetadata.set(thread.session_id, {\n title,\n status: thread.is_archived ? \"archived\" : \"regular\",\n lastActiveAt: lastActive,\n });\n\n // Extract chat number if title follows \"Chat N\" format\n const match = title.match(/^Chat (\\d+)$/);\n if (match) {\n const num = parseInt(match[1], 10);\n if (num > maxChatNum) {\n maxChatNum = num;\n }\n }\n }\n\n setThreadMetadata(newMetadata);\n // Sync counter to highest chat number\n if (maxChatNum > threadCnt) {\n setThreadCnt(maxChatNum);\n }\n } catch (error) {\n console.error(\"Failed to fetch thread list:\", error);\n }\n };\n\n void fetchThreadList();\n }, [publicKey]); // Only run on mount and when publicKey changes\n\n // ==================== Thread List Adapter ====================\n const threadListAdapter: ExternalStoreThreadListAdapter = (() => {\n const sortByLastActiveDesc = (\n [, metaA]: [string, ThreadMetadata],\n [, metaB]: [string, ThreadMetadata]\n ) => {\n const tsA = parseTimestamp(metaA.lastActiveAt);\n const tsB = parseTimestamp(metaB.lastActiveAt);\n return tsB - tsA;\n };\n\n const regularThreads = Array.from(threadMetadata.entries())\n .filter(([_, meta]) => meta.status === \"regular\")\n .filter(([_, meta]) => !isPlaceholderTitle(meta.title))\n .sort(sortByLastActiveDesc)\n .map(([id, meta]): ExternalStoreThreadData<\"regular\"> => ({\n id,\n title: meta.title || \"New Chat\",\n status: \"regular\",\n }));\n\n const archivedThreadsArray = Array.from(threadMetadata.entries())\n .filter(([_, meta]) => meta.status === \"archived\")\n .filter(([_, meta]) => !isPlaceholderTitle(meta.title))\n .sort(sortByLastActiveDesc)\n .map(([id, meta]): ExternalStoreThreadData<\"archived\"> => ({\n id,\n title: meta.title || \"New Chat\",\n status: \"archived\",\n }));\n\n return {\n threadId: currentThreadId,\n threads: regularThreads,\n archivedThreads: archivedThreadsArray,\n\n // Create new thread\n onSwitchToNewThread: async () => {\n const preparePendingThread = (newId: string) => {\n const previousPendingId = creatingThreadIdRef.current;\n if (previousPendingId && previousPendingId !== newId) {\n setThreadMetadata((prev) => {\n const next = new Map(prev);\n next.delete(previousPendingId);\n return next;\n });\n setThreads((prev) => {\n const next = new Map(prev);\n next.delete(previousPendingId);\n return next;\n });\n pendingChatMessagesRef.current.delete(previousPendingId);\n pendingSystemMessagesRef.current.delete(previousPendingId);\n tempToBackendIdRef.current.delete(previousPendingId);\n skipInitialFetchRef.current.delete(previousPendingId);\n }\n\n creatingThreadIdRef.current = newId;\n pendingChatMessagesRef.current.delete(newId);\n pendingSystemMessagesRef.current.delete(newId);\n setThreadMetadata((prev) =>\n new Map(prev).set(newId, {\n title: \"New Chat\",\n status: \"pending\",\n lastActiveAt: new Date().toISOString(),\n })\n );\n setThreadMessages(newId, []);\n setCurrentThreadId(newId);\n setIsRunning(false);\n bumpThreadViewKey();\n };\n\n // If any pending thread exists (either in-flight or awaiting title), reuse it without new request\n const existingPendingId = findPendingThreadId();\n if (existingPendingId) {\n preparePendingThread(existingPendingId);\n return;\n }\n\n // If a creation request is already in flight, just reset UI with a fresh pending thread\n if (createThreadPromiseRef.current) {\n preparePendingThread(creatingThreadIdRef.current ?? `temp-${crypto.randomUUID()}`);\n return;\n }\n\n // Generate a temporary ID for immediate UI update\n const tempId = `temp-${crypto.randomUUID()}`;\n preparePendingThread(tempId);\n\n // Create thread on backend in background (with null title)\n const createPromise = backendApiRef.current\n .createThread(publicKey, undefined)\n .then(async (newThread) => {\n const uiThreadId = creatingThreadIdRef.current ?? tempId;\n const backendId = newThread.session_id;\n\n // Store the mapping from tempId to backendId\n // This allows API calls to use the real backendId while UI stays on tempId\n tempToBackendIdRef.current.set(uiThreadId, backendId);\n\n // Mark this temp thread to skip initial fetch - we just created it,\n // and fetching would overwrite any messages the user has typed\n skipInitialFetchRef.current.add(uiThreadId);\n\n const backendTitle = newThread.title;\n if (backendTitle && !isPlaceholderTitle(backendTitle)) {\n setThreadMetadata((prev) => {\n const next = new Map(prev);\n const existing = next.get(uiThreadId);\n const nextStatus =\n existing?.status === \"archived\" ? \"archived\" : \"regular\";\n next.set(uiThreadId, {\n title: backendTitle,\n status: nextStatus,\n lastActiveAt: existing?.lastActiveAt ?? new Date().toISOString(),\n });\n return next;\n });\n if (creatingThreadIdRef.current === uiThreadId) {\n creatingThreadIdRef.current = null;\n }\n }\n\n // Flush any pending chat messages that were queued while waiting for backend ID\n const pendingMessages = pendingChatMessagesRef.current.get(uiThreadId);\n if (pendingMessages?.length) {\n pendingChatMessagesRef.current.delete(uiThreadId);\n for (const text of pendingMessages) {\n try {\n await backendApiRef.current.postChatMessage(backendId, text);\n } catch (error) {\n console.error(\"Failed to send queued message:\", error);\n }\n }\n // Start polling after messages are sent (only if user is still on this thread)\n if (currentThreadIdRef.current === uiThreadId) {\n startPolling();\n }\n }\n })\n .catch((error) => {\n console.error(\"Failed to create new thread:\", error);\n const failedId = creatingThreadIdRef.current ?? tempId;\n // On error, remove the temp thread from UI\n setThreadMetadata((prev) => {\n const next = new Map(prev);\n next.delete(failedId);\n return next;\n });\n setThreads((prev) => {\n const next = new Map(prev);\n next.delete(failedId);\n return next;\n });\n if (creatingThreadIdRef.current === failedId) {\n creatingThreadIdRef.current = null;\n }\n })\n .finally(() => {\n createThreadPromiseRef.current = null;\n });\n\n createThreadPromiseRef.current = createPromise;\n },\n\n // Switch to existing thread\n onSwitchToThread: (threadId: string) => {\n setCurrentThreadId(threadId);\n },\n\n // Rename thread\n onRename: async (threadId: string, newTitle: string) => {\n // Optimistic update\n updateThreadMetadata(threadId, { title: isPlaceholderTitle(newTitle) ? \"\" : newTitle });\n\n try {\n await backendApiRef.current.renameThread(threadId, newTitle);\n } catch (error) {\n console.error(\"Failed to rename thread:\", error);\n // Could rollback here, but we'll keep the optimistic update\n }\n },\n\n // Archive thread\n onArchive: async (threadId: string) => {\n // Optimistic update\n updateThreadMetadata(threadId, { status: \"archived\" });\n\n try {\n await backendApiRef.current.archiveThread(threadId);\n } catch (error) {\n console.error(\"Failed to archive thread:\", error);\n // Rollback on error\n updateThreadMetadata(threadId, { status: \"regular\" });\n }\n },\n\n // Unarchive thread\n onUnarchive: async (threadId: string) => {\n // Optimistic update\n updateThreadMetadata(threadId, { status: \"regular\" });\n\n try {\n await backendApiRef.current.unarchiveThread(threadId);\n } catch (error) {\n console.error(\"Failed to unarchive thread:\", error);\n // Rollback on error\n updateThreadMetadata(threadId, { status: \"archived\" });\n }\n },\n\n // Delete thread\n onDelete: async (threadId: string) => {\n try {\n await backendApiRef.current.deleteThread(threadId);\n\n // Remove from context\n setThreadMetadata((prev) => {\n const next = new Map(prev);\n next.delete(threadId);\n return next;\n });\n setThreads((prev) => {\n const next = new Map(prev);\n next.delete(threadId);\n return next;\n });\n\n // Switch to another thread if current was deleted\n if (currentThreadId === threadId) {\n const firstRegularThread = Array.from(threadMetadata.entries())\n .find(([id, meta]) => meta.status === \"regular\" && id !== threadId);\n\n if (firstRegularThread) {\n setCurrentThreadId(firstRegularThread[0]);\n } else {\n // No threads left, create a default one\n const defaultId = \"default-session\";\n setThreadMetadata((prev) =>\n new Map(prev).set(defaultId, {\n title: \"New Chat\",\n status: \"regular\",\n lastActiveAt: new Date().toISOString(),\n })\n );\n setThreadMessages(defaultId, []);\n setCurrentThreadId(defaultId);\n }\n }\n } catch (error) {\n console.error(\"Failed to delete thread:\", error);\n throw error; // Let the UI handle the error\n }\n },\n };\n })();\n\n // ==================== Message Handlers ====================\n const sendSystemMessageNow = useCallback(\n async (threadId: string, message: string) => {\n const backendThreadId = resolveThreadId(threadId);\n setIsRunning(true);\n try {\n const response = await backendApiRef.current.postSystemMessage(backendThreadId, message);\n\n if (response.res) {\n const systemMessage = constructSystemMessage(response.res);\n if (systemMessage) {\n const updatedMessages = [...getThreadMessages(threadId), systemMessage];\n setThreadMessages(threadId, updatedMessages);\n }\n }\n\n await startPolling();\n } catch (error) {\n console.error(\"Failed to send system message:\", error);\n setIsRunning(false);\n }\n },\n [getThreadMessages, setThreadMessages, startPolling, resolveThreadId]\n );\n\n const flushPendingSystemMessages = useCallback(\n async (threadId: string) => {\n const pending = pendingSystemMessagesRef.current.get(threadId);\n if (!pending?.length) return;\n\n pendingSystemMessagesRef.current.delete(threadId);\n for (const pendingMessage of pending) {\n // Send sequentially to preserve order\n await sendSystemMessageNow(threadId, pendingMessage);\n }\n },\n [sendSystemMessageNow]\n );\n\n // Flush pending chat messages when backend ID becomes available\n const flushPendingChatMessages = useCallback(\n async (threadId: string) => {\n const pending = pendingChatMessagesRef.current.get(threadId);\n if (!pending?.length) return;\n\n pendingChatMessagesRef.current.delete(threadId);\n const backendThreadId = resolveThreadId(threadId);\n\n for (const text of pending) {\n try {\n await backendApiRef.current.postChatMessage(backendThreadId, text);\n } catch (error) {\n console.error(\"Failed to send queued message:\", error);\n }\n }\n // Start polling after all messages are sent\n startPolling();\n },\n [resolveThreadId, startPolling]\n );\n\n const onNew = useCallback(\n async (message: AppendMessage) => {\n const text = message.content\n .filter((part): part is Extract<typeof part, { type: \"text\" }> => part.type === \"text\")\n .map((part: Extract<typeof message.content[number], { type: \"text\" }>) => part.text)\n .join(\"\\n\");\n\n if (!text) return;\n\n const userMessage: ThreadMessageLike = {\n role: \"user\",\n content: [{ type: \"text\", text }],\n createdAt: new Date(),\n };\n\n // Add message to current thread (show immediately in UI)\n setThreadMessages(currentThreadId, [...currentMessages, userMessage]);\n updateThreadMetadata(currentThreadId, { lastActiveAt: new Date().toISOString() });\n\n // If thread isn't ready (backend ID not available yet), queue the message\n if (!isThreadReady(currentThreadId)) {\n console.log(\"Thread not ready yet; queuing message for later delivery.\");\n setIsRunning(true); // Show pending state\n const pending = pendingChatMessagesRef.current.get(currentThreadId) || [];\n pendingChatMessagesRef.current.set(currentThreadId, [...pending, text]);\n return;\n }\n\n const backendThreadId = resolveThreadId(currentThreadId);\n\n try {\n setIsRunning(true);\n await backendApiRef.current.postChatMessage(backendThreadId, text);\n await flushPendingSystemMessages(currentThreadId);\n startPolling();\n } catch (error) {\n console.error(\"Failed to send message:\", error);\n setIsRunning(false);\n }\n },\n [\n currentThreadId,\n currentMessages,\n flushPendingSystemMessages,\n setThreadMessages,\n startPolling,\n isThreadReady,\n resolveThreadId,\n updateThreadMetadata,\n ]\n );\n\n const sendSystemMessage = useCallback(\n async (message: string) => {\n if (!isThreadReady(currentThreadId)) return;\n const threadMessages = getThreadMessages(currentThreadId);\n const hasUserMessages = threadMessages.some((msg) => msg.role === \"user\");\n\n if (!hasUserMessages) {\n const pending = pendingSystemMessagesRef.current.get(currentThreadId) || [];\n pendingSystemMessagesRef.current.set(currentThreadId, [...pending, message]);\n return;\n }\n\n await sendSystemMessageNow(currentThreadId, message);\n },\n [currentThreadId, getThreadMessages, sendSystemMessageNow, isThreadReady]\n );\n\n const onCancel = useCallback(async () => {\n if (!isThreadReady(currentThreadId)) return;\n stopPolling();\n\n const backendThreadId = resolveThreadId(currentThreadId);\n\n try {\n await backendApiRef.current.postInterrupt(backendThreadId);\n setIsRunning(false);\n } catch (error) {\n console.error(\"Failed to cancel:\", error);\n }\n }, [currentThreadId, stopPolling, isThreadReady, resolveThreadId]);\n\n // ==================== Runtime ====================\n const runtime = useExternalStoreRuntime({\n messages: currentMessages,\n setMessages: (msgs) => setThreadMessages(currentThreadId, [...msgs]),\n isRunning,\n onNew,\n onCancel,\n convertMessage: (msg) => msg,\n adapters: {\n threadList: threadListAdapter, // 🎯 Thread list adapter enabled!\n },\n });\n\n useEffect(() => {\n if (isTempThreadId(currentThreadId)) return;\n const hasUserMessages = currentMessages.some((msg) => msg.role === \"user\");\n if (hasUserMessages) {\n void flushPendingSystemMessages(currentThreadId);\n }\n }, [currentMessages, currentThreadId, flushPendingSystemMessages]);\n\n useEffect(() => {\n const unsubscribe = backendApiRef.current.subscribeToUpdates(\n (update) => {\n if (update.type !== \"TitleChanged\") return;\n const sessionId = update.data.session_id;\n const newTitle = update.data.new_title;\n\n // Check if this sessionId corresponds to a temp thread\n // If so, update the temp thread's metadata, not create a new one\n const tempId = findTempIdForBackendId(sessionId);\n const threadIdToUpdate = tempId || sessionId;\n\n setThreadMetadata((prev) => {\n const next = new Map(prev);\n const existing = next.get(threadIdToUpdate);\n const normalizedTitle = isPlaceholderTitle(newTitle) ? \"\" : newTitle;\n const nextStatus =\n existing?.status === \"archived\" ? \"archived\" : \"regular\";\n next.set(threadIdToUpdate, {\n title: normalizedTitle,\n status: nextStatus,\n lastActiveAt: existing?.lastActiveAt ?? new Date().toISOString(),\n });\n return next;\n });\n if (!isPlaceholderTitle(newTitle) && creatingThreadIdRef.current === threadIdToUpdate) {\n creatingThreadIdRef.current = null;\n }\n },\n (error) => {\n console.error(\"Failed to handle system update SSE:\", error);\n }\n );\n\n return () => {\n unsubscribe();\n };\n }, [backendUrl, setThreadMetadata, findTempIdForBackendId]);\n\n return (\n <RuntimeActionsContext.Provider value={{ sendSystemMessage }}>\n <AssistantRuntimeProvider runtime={runtime}>{children}</AssistantRuntimeProvider>\n </RuntimeActionsContext.Provider>\n );\n}\n","export interface SessionMessage {\n sender?: string;\n content?: string;\n timestamp?: string;\n is_streaming?: boolean;\n tool_stream?: [string, string] | { topic?: unknown; content?: unknown } | null;\n}\n\nexport interface SessionResponsePayload {\n messages?: SessionMessage[] | null;\n is_processing?: boolean;\n session_exists?: boolean;\n session_id?: string;\n pending_wallet_tx?: string | null;\n}\n\nexport type BackendSessionResponse = SessionResponsePayload;\n\nexport interface SystemResponsePayload {\n res?: SessionMessage | null;\n}\n\n// Thread Management Types\nexport interface ThreadMetadata {\n session_id: string;\n title: string;\n is_archived?: boolean;\n created_at?: string;\n updated_at?: string;\n last_active_at?: string;\n}\n\nexport interface CreateThreadResponse {\n session_id: string;\n title?: string;\n}\n\nexport type SystemUpdate =\n | {\n type: \"TitleChanged\";\n data: {\n session_id: string;\n new_title: string;\n };\n };\n\nfunction toQueryString(payload: Record<string, unknown>): string {\n const params = new URLSearchParams();\n for (const [key, value] of Object.entries(payload)) {\n if (value === undefined || value === null) continue;\n params.set(key, String(value));\n }\n const qs = params.toString();\n return qs ? `?${qs}` : \"\";\n}\n\nasync function postState<T>(\n backendUrl: string,\n path: string,\n payload: Record<string, unknown>\n): Promise<T> {\n const query = toQueryString(payload);\n const url = `${backendUrl}${path}${query}`;\n console.log('🔵 [postState] URL:', url);\n console.log('🔵 [postState] Payload:', payload);\n\n const response = await fetch(url, {\n method: \"POST\",\n });\n console.log('🔵 [postState] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [postState] Error:', response.status, response.statusText);\n throw new Error(`HTTP ${response.status}: ${response.statusText}`);\n }\n\n const data = (await response.json()) as T;\n console.log('🟢 [postState] Success:', data);\n return data;\n}\n\nexport class BackendApi {\n private connectionStatus = false;\n private eventSource: EventSource | null = null;\n private updatesEventSource: EventSource | null = null;\n\n constructor(private readonly backendUrl: string) {}\n\n async fetchState(sessionId: string): Promise<SessionResponsePayload> {\n console.log('🔵 [fetchState] Called with sessionId:', sessionId);\n const url = `${this.backendUrl}/api/state?session_id=${encodeURIComponent(sessionId)}`;\n console.log('🔵 [fetchState] URL:', url);\n\n const response = await fetch(url);\n console.log('🔵 [fetchState] Response status:', response.status, response.statusText);\n\n if (!response.ok) {\n console.error('🔴 [fetchState] Error:', response.status, response.statusText);\n throw new Error(`HTTP ${response.status}: ${response.statusText}`);\n }\n\n const data = (await response.json()) as SessionResponsePayload;\n console.log('🟢 [fetchState] Success:', data);\n return data;\n }\n\n async postChatMessage(sessionId: string, message: string): Promise<SessionResponsePayload> {\n console.log('🔵 [postChatMessage] Called with sessionId:', sessionId, 'message:', message);\n const result = await postState<SessionResponsePayload>(this.backendUrl, \"/api/chat\", { message, session_id: sessionId });\n console.log('🟢 [postChatMessage] Success:', result);\n return result;\n }\n\n async postSystemMessage(sessionId: string, message: string): Promise<SystemResponsePayload> {\n console.log('🔵 [postSystemMessage] Called with sessionId:', sessionId, 'message:', message);\n const result = await postState<SystemResponsePayload>(this.backendUrl, \"/api/system\", { message, session_id: sessionId });\n console.log('🟢 [postSystemMessage] Success:', result);\n return result;\n }\n\n async postInterrupt(sessionId: string): Promise<SessionResponsePayload> {\n console.log('🔵 [postInterrupt] Called with sessionId:', sessionId);\n const result = await postState<SessionResponsePayload>(this.backendUrl, \"/api/interrupt\", { session_id: sessionId });\n console.log('🟢 [postInterrupt] Success:', result);\n return result;\n }\n\n disconnectSSE(): void {\n if (this.eventSource) {\n this.eventSource.close();\n this.eventSource = null;\n }\n this.setConnectionStatus(false);\n }\n\n setConnectionStatus(on: boolean): void {\n this.connectionStatus = on\n }\n\n async connectSSE(sessionId: string, publicKey?: string) {\n // Close existing connection\n this.disconnectSSE();\n\n try {\n // Build URL with optional public_key parameter\n const url = new URL(`${this.backendUrl}/api/chat/stream`);\n url.searchParams.set('session_id', sessionId);\n if (publicKey) {\n url.searchParams.set('public_key', publicKey);\n }\n\n this.eventSource = new EventSource(url.toString());\n\n this.eventSource.onopen = () => {\n console.log('🌐 SSE connection opened to:', url.toString());\n this.setConnectionStatus(true);\n };\n\n this.eventSource.onmessage = (event) => {\n try {\n const data = JSON.parse(event.data);\n // this.updateChatState(data);\n } catch (error) {\n console.error('Failed to parse SSE data:', error);\n }\n };\n\n this.eventSource.onerror = (error) => {\n console.error('SSE connection error:', error);\n };\n\n } catch (error) {\n console.error('Failed to establish SSE connection:', error);\n this.handleConnectionError(sessionId, publicKey);\n }\n }\n\n private handleConnectionError(sessionId: string, publicKey?: string): void {\n this.setConnectionStatus(false);\n let attempt = 0;\n let total = 3;\n if (attempt < total) {\n attempt++;\n console.log(`Attempting to reconnect (${attempt}/${total})...`);\n\n setTimeout(() => {\n this.connectSSE(sessionId, publicKey);\n }, 100);\n } else {\n console.error('Max reconnection attempts reached');\n this.setConnectionStatus(false);\n }\n }\n\n subscribeToUpdates(\n onUpdate: (update: SystemUpdate) => void,\n onError?: (error: unknown) => void\n ): () => void {\n // Close any existing connection before opening a new one\n if (this.updatesEventSource) {\n this.updatesEventSource.close();\n }\n\n const updatesUrl = new URL(\"/api/updates\", this.backendUrl).toString();\n this.updatesEventSource = new EventSource(updatesUrl);\n\n this.updatesEventSource.onmessage = (event) => {\n try {\n const parsed = JSON.parse(event.data) as SystemUpdate;\n onUpdate(parsed);\n } catch (error) {\n console.error(\"Failed to parse system update SSE:\", error);\n onError?.(error);\n }\n };\n\n this.updatesEventSource.onerror = (error) => {\n console.error(\"System updates SSE error:\", error);\n onError?.(error);\n };\n\n return () => {\n if (this.updatesEventSource) {\n this.updatesEventSource.close();\n this.updatesEventSource = null;\n }\n };\n }\n\n // ==================== Thread Management API ====================\n\n /**\n * Fetch all threads/sessions for a given public key\n * @param publicKey - User's wallet address\n * @returns Array of thread metadata\n */\n async fetchThreads(publicKey: string): Promise<ThreadMetadata[]> {\n console.log('🔵 [fetchThreads] Called with publicKey:', publicKey);\n const url = `${this.backendUrl}/api/sessions?public_key=${encodeURIComponent(publicKey)}`;\n console.log('🔵 [fetchThreads] URL:', url);\n\n const response = await fetch(url);\n console.log('🔵 [fetchThreads] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [fetchThreads] Error:', response.status);\n throw new Error(`Failed to fetch threads: HTTP ${response.status}`);\n }\n\n const data = (await response.json()) as ThreadMetadata[];\n console.log('🟢 [fetchThreads] Success:', data);\n return data;\n }\n\n /**\n * Create a new thread/session\n * @param publicKey - Optional user's wallet address\n * @param title - Thread title (keep empty for backend to own the title)\n * @returns Created thread information with backend-generated ID\n */\n async createThread(publicKey?: string, title?: string): Promise<CreateThreadResponse> {\n console.log('🔵 [createThread] Called with publicKey:', publicKey, 'title:', title);\n const body: Record<string, string> = {};\n if (publicKey) {\n body.public_key = publicKey;\n }\n if (title) {\n body.title = title;\n }\n console.log('🔵 [createThread] Request body:', body);\n\n const url = `${this.backendUrl}/api/sessions`;\n console.log('🔵 [createThread] URL:', url);\n\n const response = await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n console.log('🔵 [createThread] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [createThread] Error:', response.status);\n throw new Error(`Failed to create thread: HTTP ${response.status}`);\n }\n\n const data = (await response.json()) as CreateThreadResponse;\n console.log('🟢 [createThread] Success:', data);\n return data;\n }\n\n /**\n * Archive a thread/session\n * @param sessionId - The session ID to archive\n */\n async archiveThread(sessionId: string): Promise<void> {\n console.log('🔵 [archiveThread] Called with sessionId:', sessionId);\n const url = `${this.backendUrl}/api/sessions/${encodeURIComponent(sessionId)}/archive`;\n console.log('🔵 [archiveThread] URL:', url);\n\n const response = await fetch(url, { method: 'POST' });\n console.log('🔵 [archiveThread] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [archiveThread] Error:', response.status);\n throw new Error(`Failed to archive thread: HTTP ${response.status}`);\n }\n console.log('🟢 [archiveThread] Success');\n }\n\n /**\n * Unarchive a thread/session\n * @param sessionId - The session ID to unarchive\n */\n async unarchiveThread(sessionId: string): Promise<void> {\n console.log('🔵 [unarchiveThread] Called with sessionId:', sessionId);\n const url = `${this.backendUrl}/api/sessions/${encodeURIComponent(sessionId)}/unarchive`;\n console.log('🔵 [unarchiveThread] URL:', url);\n\n const response = await fetch(url, { method: 'POST' });\n console.log('🔵 [unarchiveThread] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [unarchiveThread] Error:', response.status);\n throw new Error(`Failed to unarchive thread: HTTP ${response.status}`);\n }\n console.log('🟢 [unarchiveThread] Success');\n }\n\n /**\n * Delete a thread/session permanently\n * @param sessionId - The session ID to delete\n */\n async deleteThread(sessionId: string): Promise<void> {\n console.log('🔵 [deleteThread] Called with sessionId:', sessionId);\n const url = `${this.backendUrl}/api/sessions/${encodeURIComponent(sessionId)}`;\n console.log('🔵 [deleteThread] URL:', url);\n\n const response = await fetch(url, { method: 'DELETE' });\n console.log('🔵 [deleteThread] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [deleteThread] Error:', response.status);\n throw new Error(`Failed to delete thread: HTTP ${response.status}`);\n }\n console.log('🟢 [deleteThread] Success');\n }\n\n /**\n * Rename a thread/session\n * @param sessionId - The session ID to rename\n * @param newTitle - The new title for the thread\n */\n async renameThread(sessionId: string, newTitle: string): Promise<void> {\n console.log('🔵 [renameThread] Called with sessionId:', sessionId, 'newTitle:', newTitle);\n const url = `${this.backendUrl}/api/sessions/${encodeURIComponent(sessionId)}`;\n console.log('🔵 [renameThread] URL:', url);\n\n const response = await fetch(url, {\n method: 'PATCH',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ title: newTitle }),\n });\n console.log('🔵 [renameThread] Response status:', response.status);\n\n if (!response.ok) {\n console.error('🔴 [renameThread] Error:', response.status);\n throw new Error(`Failed to rename thread: HTTP ${response.status}`);\n }\n console.log('🟢 [renameThread] Success');\n }\n}\n","import { SessionMessage } from \"@/lib/backend-api\";\nimport { ThreadMessageLike } from \"@assistant-ui/react\";\n\nexport function constructThreadMessage(msg: SessionMessage): ThreadMessageLike | null {\n if (msg.sender === \"system\") return null;\n\n const content = [];\n const role: ThreadMessageLike[\"role\"] = msg.sender === \"user\" ? \"user\" : \"assistant\";\n\n if (msg.content) {\n content.push({ type: \"text\" as const, text: msg.content });\n }\n\n const [topic, toolContent] = parseToolStream(msg.tool_stream) ?? [];\n if (topic && toolContent) {\n content.push({\n type: \"tool-call\" as const,\n toolCallId: `tool_${Date.now()}`,\n toolName: topic,\n args: undefined,\n result: (() => {\n try {\n return JSON.parse(toolContent);\n } catch {\n return { args: toolContent };\n }\n })(),\n });\n }\n\n const threadMessage = {\n role,\n content: content.length > 0 ? content : [{ type: \"text\" as const, text: \"\" }],\n ...(msg.timestamp && { createdAt: new Date(msg.timestamp) }),\n };\n\n return threadMessage;\n}\n\n\n// SessionMessage {\n// sender: 'system';\n// content: 'system's msg to the agent'; => system send to the agent e.g. \"wallet connected on X network with address Y, call tools with network param X\"\n// timestamp: some-time; => \"Error calling tool WebSearch: 404\"\n// is_streaming: false;\n// tool_stream: ['notification name to print', '']; => system notification to show to the user \"Wallet connected on X network\"\n// => \"WebSearch Error\"\n// }\n\nexport function constructSystemMessage(msg: SessionMessage): ThreadMessageLike | null {\n const [topic] = parseToolStream(msg.tool_stream) ?? [];\n const messageText = topic || msg.content || \"\";\n const timestamp = parseTimestamp(msg.timestamp);\n\n if (!messageText.trim()) return null;\n\n return {\n role: \"system\",\n content: [{ type: \"text\", text: messageText }],\n ...(timestamp && { createdAt: timestamp }),\n };\n}\n\nexport function constructUITool(): string {\n // TODO\n return '';\n}\n\nfunction parseTimestamp(timestamp?: string) {\n if (!timestamp) return undefined;\n const parsed = new Date(timestamp);\n return Number.isNaN(parsed.valueOf()) ? undefined : parsed;\n}\n\n\nfunction parseToolStream(toolStream: SessionMessage[\"tool_stream\"]): [string, string] | null {\n if (!toolStream) return null;\n\n if (Array.isArray(toolStream) && toolStream.length === 2) {\n const [topic, content] = toolStream;\n return [String(topic), content];\n } else if (typeof toolStream === \"object\") {\n const topic = (toolStream as { topic?: unknown }).topic;\n const content = (toolStream as { content?: unknown }).content;\n return topic ? [String(topic), String(content)] : null;\n }\n\n return null;\n}\n","\"use client\";\n\nimport { useEffect, useRef } from \"react\";\nimport { useRuntimeActions } from \"@/components/assistant-ui/runtime\";\n\n// ============================================\n// Types\n// ============================================\n\nexport type WalletButtonState = {\n address?: string;\n chainId?: number;\n isConnected: boolean;\n ensName?: string;\n};\n\nexport type WalletFooterProps = {\n wallet: WalletButtonState;\n setWallet: (data: Partial<WalletButtonState>) => void;\n};\n\n// ============================================\n// Utility Functions\n// ============================================\n\n/**\n * Get network name from chainId\n */\nexport const getNetworkName = (chainId: number | string | undefined): string => {\n if (chainId === undefined) return \"\";\n const id = typeof chainId === \"string\" ? Number(chainId) : chainId;\n switch (id) {\n case 1:\n return \"ethereum\";\n case 137:\n return \"polygon\";\n case 42161:\n return \"arbitrum\";\n case 8453:\n return \"base\";\n case 10:\n return \"optimism\";\n case 11155111:\n return \"sepolia\";\n case 1337:\n case 31337:\n return \"testnet\";\n case 59140:\n return \"linea-sepolia\";\n case 59144:\n return \"linea\";\n default:\n return \"testnet\";\n }\n};\n\n/**\n * Format wallet address for display (0x1234...5678)\n */\nexport const formatAddress = (addr?: string): string =>\n addr ? `${addr.slice(0, 6)}...${addr.slice(-4)}` : \"Connect Wallet\";\n\n// ============================================\n// WalletSystemMessageEmitter\n// ============================================\n\ntype WalletSystemMessageEmitterProps = {\n wallet: WalletButtonState;\n};\n\n/**\n * Internal component that watches wallet state and sends system messages\n * to the backend when wallet connects, disconnects, or switches networks.\n */\nexport function WalletSystemMessageEmitter({ wallet }: WalletSystemMessageEmitterProps) {\n const { sendSystemMessage } = useRuntimeActions();\n const lastWalletRef = useRef<{\n isConnected: boolean;\n address?: string;\n chainId?: number;\n }>({ isConnected: false });\n\n useEffect(() => {\n const prev = lastWalletRef.current;\n const { address, chainId, isConnected } = wallet;\n const normalizedAddress = address?.toLowerCase();\n\n // Handle connect\n if (\n isConnected &&\n normalizedAddress &&\n chainId &&\n (!prev.isConnected || prev.address !== normalizedAddress)\n ) {\n const networkName = getNetworkName(chainId);\n const message = `User connected wallet with address ${normalizedAddress} on ${networkName} network (Chain ID: ${chainId}). Ready to help with transactions.`;\n console.log(message);\n void sendSystemMessage(message);\n lastWalletRef.current = { isConnected: true, address: normalizedAddress, chainId };\n return;\n }\n\n // Handle disconnect\n if (!isConnected && prev.isConnected) {\n void sendSystemMessage(\"Wallet disconnected by user.\");\n console.log(\"Wallet disconnected by user.\");\n lastWalletRef.current = { isConnected: false };\n return;\n }\n\n // Handle network switch\n if (\n isConnected &&\n normalizedAddress &&\n chainId &&\n prev.isConnected &&\n prev.address === normalizedAddress &&\n prev.chainId !== chainId\n ) {\n const networkName = getNetworkName(chainId);\n const message = `User switched wallet to ${networkName} network (Chain ID: ${chainId}).`;\n console.log(message);\n void sendSystemMessage(message);\n lastWalletRef.current = { isConnected: true, address: normalizedAddress, chainId };\n }\n }, [wallet, sendSystemMessage]);\n\n return null;\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport Link from \"next/link\";\nimport Image from \"next/image\";\nimport { Button } from \"@/components/ui/button\";\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarRail,\n} from \"@/components/ui/sidebar\";\nimport { ThreadList } from \"@/components/assistant-ui/thread-list\";\n\ntype BaseSidebarProps = React.ComponentProps<typeof Sidebar> & {\n /** Label to display on the footer button */\n footerLabel?: string;\n /** Secondary label (e.g., network name) */\n footerSecondaryLabel?: string;\n /** Click handler for footer button */\n onFooterClick?: () => void;\n /** Logo URL (defaults to aomi logo) */\n logoUrl?: string;\n /** Logo link href */\n logoHref?: string;\n};\n\nexport function BaseSidebar({\n footerLabel = \"Connect Wallet\",\n footerSecondaryLabel,\n onFooterClick,\n logoUrl = \"/assets/images/a.svg\",\n logoHref = \"https://aomi.dev\",\n ...props\n}: BaseSidebarProps) {\n return (\n <Sidebar\n collapsible=\"offcanvas\"\n variant=\"inset\"\n className=\"relative\"\n {...props}\n >\n <SidebarHeader className=\"aomi-sidebar-header\">\n <div className=\"aomi-sidebar-header-content flex items-center justify-between\">\n <SidebarMenu>\n <SidebarMenuItem>\n <SidebarMenuButton size=\"lg\" asChild>\n <Link\n href={logoHref}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <div className=\"aomi-sidebar-header-icon-wrapper flex aspect-square size-8 items-center justify-center rounded-lg bg-white\">\n <Image\n src={logoUrl}\n alt=\"Logo\"\n width={28}\n height={28}\n className=\"aomi-sidebar-header-icon size-7 ml-3\"\n priority\n />\n </div>\n </Link>\n </SidebarMenuButton>\n </SidebarMenuItem>\n </SidebarMenu>\n </div>\n </SidebarHeader>\n <SidebarContent className=\"aomi-sidebar-content\">\n <ThreadList />\n </SidebarContent>\n <SidebarRail />\n <SidebarFooter className=\"aomi-sidebar-footer border-t border-sm py-4\">\n <SidebarMenu>\n <SidebarMenuItem>\n <SidebarMenuButton size=\"lg\" asChild>\n <Button\n className=\"w-full justify-center rounded-full text-white shadow-lg hover:bg-[var(--muted-foreground)] hover:text-white\"\n onClick={onFooterClick}\n >\n <div className=\"flex items-center gap-2\">\n <span className=\"text-sm\">{footerLabel}</span>\n {footerSecondaryLabel ? (\n <span className=\"text-[11px] text-white/80\">• {footerSecondaryLabel}</span>\n ) : null}\n </div>\n </Button>\n </SidebarMenuButton>\n </SidebarMenuItem>\n </SidebarMenu>\n </SidebarFooter>\n </Sidebar>\n );\n}\n","import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Card = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={cn(\n \"rounded-lg border bg-card text-card-foreground shadow-sm\",\n className\n )}\n {...props}\n />\n))\nCard.displayName = \"Card\"\n\nconst CardHeader = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={cn(\"flex flex-col space-y-1.5 p-6\", className)}\n {...props}\n />\n))\nCardHeader.displayName = \"CardHeader\"\n\nconst CardTitle = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLHeadingElement>\n>(({ className, ...props }, ref) => (\n <h3\n ref={ref}\n className={cn(\n \"text-2xl font-semibold leading-none tracking-tight\",\n className\n )}\n {...props}\n />\n))\nCardTitle.displayName = \"CardTitle\"\n\nconst CardDescription = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => (\n <p\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n))\nCardDescription.displayName = \"CardDescription\"\n\nconst CardContent = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n <div ref={ref} className={cn(\"p-6 pt-0\", className)} {...props} />\n))\nCardContent.displayName = \"CardContent\"\n\nconst CardFooter = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={cn(\"flex items-center p-6 pt-0\", className)}\n {...props}\n />\n))\nCardFooter.displayName = \"CardFooter\"\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent }\n","import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst badgeVariants = cva(\n \"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2\",\n {\n variants: {\n variant: {\n default:\n \"border-transparent bg-primary text-primary-foreground hover:bg-primary/80\",\n secondary:\n \"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n destructive:\n \"border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80\",\n outline: \"text-foreground\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nexport interface BadgeProps\n extends React.HTMLAttributes<HTMLDivElement>,\n VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n return (\n <div className={cn(badgeVariants({ variant }), className)} {...props} />\n )\n}\n\nexport { Badge, badgeVariants }\n","import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Label = React.forwardRef<\n HTMLLabelElement,\n React.LabelHTMLAttributes<HTMLLabelElement>\n>(({ className, ...props }, ref) => (\n <label\n ref={ref}\n className={cn(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n className\n )}\n {...props}\n />\n))\nLabel.displayName = \"Label\"\n\nexport { Label }\n"],"mappings":"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","names":["import_react","import_lucide_react","import_react","import_react","import_react_slot","import_jsx_runtime","import_jsx_runtime","import_jsx_runtime","remarkGfm","memoizeMarkdownComponents","import_lucide_react","import_react","import_jsx_runtime","import_react","import_lucide_react","import_lucide_react","import_jsx_runtime","import_jsx_runtime","import_jsx_runtime","_a","src","Image","import_react","import_jsx_runtime","import_react","import_jsx_runtime","import_image","React","import_react_slot","import_class_variance_authority","import_lucide_react","import_jsx_runtime","import_jsx_runtime","import_lucide_react","import_jsx_runtime","import_jsx_runtime","import_jsx_runtime","open","import_react","import_lucide_react","import_jsx_runtime","import_jsx_runtime","Link","Image","import_react_slot","import_lucide_react","import_jsx_runtime","import_react","import_jsx_runtime","parseTimestamp","_a","import_react","import_jsx_runtime","import_link","import_image","import_jsx_runtime","Link","Image","React","import_jsx_runtime","import_class_variance_authority","import_jsx_runtime","React","import_jsx_runtime"]}