'use client' import { ChevronDownIcon, PaperclipIcon } from 'lucide-react' import type { ComponentProps } from 'react' import { Button } from '@/components/ui/button' import { Collapsible, CollapsibleContent, CollapsibleTrigger, } from '@/components/ui/collapsible' import { ScrollArea } from '@/components/ui/scroll-area' import { cn } from '@/lib/utils' export type QueueMessagePart = { type: string text?: string url?: string filename?: string mediaType?: string } export type QueueMessage = { id: string parts: QueueMessagePart[] } export type QueueTodo = { id: string title: string description?: string status?: 'pending' | 'completed' } export type QueueItemProps = ComponentProps<'li'> /** @public */ export const QueueItem = ({ className, ...props }: QueueItemProps) => (
  • ) export type QueueItemIndicatorProps = ComponentProps<'span'> & { completed?: boolean } /** @public */ export const QueueItemIndicator = ({ completed = false, className, ...props }: QueueItemIndicatorProps) => ( ) export type QueueItemContentProps = ComponentProps<'span'> & { completed?: boolean } /** @public */ export const QueueItemContent = ({ completed = false, className, ...props }: QueueItemContentProps) => ( ) export type QueueItemDescriptionProps = ComponentProps<'div'> & { completed?: boolean } /** @public */ export const QueueItemDescription = ({ completed = false, className, ...props }: QueueItemDescriptionProps) => (
    ) export type QueueItemActionsProps = ComponentProps<'div'> /** @public */ export const QueueItemActions = ({ className, ...props }: QueueItemActionsProps) => (
    ) export type QueueItemActionProps = Omit< ComponentProps, 'variant' | 'size' > /** @public */ export const QueueItemAction = ({ className, ...props }: QueueItemActionProps) => ( ) // QueueSectionLabel - label content with icon and count export type QueueSectionLabelProps = ComponentProps<'span'> & { count?: number label: string icon?: React.ReactNode } /** @public */ export const QueueSectionLabel = ({ count, label, icon, className, ...props }: QueueSectionLabelProps) => ( {icon} {count} {label} ) // QueueSectionContent - collapsible content area export type QueueSectionContentProps = ComponentProps /** @public */ export const QueueSectionContent = ({ className, ...props }: QueueSectionContentProps) => ( ) export type QueueProps = ComponentProps<'div'> /** @public */ export const Queue = ({ className, ...props }: QueueProps) => (
    )