@alfadocs/ui-kit-debug 0.46.0 → 0.47.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.
- package/dist/_chunks/alia-sidebar-CVIPrdc9.js +1125 -0
- package/dist/_chunks/alia-sidebar-CVIPrdc9.js.map +1 -0
- package/dist/_chunks/{audio-recorder-C1rhKhSN.js → audio-recorder-DC-v9YFW.js} +81 -91
- package/dist/_chunks/audio-recorder-DC-v9YFW.js.map +1 -0
- package/dist/_chunks/{chat-input-CQe7nR_v.js → chat-input-CFwc7JxL.js} +2 -1
- package/dist/_chunks/{chat-input-CQe7nR_v.js.map → chat-input-CFwc7JxL.js.map} +1 -1
- package/dist/_chunks/{chat-message-ASgGtj-L.js → chat-message-B5JpFj0F.js} +79 -73
- package/dist/_chunks/chat-message-B5JpFj0F.js.map +1 -0
- package/dist/_chunks/code-block-HoddNOKJ.js +106 -0
- package/dist/_chunks/code-block-HoddNOKJ.js.map +1 -0
- package/dist/_chunks/download-CDF1sbL9.js +16 -0
- package/dist/_chunks/download-CDF1sbL9.js.map +1 -0
- package/dist/_chunks/{editable-currency-cell-renderer-BEBUQl9P.js → editable-currency-cell-renderer-CLil9B29.js} +283 -293
- package/dist/_chunks/editable-currency-cell-renderer-CLil9B29.js.map +1 -0
- package/dist/_chunks/mic-B4Gog3Gi.js +16 -0
- package/dist/_chunks/mic-B4Gog3Gi.js.map +1 -0
- package/dist/_chunks/pencil-CfQX-0Qc.js +21 -0
- package/dist/_chunks/pencil-CfQX-0Qc.js.map +1 -0
- package/dist/_chunks/{streaming-text-GH07yIYh.js → streaming-text-CfhDqtIT.js} +49 -45
- package/dist/_chunks/streaming-text-CfhDqtIT.js.map +1 -0
- package/dist/_chunks/{workflow-map-BFNpzTiw.js → workflow-map-Djn1QMJc.js} +135 -150
- package/dist/_chunks/workflow-map-Djn1QMJc.js.map +1 -0
- package/dist/agent-catalog.json +1 -1
- package/dist/components/_shared/code-block.d.ts +39 -0
- package/dist/components/_shared/code-block.d.ts.map +1 -0
- package/dist/components/audio-recorder/index.js +1 -1
- package/dist/components/chat-input/index.js +1 -1
- package/dist/components/chat-message/chat-message.d.ts +6 -0
- package/dist/components/chat-message/chat-message.d.ts.map +1 -1
- package/dist/components/chat-message/index.js +1 -1
- package/dist/components/data-table/index.js +1 -1
- package/dist/components/streaming-text/index.js +1 -1
- package/dist/components/streaming-text/streaming-text.d.ts.map +1 -1
- package/dist/components/workflow/index.js +1 -1
- package/dist/i18n/locales/ar.d.ts +15 -0
- package/dist/i18n/locales/ar.d.ts.map +1 -1
- package/dist/i18n/locales/ar.js +16 -1
- package/dist/i18n/locales/ar.js.map +1 -1
- package/dist/i18n/locales/de.d.ts +15 -0
- package/dist/i18n/locales/de.d.ts.map +1 -1
- package/dist/i18n/locales/de.js +16 -1
- package/dist/i18n/locales/de.js.map +1 -1
- package/dist/i18n/locales/el.d.ts +15 -0
- package/dist/i18n/locales/el.d.ts.map +1 -1
- package/dist/i18n/locales/el.js +16 -1
- package/dist/i18n/locales/el.js.map +1 -1
- package/dist/i18n/locales/en.d.ts +15 -0
- package/dist/i18n/locales/en.d.ts.map +1 -1
- package/dist/i18n/locales/en.js +16 -1
- package/dist/i18n/locales/en.js.map +1 -1
- package/dist/i18n/locales/es.d.ts +15 -0
- package/dist/i18n/locales/es.d.ts.map +1 -1
- package/dist/i18n/locales/es.js +16 -1
- package/dist/i18n/locales/es.js.map +1 -1
- package/dist/i18n/locales/fr.d.ts +15 -0
- package/dist/i18n/locales/fr.d.ts.map +1 -1
- package/dist/i18n/locales/fr.js +16 -1
- package/dist/i18n/locales/fr.js.map +1 -1
- package/dist/i18n/locales/hi.d.ts +15 -0
- package/dist/i18n/locales/hi.d.ts.map +1 -1
- package/dist/i18n/locales/hi.js +16 -1
- package/dist/i18n/locales/hi.js.map +1 -1
- package/dist/i18n/locales/it.d.ts +15 -0
- package/dist/i18n/locales/it.d.ts.map +1 -1
- package/dist/i18n/locales/it.js +16 -1
- package/dist/i18n/locales/it.js.map +1 -1
- package/dist/i18n/locales/ja.d.ts +15 -0
- package/dist/i18n/locales/ja.d.ts.map +1 -1
- package/dist/i18n/locales/ja.js +16 -1
- package/dist/i18n/locales/ja.js.map +1 -1
- package/dist/i18n/locales/nl.d.ts +15 -0
- package/dist/i18n/locales/nl.d.ts.map +1 -1
- package/dist/i18n/locales/nl.js +16 -1
- package/dist/i18n/locales/nl.js.map +1 -1
- package/dist/i18n/locales/pl.d.ts +15 -0
- package/dist/i18n/locales/pl.d.ts.map +1 -1
- package/dist/i18n/locales/pl.js +16 -1
- package/dist/i18n/locales/pl.js.map +1 -1
- package/dist/i18n/locales/pt.d.ts +15 -0
- package/dist/i18n/locales/pt.d.ts.map +1 -1
- package/dist/i18n/locales/pt.js +16 -1
- package/dist/i18n/locales/pt.js.map +1 -1
- package/dist/i18n/locales/ro.d.ts +15 -0
- package/dist/i18n/locales/ro.d.ts.map +1 -1
- package/dist/i18n/locales/ro.js +16 -1
- package/dist/i18n/locales/ro.js.map +1 -1
- package/dist/i18n/locales/ru.d.ts +15 -0
- package/dist/i18n/locales/ru.d.ts.map +1 -1
- package/dist/i18n/locales/ru.js +16 -1
- package/dist/i18n/locales/ru.js.map +1 -1
- package/dist/i18n/locales/sq.d.ts +15 -0
- package/dist/i18n/locales/sq.d.ts.map +1 -1
- package/dist/i18n/locales/sq.js +16 -1
- package/dist/i18n/locales/sq.js.map +1 -1
- package/dist/i18n/locales/sv.d.ts +15 -0
- package/dist/i18n/locales/sv.d.ts.map +1 -1
- package/dist/i18n/locales/sv.js +16 -1
- package/dist/i18n/locales/sv.js.map +1 -1
- package/dist/i18n/locales/tr.d.ts +15 -0
- package/dist/i18n/locales/tr.d.ts.map +1 -1
- package/dist/i18n/locales/tr.js +16 -1
- package/dist/i18n/locales/tr.js.map +1 -1
- package/dist/i18n/locales/zh.d.ts +15 -0
- package/dist/i18n/locales/zh.d.ts.map +1 -1
- package/dist/i18n/locales/zh.js +16 -1
- package/dist/i18n/locales/zh.js.map +1 -1
- package/dist/index.js +7 -7
- package/dist/locales/ar.json +16 -1
- package/dist/locales/de.json +16 -1
- package/dist/locales/el.json +16 -1
- package/dist/locales/en.json +16 -1
- package/dist/locales/es.json +16 -1
- package/dist/locales/fr.json +16 -1
- package/dist/locales/hi.json +16 -1
- package/dist/locales/it.json +16 -1
- package/dist/locales/ja.json +16 -1
- package/dist/locales/nl.json +16 -1
- package/dist/locales/pl.json +16 -1
- package/dist/locales/pt.json +16 -1
- package/dist/locales/ro.json +16 -1
- package/dist/locales/ru.json +16 -1
- package/dist/locales/sq.json +16 -1
- package/dist/locales/sv.json +16 -1
- package/dist/locales/tr.json +16 -1
- package/dist/locales/zh.json +16 -1
- package/dist/patterns/alia-assistant/alia-chat-surface.d.ts.map +1 -1
- package/dist/patterns/alia-assistant/alia-types.d.ts +61 -0
- package/dist/patterns/alia-assistant/alia-types.d.ts.map +1 -1
- package/dist/patterns/alia-assistant/index.js +1 -1
- package/dist/tokens.css +1 -1
- package/package.json +1 -1
- package/dist/_chunks/alia-sidebar-Be8FhKYd.js +0 -837
- package/dist/_chunks/alia-sidebar-Be8FhKYd.js.map +0 -1
- package/dist/_chunks/audio-recorder-C1rhKhSN.js.map +0 -1
- package/dist/_chunks/chat-message-ASgGtj-L.js.map +0 -1
- package/dist/_chunks/editable-currency-cell-renderer-BEBUQl9P.js.map +0 -1
- package/dist/_chunks/streaming-text-GH07yIYh.js.map +0 -1
- package/dist/_chunks/workflow-map-BFNpzTiw.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alia-sidebar-CVIPrdc9.js","sources":["../../node_modules/lucide-react/dist/esm/icons/shield-x.js","../../src/patterns/alia-assistant/alia-chat-surface.tsx","../../src/patterns/alia-assistant/alia-embedded.tsx","../../src/patterns/alia-assistant/alia-popout.tsx","../../src/patterns/alia-assistant/alia-sidebar.tsx"],"sourcesContent":["/**\n * @license lucide-react v1.8.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z\",\n key: \"oel41y\"\n }\n ],\n [\"path\", { d: \"m14.5 9.5-5 5\", key: \"17q4r4\" }],\n [\"path\", { d: \"m9.5 9.5 5 5\", key: \"18nt4w\" }]\n];\nconst ShieldX = createLucideIcon(\"shield-x\", __iconNode);\n\nexport { __iconNode, ShieldX as default };\n//# sourceMappingURL=shield-x.js.map\n","/**\n * Alia Assistant — inner chat surface shared between embedded and popout\n * modes. This is a pure presentational composition of existing DS\n * primitives and owns NO state, NO API calls, NO SSE parsing — the\n * consuming app drives `messages`, `isGenerating`, `usage`, and the\n * callbacks.\n */\nimport {\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n type ReactNode,\n} from 'react';\nimport { useTranslation } from 'react-i18next';\nimport {\n Check,\n Copy,\n Download,\n Mic,\n Paperclip,\n Pencil,\n Plus,\n RefreshCw,\n ShieldX,\n Sparkles,\n Square,\n User,\n X,\n} from 'lucide-react';\nimport { Avatar } from '../../components/avatar';\nimport { Button, IconButton } from '../../components/button';\nimport { ChatContainer } from '../../components/chat-container';\nimport { ChatMessage } from '../../components/chat-message';\nimport { ChatInput } from '../../components/chat-input';\nimport { Spinner } from '../../components/spinner';\nimport { StreamingText } from '../../components/streaming-text';\nimport {\n SuggestionChip,\n SuggestionChipGroup,\n} from '../../components/suggestion-chip';\nimport { TypingIndicator } from '../../components/typing-indicator';\nimport { Progress } from '../../components/progress';\nimport type {\n AliaAttachment,\n AliaChatSurfaceProps,\n AliaMessage,\n AliaSuggestion,\n AliaUserAvatar,\n} from './alia-types';\n\n/* ------------------------------------------------------------------ */\n/* Alia identity tile — Sparkles on an accent-tinted disc. */\n/* */\n/* Used in place of <Avatar> for Alia's own identity (header + empty */\n/* state + streaming/typing rows) so the visual identity matches the */\n/* collapsed sidebar rail trigger. When the consuming app supplies an */\n/* `assistantAvatar.src`, AliaChatSurface falls back to <Avatar> — the */\n/* sparkle is for the DS-provided default only. */\n/* */\n/* Sizes mirror the Avatar size scale we were replacing: */\n/* sm → 32px (row messages, streaming bubble, compact header) */\n/* md → 40px (default header) */\n/* xl → 64px (empty-state hero) */\n/* ------------------------------------------------------------------ */\n\nconst LEO_TILE_SIZES = {\n sm: {\n box: 'ds:size-[calc(var(--spacing-md)*2)]',\n icon: 'ds:size-4',\n },\n md: {\n box: 'ds:size-[calc(var(--spacing-md)*2.5)]',\n icon: 'ds:size-[1.125rem]',\n },\n xl: {\n box: 'ds:size-[calc(var(--spacing-md)*4)]',\n icon: 'ds:size-8',\n },\n} as const;\n\nfunction AliaIdentityTile({\n size,\n label,\n appearance = 'sparkle',\n loading = false,\n}: {\n size: keyof typeof LEO_TILE_SIZES;\n label: string;\n /**\n * `'sparkle'` (default) — Sparkles on the accent-tinted disc. `'spinner'` —\n * the AlfaDocs brand mark in the brand colour (no disc): a static logo glyph\n * at rest, switching to a pulse while the assistant is generating. Used for\n * Alia's identity throughout — header, empty-state hero, and chat rows (the\n * streaming row pulses; every other row shows the static mark).\n */\n appearance?: 'sparkle' | 'spinner';\n /** When `appearance='spinner'`, pulse rather than rest static (Alia is generating). */\n loading?: boolean;\n}) {\n const dims = LEO_TILE_SIZES[size];\n\n if (appearance === 'spinner') {\n // Alia's identity = the AlfaDocs brand mark in the brand colour (--primary,\n // the violet the logo uses): static at rest, pulsing while generating. The\n // tile owns the accessible name (`role=\"img\"` + `aria-label`); the Spinner\n // is decorative — `aria-hidden` suppresses its own `role=\"status\"` +\n // `aria-live`, so there's no nested image semantics and no \"Loading…\" announce.\n return (\n <span\n role=\"img\"\n aria-label={label}\n className=\"ds:inline-flex ds:shrink-0 ds:items-center ds:justify-center ds:text-[color:var(--primary)]\"\n >\n <Spinner\n aria-hidden={true}\n variant={loading ? 'pulse' : 'static'}\n className={dims.box}\n />\n </span>\n );\n }\n\n return (\n <span\n role=\"img\"\n aria-label={label}\n className={[\n 'ds:inline-flex ds:shrink-0 ds:items-center ds:justify-center',\n 'ds:rounded-[var(--radius-full)]',\n // Subtle accent-tinted disc so the sparkle reads against both\n // light and dark surfaces without a hard-coded literal colour.\n 'ds:bg-[color-mix(in_srgb,var(--accent)_14%,transparent)]',\n 'ds:text-[color:var(--accent)]',\n // forced-colors: UA strips color-mix backgrounds; fall back to\n // a bordered disc so the identity still reads in HCM.\n 'ds:forced-colors:bg-transparent ds:forced-colors:border ds:forced-colors:border-[CanvasText]',\n dims.box,\n ].join(' ')}\n >\n <Sparkles aria-hidden=\"true\" className={dims.icon} />\n </span>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* User identity tile — neutral companion to the Sparkles tile above. */\n/* Rendered when the caller has no user avatar to display, so the */\n/* conversation still has a consistent visual anchor on both sides. */\n/* Uses --muted/--muted-foreground so it reads as \"neutral person\" */\n/* without borrowing the brand accent. */\n/* ------------------------------------------------------------------ */\n\nfunction UserIdentityTile({\n size,\n label,\n}: {\n size: keyof typeof LEO_TILE_SIZES;\n label: string;\n}) {\n const dims = LEO_TILE_SIZES[size];\n return (\n <span\n role=\"img\"\n aria-label={label}\n className={[\n 'ds:inline-flex ds:shrink-0 ds:items-center ds:justify-center',\n 'ds:rounded-[var(--radius-full)]',\n 'ds:bg-[color-mix(in_srgb,var(--muted-foreground)_14%,transparent)]',\n 'ds:text-[color:var(--muted-foreground)]',\n 'ds:forced-colors:bg-transparent ds:forced-colors:border ds:forced-colors:border-[CanvasText]',\n dims.box,\n ].join(' ')}\n >\n <User aria-hidden=\"true\" className={dims.icon} />\n </span>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* Ended divider — centred, locked \"conversation ended\" notice shown */\n/* at the END of the message list when `ended` is set. Mirrors the */\n/* system-message divider styling (centred, muted, type-body-sm) but */\n/* adds a lock affordance (ShieldX) and a `role=\"status\"` so AT users */\n/* hear the termination. The consuming app supplies `note`. */\n/* ------------------------------------------------------------------ */\n\nfunction EndedDivider({ note }: { note: ReactNode }) {\n return (\n <div\n role=\"status\"\n className={[\n 'ds:flex ds:w-full ds:flex-col ds:items-center ds:text-center',\n 'ds:gap-[var(--spacing-xs)]',\n ].join(' ')}\n data-testid=\"alia-ended-divider\"\n >\n <ShieldX\n aria-hidden=\"true\"\n className=\"ds:size-5 ds:text-[color:var(--destructive)]\"\n />\n <span className=\"type-body-sm ds:text-[color:var(--muted-foreground)]\">\n {note}\n </span>\n </div>\n );\n}\n\n/**\n * Pick the right avatar shape for a user message.\n *\n * Precedence (highest wins):\n * 1. `userAvatar.slot` — caller supplied a fully custom node.\n * 2. `userAvatar.src` — caller supplied a photo (or initials override via `name`).\n * 3. `userAvatar.name` only — <Avatar> renders initials.\n * 4. Nothing supplied — fall back to the neutral `<UserIdentityTile>`.\n */\nfunction resolveUserAvatar(\n userAvatar: AliaUserAvatar | undefined,\n defaultLabel: string,\n) {\n if (!userAvatar) {\n return { slot: <UserIdentityTile size=\"sm\" label={defaultLabel} /> };\n }\n if (userAvatar.slot) return { slot: userAvatar.slot };\n // Pass the fields straight through; ChatMessage scrubs `src` with\n // `safeImageSrc` and falls back to initials from `name`.\n return { name: userAvatar.name, src: userAvatar.src };\n}\n\n/* ------------------------------------------------------------------ */\n/* Empty state — branded welcome shown when messages is empty */\n/* ------------------------------------------------------------------ */\n\ninterface EmptyStateProps {\n assistantName: string;\n avatarSrc?: string;\n greeting: string;\n subtitle: string;\n suggestions?: AliaSuggestion[];\n onSuggestion?: (suggestion: AliaSuggestion) => void;\n}\n\nfunction EmptyState({\n assistantName,\n avatarSrc,\n greeting,\n subtitle,\n suggestions,\n onSuggestion,\n}: EmptyStateProps) {\n const { t } = useTranslation();\n const headingId = 'alia-empty-state-heading';\n\n return (\n <section\n aria-labelledby={headingId}\n className={[\n 'ds:flex ds:flex-1 ds:min-h-0 ds:flex-col ds:items-center ds:justify-center',\n 'ds:text-center',\n 'ds:ps-[var(--spacing-lg)] ds:pe-[var(--spacing-lg)]',\n 'ds:pt-[var(--spacing-xl)] ds:pb-[var(--spacing-xl)]',\n 'ds:gap-[var(--spacing-md)]',\n ].join(' ')}\n data-testid=\"alia-empty-state\"\n >\n {avatarSrc ? (\n <Avatar name={assistantName} src={avatarSrc} size=\"xl\" />\n ) : (\n <AliaIdentityTile\n size=\"xl\"\n label={assistantName}\n appearance=\"spinner\"\n />\n )}\n <div className=\"ds:flex ds:flex-col ds:items-center ds:gap-[var(--spacing-xs)] ds:max-w-[32rem]\">\n <h2\n id={headingId}\n className=\"type-title-section ds:m-0 ds:text-[color:var(--foreground)]\"\n >\n {greeting}\n </h2>\n <p className=\"type-body-sm ds:m-0 ds:text-[color:var(--muted-foreground)]\">\n {subtitle}\n </p>\n </div>\n {suggestions && suggestions.length > 0 ? (\n <div className=\"ds:w-full ds:max-w-[40rem]\">\n <SuggestionChipGroup\n label={t('alia.exampleQuestions')}\n className=\"ds:justify-center\"\n >\n {suggestions.map((s) => (\n <SuggestionChip\n key={s.id}\n intent=\"suggestion\"\n startIcon={s.icon}\n keepOnSelect\n onSelect={() => onSuggestion?.(s)}\n >\n {s.label}\n </SuggestionChip>\n ))}\n </SuggestionChipGroup>\n </div>\n ) : null}\n </section>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* Streaming message — renders the last assistant message's body via */\n/* StreamingText when `streaming: true`. */\n/* ------------------------------------------------------------------ */\n\ninterface StreamingMessageProps {\n message: AliaMessage;\n assistantName: string;\n avatarSrc?: string;\n renderMarkdown?: boolean;\n}\n\nfunction StreamingMessage({\n message,\n assistantName,\n avatarSrc,\n renderMarkdown,\n}: StreamingMessageProps) {\n const { t, i18n } = useTranslation();\n const roleLabel = t('chat.message.role.assistant');\n const formattedTime = useMemo(() => {\n if (!message.timestamp) return null;\n const date =\n message.timestamp instanceof Date\n ? message.timestamp\n : new Date(message.timestamp);\n if (Number.isNaN(date.getTime())) return null;\n return new Intl.DateTimeFormat(i18n.language, {\n hour: '2-digit',\n minute: '2-digit',\n }).format(date);\n }, [message.timestamp, i18n.language]);\n\n const label = formattedTime\n ? t('chat.message.label', { role: roleLabel, time: formattedTime })\n : t('chat.message.labelNoTime', { role: roleLabel });\n\n return (\n <article\n aria-label={label}\n className=\"ds:flex ds:w-full ds:items-start ds:flex-row ds:gap-[var(--spacing-sm)]\"\n >\n {avatarSrc ? (\n <Avatar name={assistantName} src={avatarSrc} size=\"sm\" />\n ) : (\n <AliaIdentityTile\n size=\"sm\"\n label={assistantName}\n appearance=\"spinner\"\n loading={true}\n />\n )}\n <div className=\"ds:flex ds:flex-col ds:items-start\">\n <div\n dir=\"auto\"\n className={[\n 'ds:relative ds:max-w-[min(42rem,90%)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n 'type-body',\n 'ds:break-words',\n 'ds:bg-muted/40 ds:text-foreground',\n 'ds:rounded-[var(--radius-md)] ds:rounded-es-[var(--radius-sm)]',\n ].join(' ')}\n >\n <StreamingText\n content={message.content}\n isStreaming={true}\n renderMarkdown={renderMarkdown}\n />\n </div>\n </div>\n </article>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* Header bar — avatar + name + optional new-conversation + end slot */\n/* ------------------------------------------------------------------ */\n\ninterface HeaderBarProps {\n assistantName: string;\n avatarSrc?: string;\n onNewConversation?: () => void;\n headerEndSlot?: ReactNode;\n density: 'default' | 'compact';\n}\n\nfunction HeaderBar({\n assistantName,\n avatarSrc,\n onNewConversation,\n headerEndSlot,\n density,\n}: HeaderBarProps) {\n const { t } = useTranslation();\n return (\n <header\n aria-label={t('alia.headerLabel')}\n className={[\n 'ds:flex ds:shrink-0 ds:items-center ds:gap-[var(--spacing-sm)]',\n // Soft drop-shadow on the block-end edge in place of a `border-b`\n // against `--border` — same rationale as the Alia sidebar's inline\n // edge (see alia-sidebar.tsx).\n 'ds:shadow-[var(--shadow-chrome-down)]',\n 'ds:bg-[var(--background)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n density === 'compact'\n ? 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]'\n : 'ds:pt-[var(--spacing-md)] ds:pb-[var(--spacing-md)]',\n ].join(' ')}\n data-testid=\"alia-header\"\n >\n {avatarSrc ? (\n <Avatar\n name={assistantName}\n src={avatarSrc}\n size={density === 'compact' ? 'sm' : 'md'}\n />\n ) : (\n <AliaIdentityTile\n size={density === 'compact' ? 'sm' : 'md'}\n label={assistantName}\n appearance=\"spinner\"\n />\n )}\n <span className=\"type-title-item ds:text-[color:var(--foreground)]\">\n {assistantName}\n </span>\n <div className=\"ds:ms-auto ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n {onNewConversation ? (\n <Button\n intent=\"ghost\"\n size=\"sm\"\n startIcon={<Plus aria-hidden=\"true\" />}\n onClick={onNewConversation}\n >\n {t('alia.newConversation')}\n </Button>\n ) : null}\n {headerEndSlot}\n </div>\n </header>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* Message + composer affordance helpers + sub-components */\n/* All pure client actions — no consumer state required. */\n/* ------------------------------------------------------------------ */\n\nfunction clipboardWriteText(text: string): Promise<boolean> {\n if (\n typeof navigator === 'undefined' ||\n typeof navigator.clipboard?.writeText !== 'function'\n ) {\n return Promise.resolve(false);\n }\n return navigator.clipboard\n .writeText(text)\n .then(() => true)\n .catch(() => false);\n}\n\nfunction downloadTextFile(text: string, filename: string): void {\n if (\n typeof window === 'undefined' ||\n typeof URL === 'undefined' ||\n typeof URL.createObjectURL !== 'function'\n ) {\n return;\n }\n const blob = new Blob([text], { type: 'text/markdown;charset=utf-8' });\n const url = URL.createObjectURL(blob);\n const anchor = document.createElement('a');\n anchor.href = url;\n anchor.download = filename;\n document.body.appendChild(anchor);\n anchor.click();\n anchor.remove();\n URL.revokeObjectURL(url);\n}\n\nfunction promptFilename(assistantName: string): string {\n const stamp = new Date().toISOString().slice(0, 10); // YYYY-MM-DD\n const slug =\n assistantName\n .toLowerCase()\n .replace(/[^a-z0-9]+/g, '-')\n .replace(/^-+|-+$/g, '') || 'assistant';\n return `${slug}-prompt-${stamp}.md`;\n}\n\nconst clipboardAvailable = (): boolean =>\n typeof navigator !== 'undefined' &&\n typeof navigator.clipboard?.writeText === 'function';\n\n/* Assistant-message action row — Copy / Download / Regenerate. */\nfunction MessageActions({\n message,\n actions,\n assistantName,\n canRegenerate,\n onCopyMessage,\n onDownloadMessage,\n onRegenerate,\n}: {\n message: AliaMessage;\n actions: Array<'copy' | 'download'>;\n assistantName: string;\n canRegenerate: boolean;\n onCopyMessage?: (id: string) => void;\n onDownloadMessage?: (id: string) => void;\n onRegenerate?: (id: string) => void;\n}) {\n const { t } = useTranslation();\n const [copied, setCopied] = useState(false);\n\n const handleCopy = useCallback(() => {\n clipboardWriteText(message.content).then((ok) => {\n if (!ok) return;\n setCopied(true);\n setTimeout(() => setCopied(false), 2000);\n onCopyMessage?.(message.id);\n });\n }, [message.content, message.id, onCopyMessage]);\n\n const handleDownload = useCallback(() => {\n downloadTextFile(message.content, promptFilename(assistantName));\n onDownloadMessage?.(message.id);\n }, [message.content, message.id, assistantName, onDownloadMessage]);\n\n return (\n <>\n {actions.includes('copy') && clipboardAvailable() ? (\n <IconButton\n icon={copied ? <Check /> : <Copy />}\n aria-label={copied ? t('alia.copied') : t('alia.copyMessage')}\n intent=\"ghost\"\n size=\"sm\"\n onClick={handleCopy}\n />\n ) : null}\n {actions.includes('download') ? (\n <IconButton\n icon={<Download />}\n aria-label={t('alia.downloadMessage')}\n intent=\"ghost\"\n size=\"sm\"\n onClick={handleDownload}\n />\n ) : null}\n {canRegenerate && onRegenerate ? (\n <IconButton\n icon={<RefreshCw />}\n aria-label={t('alia.regenerate')}\n intent=\"ghost\"\n size=\"sm\"\n onClick={() => onRegenerate(message.id)}\n />\n ) : null}\n <span role=\"status\" aria-live=\"polite\" className=\"ds:sr-only\">\n {copied ? t('alia.copied') : ''}\n </span>\n </>\n );\n}\n\n/* Attachment chip row above the composer. Presentational — consumer owns list. */\nfunction AttachmentChips({\n attachments,\n onRemove,\n}: {\n attachments: AliaAttachment[];\n onRemove?: (id: string) => void;\n}) {\n const { t } = useTranslation();\n if (attachments.length === 0) return null;\n return (\n <ul\n aria-label={t('alia.attachmentsLabel')}\n className=\"ds:m-0 ds:flex ds:list-none ds:flex-wrap ds:gap-[var(--spacing-xs)] ds:p-0\"\n >\n {attachments.map((att) => (\n <li\n key={att.id}\n className={[\n 'ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'ds:rounded-[var(--radius-full)] ds:bg-[var(--muted)]',\n 'ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-xs)]',\n 'ds:pt-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]',\n ].join(' ')}\n >\n <Paperclip\n aria-hidden=\"true\"\n className=\"ds:size-3.5 ds:text-[color:var(--muted-foreground)]\"\n />\n <span dir=\"auto\" className=\"type-meta ds:max-w-[12rem] ds:truncate\">\n {att.name}\n </span>\n {onRemove ? (\n <IconButton\n icon={<X />}\n aria-label={t('alia.removeAttachment', { name: att.name })}\n intent=\"ghost\"\n size=\"sm\"\n onClick={() => onRemove(att.id)}\n />\n ) : null}\n </li>\n ))}\n </ul>\n );\n}\n\n/* SpeechRecognition — the minimal surface we touch (lib types aren't in TS DOM). */\ninterface MinimalSpeechRecognition {\n lang: string;\n continuous: boolean;\n interimResults: boolean;\n start: () => void;\n stop: () => void;\n onresult:\n | ((event: {\n results: ArrayLike<ArrayLike<{ transcript: string }>>;\n }) => void)\n | null;\n onend: (() => void) | null;\n onerror: (() => void) | null;\n}\ninterface SpeechRecognitionWindow {\n SpeechRecognition?: new () => MinimalSpeechRecognition;\n webkitSpeechRecognition?: new () => MinimalSpeechRecognition;\n}\nfunction getSpeechRecognitionCtor():\n | (new () => MinimalSpeechRecognition)\n | undefined {\n if (typeof window === 'undefined') return undefined;\n const w = window as unknown as SpeechRecognitionWindow;\n return w.SpeechRecognition ?? w.webkitSpeechRecognition;\n}\n\n/* Composer mic toggle (Web Speech API). Only mounted when feature-supported. */\nfunction VoiceMic({\n lang,\n disabled,\n onTranscript,\n}: {\n lang: string;\n disabled?: boolean;\n onTranscript: (text: string) => void;\n}) {\n const { t } = useTranslation();\n const [listening, setListening] = useState(false);\n const recognitionRef = useRef<MinimalSpeechRecognition | null>(null);\n\n const stop = useCallback(() => {\n recognitionRef.current?.stop();\n setListening(false);\n }, []);\n\n const start = useCallback(() => {\n const Ctor = getSpeechRecognitionCtor();\n if (!Ctor) return;\n const rec = new Ctor();\n rec.lang = lang;\n rec.continuous = false;\n rec.interimResults = false;\n rec.onresult = (event) => {\n let text = '';\n for (let i = 0; i < event.results.length; i++) {\n text += event.results[i][0].transcript;\n }\n if (text) onTranscript(text);\n };\n rec.onend = () => setListening(false);\n rec.onerror = () => setListening(false);\n recognitionRef.current = rec;\n rec.start();\n setListening(true);\n }, [lang, onTranscript]);\n\n // Esc stops dictation; also stop on unmount.\n useEffect(() => {\n if (!listening) return;\n const onKey = (e: KeyboardEvent) => {\n if (e.key === 'Escape') stop();\n };\n window.addEventListener('keydown', onKey);\n return () => window.removeEventListener('keydown', onKey);\n }, [listening, stop]);\n useEffect(() => () => recognitionRef.current?.stop(), []);\n\n return (\n <IconButton\n icon={<Mic />}\n aria-label={listening ? t('alia.dictateStop') : t('alia.dictate')}\n aria-pressed={listening}\n intent={listening ? 'primary' : 'ghost'}\n size=\"sm\"\n disabled={disabled}\n onClick={() => (listening ? stop() : start())}\n className={\n listening\n ? 'ds:motion-safe:animate-pulse ds:motion-reduce:animate-none ds:[.theme-accessible_&]:animate-none'\n : undefined\n }\n />\n );\n}\n\n/* Inline editor for editing & resending a user message. */\nfunction MessageEditor({\n initialText,\n onSave,\n onCancel,\n}: {\n initialText: string;\n onSave: (text: string) => void;\n onCancel: () => void;\n}) {\n const { t } = useTranslation();\n const [text, setText] = useState(initialText);\n return (\n <div\n className=\"ds:flex ds:w-full ds:flex-col ds:gap-[var(--spacing-xs)]\"\n data-testid=\"alia-message-editor\"\n >\n <ChatInput\n label={t('alia.editMessage')}\n value={text}\n onChange={(e) => setText(e.target.value)}\n submitOnEnter\n onSubmit={(v) => onSave(v)}\n minRows={2}\n />\n <div className=\"ds:flex ds:items-center ds:justify-end ds:gap-[var(--spacing-xs)]\">\n <Button intent=\"ghost\" size=\"sm\" onClick={onCancel}>\n {t('alia.cancelEdit')}\n </Button>\n <Button\n intent=\"primary\"\n size=\"sm\"\n onClick={() => onSave(text)}\n disabled={text.trim().length === 0}\n >\n {t('alia.saveEdit')}\n </Button>\n </div>\n </div>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* Main export — AliaChatSurface */\n/* ------------------------------------------------------------------ */\n\nexport const AliaChatSurface = forwardRef<HTMLDivElement, AliaChatSurfaceProps>(\n (\n {\n messages,\n onSend,\n onRetry,\n onSuggestion,\n suggestions,\n isGenerating = false,\n onStopGenerating,\n usage,\n onUpgrade,\n assistantName,\n assistantAvatar,\n userAvatar,\n greeting,\n subtitle,\n density = 'default',\n renderMarkdown = true,\n onNewConversation,\n onAttach,\n acceptedFileTypes,\n headerEndSlot,\n ended,\n messageActions,\n onCopyMessage,\n onDownloadMessage,\n voiceInput,\n onVoiceTranscript,\n attachments,\n onRemoveAttachment,\n showScrollToLatest,\n onRegenerate,\n onEditMessage,\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n\n // Transient client-only UI state. The presentational contract allows local\n // draft / editing state (it holds no conversation or attachment state).\n const [editingId, setEditingId] = useState<string | null>(null);\n const [composerText, setComposerText] = useState('');\n\n // Voice dictation is feature-detected: the mic mounts only when the Web\n // Speech API is present AND the consumer opted in via `voiceInput`.\n const voiceSupported = !!voiceInput && getSpeechRecognitionCtor() != null;\n\n // Regenerate targets the most recent COMPLETE assistant message.\n const lastAssistantId = useMemo(() => {\n for (let i = messages.length - 1; i >= 0; i--) {\n const m = messages[i];\n if (m.role === 'assistant' && !m.streaming) return m.id;\n }\n return undefined;\n }, [messages]);\n\n // CONVERSATION-ENDED / UI-LOCKED. When the consuming app supplies\n // `ended`, forward interaction is frozen: the composer disables and the\n // suggestion chips + stop-generating button stop rendering. History\n // stays visible and read-only.\n const isEnded = ended != null;\n\n const resolvedName = assistantName ?? t('alia.name');\n const resolvedGreeting = greeting ?? t('alia.greeting');\n const resolvedSubtitle = subtitle ?? t('alia.subtitle');\n\n const lastMessage = messages[messages.length - 1];\n const lastIsStreamingAssistant =\n lastMessage?.role === 'assistant' && lastMessage.streaming === true;\n const listMessages = lastIsStreamingAssistant\n ? messages.slice(0, -1)\n : messages;\n\n // ChatContainer messages — each visible non-streaming message becomes\n // a ChatMessage; the streaming tail + typing indicator are appended.\n const containerMessages = useMemo(() => {\n const userLabel = t('chat.message.role.user');\n const base = listMessages.map((m) => {\n let avatar;\n if (m.role === 'assistant') {\n // Consumer-provided image wins; otherwise render the spinner tile.\n avatar = assistantAvatar?.src\n ? { name: resolvedName, src: assistantAvatar.src }\n : {\n slot: (\n <AliaIdentityTile\n size=\"sm\"\n label={resolvedName}\n appearance=\"spinner\"\n />\n ),\n };\n } else if (m.role === 'user') {\n avatar = resolveUserAvatar(userAvatar, userLabel);\n }\n\n // Editing a user message → swap in the inline editor.\n if (m.role === 'user' && onEditMessage && editingId === m.id) {\n return {\n id: m.id,\n node: (\n <MessageEditor\n initialText={m.content}\n onSave={(text) => {\n onEditMessage(m.id, text);\n setEditingId(null);\n }}\n onCancel={() => setEditingId(null)}\n />\n ),\n };\n }\n\n // Per-message action row (assistant: Copy / Download / Regenerate;\n // user: Edit). Opt-in — undefined when no affordance applies.\n let actions: ReactNode;\n if (\n m.role === 'assistant' &&\n ((messageActions && messageActions.length > 0) ||\n (onRegenerate && m.id === lastAssistantId))\n ) {\n actions = (\n <MessageActions\n message={m}\n actions={messageActions ?? []}\n assistantName={resolvedName}\n canRegenerate={!!onRegenerate && m.id === lastAssistantId}\n onCopyMessage={onCopyMessage}\n onDownloadMessage={onDownloadMessage}\n onRegenerate={onRegenerate}\n />\n );\n } else if (m.role === 'user' && onEditMessage) {\n actions = (\n <IconButton\n icon={<Pencil />}\n aria-label={t('alia.editMessage')}\n intent=\"ghost\"\n size=\"sm\"\n onClick={() => setEditingId(m.id)}\n />\n );\n }\n\n return {\n id: m.id,\n node: (\n <ChatMessage\n role={m.role}\n content={m.content}\n avatar={avatar}\n timestamp={m.timestamp}\n status={m.status}\n renderMarkdown={renderMarkdown}\n onRetry={onRetry ? () => onRetry(m.id) : undefined}\n actions={actions}\n />\n ),\n };\n });\n\n if (lastIsStreamingAssistant && lastMessage) {\n base.push({\n id: lastMessage.id,\n node: (\n <StreamingMessage\n message={lastMessage}\n assistantName={resolvedName}\n avatarSrc={assistantAvatar?.src}\n renderMarkdown={renderMarkdown}\n />\n ),\n });\n }\n\n if (isGenerating && !lastIsStreamingAssistant) {\n base.push({\n id: '__alia-typing__',\n node: (\n <div className=\"ds:flex ds:w-full ds:items-start ds:gap-[var(--spacing-sm)]\">\n {assistantAvatar?.src ? (\n <Avatar\n name={resolvedName}\n src={assistantAvatar.src}\n size=\"sm\"\n />\n ) : (\n <AliaIdentityTile\n size=\"sm\"\n label={resolvedName}\n appearance=\"spinner\"\n />\n )}\n <div\n className={[\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n 'ds:rounded-[var(--radius-md)] ds:rounded-es-[var(--radius-sm)]',\n 'ds:bg-muted/40',\n ].join(' ')}\n >\n <TypingIndicator label={t('chat.typing')} density={density} />\n </div>\n </div>\n ),\n });\n }\n\n // Locked end-of-conversation divider — always the last row so it reads\n // as the terminal state below the full history.\n if (ended) {\n base.push({\n id: '__alia-ended__',\n node: <EndedDivider note={ended.note} />,\n });\n }\n\n return base;\n }, [\n listMessages,\n lastIsStreamingAssistant,\n lastMessage,\n isGenerating,\n resolvedName,\n assistantAvatar?.src,\n userAvatar,\n renderMarkdown,\n onRetry,\n density,\n ended,\n t,\n editingId,\n onEditMessage,\n messageActions,\n onRegenerate,\n lastAssistantId,\n onCopyMessage,\n onDownloadMessage,\n ]);\n\n // Usage progress data.\n const usagePercent = usage\n ? Math.min(\n 100,\n Math.max(0, (usage.current / Math.max(1, usage.limit)) * 100),\n )\n : 0;\n const usageFull = usage ? usage.current >= usage.limit : false;\n const usageLabel = usage\n ? (usage.label ??\n t('alia.usageLabel', {\n current: usage.current,\n limit: usage.limit,\n }))\n : null;\n\n // When ended, never fall into the empty state — the locked divider must\n // render in the message list even if the history is otherwise empty.\n const isEmpty = messages.length === 0 && !isGenerating && !isEnded;\n\n // Composer — disabled when usage is full.\n const composer = (\n <div className=\"ds:flex ds:flex-col ds:gap-[var(--spacing-sm)]\">\n {usage ? (\n <div className=\"ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]\">\n <div className=\"ds:flex ds:items-center ds:justify-between ds:gap-[var(--spacing-sm)]\">\n <span\n className={[\n 'type-meta',\n usageFull\n ? 'ds:text-[color:var(--destructive)]'\n : 'ds:text-[color:var(--muted-foreground)]',\n ].join(' ')}\n data-testid=\"alia-usage-label\"\n >\n {usageFull ? t('alia.usageLimitReached') : usageLabel}\n </span>\n {usageFull && onUpgrade ? (\n <Button intent=\"primary\" size=\"sm\" onClick={onUpgrade}>\n {t('alia.upgrade')}\n </Button>\n ) : null}\n </div>\n <Progress\n value={usagePercent}\n max={100}\n size=\"sm\"\n ariaLabel={\n usageLabel ??\n t('alia.usageLabel', {\n current: usage.current,\n limit: usage.limit,\n })\n }\n className={\n usageFull\n ? 'ds:[&_[role=progressbar]>*]:bg-[color:var(--destructive)]'\n : undefined\n }\n data-testid=\"alia-usage-progress\"\n />\n </div>\n ) : null}\n {!isEmpty &&\n suggestions &&\n suggestions.length > 0 &&\n !isGenerating &&\n !isEnded ? (\n <SuggestionChipGroup\n label={t('alia.exampleQuestions')}\n data-testid=\"alia-followup-suggestions\"\n >\n {suggestions.map((s) => (\n <SuggestionChip\n key={s.id}\n intent=\"followup\"\n startIcon={s.icon}\n keepOnSelect\n onSelect={() => onSuggestion?.(s)}\n >\n {s.label}\n </SuggestionChip>\n ))}\n </SuggestionChipGroup>\n ) : null}\n {attachments && attachments.length > 0 ? (\n <AttachmentChips\n attachments={attachments}\n onRemove={onRemoveAttachment}\n />\n ) : null}\n <div className=\"ds:flex ds:items-end ds:gap-[var(--spacing-sm)]\">\n <div className=\"ds:flex-1 ds:min-w-0\">\n <ChatInput\n submitOnEnter\n onSubmit={\n voiceSupported\n ? (text) => {\n onSend(text);\n setComposerText('');\n }\n : onSend\n }\n value={voiceSupported ? composerText : undefined}\n onChange={\n voiceSupported\n ? (e) => setComposerText(e.target.value)\n : undefined\n }\n onAttach={onAttach}\n accept={acceptedFileTypes}\n disabled={usageFull || isEnded}\n toolbar={\n voiceSupported ? (\n <VoiceMic\n lang={i18n.language}\n disabled={usageFull || isEnded}\n onTranscript={(text) => {\n onVoiceTranscript?.(text);\n setComposerText((prev) =>\n prev ? `${prev} ${text}` : text,\n );\n }}\n />\n ) : undefined\n }\n data-testid=\"alia-composer\"\n />\n </div>\n {isGenerating && onStopGenerating && !isEnded ? (\n <Button\n intent=\"outline\"\n size=\"sm\"\n startIcon={<Square aria-hidden=\"true\" />}\n onClick={onStopGenerating}\n aria-label={t('alia.stopGenerating')}\n >\n {t('alia.stopGenerating')}\n </Button>\n ) : null}\n </div>\n </div>\n );\n\n return (\n <div\n ref={ref}\n className={[\n 'ds:flex ds:min-h-0 ds:flex-1 ds:flex-col',\n 'ds:bg-[var(--background)] ds:text-[color:var(--foreground)]',\n ].join(' ')}\n data-testid=\"alia-surface\"\n >\n <HeaderBar\n assistantName={resolvedName}\n avatarSrc={assistantAvatar?.src}\n onNewConversation={onNewConversation}\n headerEndSlot={headerEndSlot}\n density={density}\n />\n {isEmpty ? (\n <>\n <EmptyState\n assistantName={resolvedName}\n avatarSrc={assistantAvatar?.src}\n greeting={resolvedGreeting}\n subtitle={resolvedSubtitle}\n suggestions={suggestions}\n onSuggestion={onSuggestion}\n />\n <div\n className={[\n // No top divider — the ChatInput's own soft shadow + the\n // border-radius give it enough visual containment, and a\n // surface-level separator here read as a sharp line at\n // 1px-equivalent shadow blur. Keep the bg explicit so\n // the chat-input chrome paints over the messages-area\n // background instead of mixing with it.\n 'ds:shrink-0 ds:bg-[var(--background)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n ].join(' ')}\n >\n {composer}\n </div>\n </>\n ) : (\n <ChatContainer\n messages={containerMessages}\n density={density}\n composer={composer}\n showScrollToLatest={showScrollToLatest}\n className=\"ds:flex-1 ds:min-h-0\"\n />\n )}\n </div>\n );\n },\n);\n\nAliaChatSurface.displayName = 'AliaChatSurface';\n","/**\n * Alia Assistant — embedded (full-page) mode. Fills the parent container\n * (typically `<AppFrame padded={false}>`'s `<main>` slot) with a\n * ChatGPT-style centred conversation column.\n */\nimport { forwardRef, type ReactNode } from 'react';\nimport { AliaChatSurface } from './alia-chat-surface';\nimport type { AliaChatSurfaceProps } from './alia-types';\n\nexport interface AliaEmbeddedProps extends AliaChatSurfaceProps {\n /** Optional slot rendered above the chat surface (e.g. a breadcrumb). */\n headerSlot?: ReactNode;\n}\n\nexport const AliaEmbedded = forwardRef<HTMLDivElement, AliaEmbeddedProps>(\n ({ headerSlot, ...surfaceProps }, ref) => {\n return (\n <div\n ref={ref}\n className={[\n 'ds:flex ds:min-h-0 ds:flex-1 ds:flex-col',\n 'ds:bg-[var(--background)] ds:text-[color:var(--foreground)]',\n 'ds:h-full ds:w-full',\n ].join(' ')}\n data-testid=\"alia-embedded\"\n >\n {headerSlot ? (\n <div\n className={[\n 'ds:shrink-0',\n 'ds:ps-[var(--spacing-lg)] ds:pe-[var(--spacing-lg)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n ].join(' ')}\n >\n {headerSlot}\n </div>\n ) : null}\n <div className=\"ds:flex ds:min-h-0 ds:flex-1 ds:flex-col ds:items-stretch\">\n <div\n className={[\n 'ds:flex ds:min-h-0 ds:w-full ds:flex-1 ds:flex-col',\n 'ds:ms-auto ds:me-auto',\n 'ds:[max-inline-size:48rem]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n ].join(' ')}\n >\n <AliaChatSurface {...surfaceProps} />\n </div>\n </div>\n </div>\n );\n },\n);\n\nAliaEmbedded.displayName = 'AliaEmbedded';\n","/**\n * Alia Assistant — popout (FAB + Sheet) mode. A floating trigger button\n * anchored to the bottom-inline-end corner opens a slide-in `Sheet`\n * panel containing the same `AliaChatSurface` in compact density.\n *\n * Z-index: the FAB sits on `--z-fixed`; the Sheet sits on `--z-modal`.\n * Both render above the app chrome but below any open Dialog.\n */\nimport { forwardRef } from 'react';\nimport * as RadixDialog from '@radix-ui/react-dialog';\nimport { useTranslation } from 'react-i18next';\nimport { Sparkles, X } from 'lucide-react';\nimport { FloatingActionButton } from '../../components/floating-action-button';\nimport { IconButton } from '../../components/button';\nimport { Sheet } from '../../components/sheet';\nimport { AliaChatSurface } from './alia-chat-surface';\nimport type { AliaChatSurfaceProps } from './alia-types';\n\nexport interface AliaPopoutProps extends AliaChatSurfaceProps {\n /** Whether the popout panel is open. */\n open: boolean;\n /** Fires when the panel should open or close. */\n onOpenChange: (open: boolean) => void;\n /** Position of the FAB trigger. */\n position?: 'bottom-end' | 'bottom-start';\n /** Optional unseen message count badge on the FAB. */\n unseenCount?: number;\n}\n\nfunction formatBadgeCount(count: number): string {\n return count > 99 ? '99+' : String(count);\n}\n\nexport const AliaPopout = forwardRef<HTMLDivElement, AliaPopoutProps>(\n (\n {\n open,\n onOpenChange,\n position = 'bottom-end',\n unseenCount,\n assistantName,\n assistantAvatar,\n ...surfaceProps\n },\n ref,\n ) => {\n const { t } = useTranslation();\n // `|| t(…)` (not `??`) — also defaults when the host passes an empty\n // string so Radix Dialog's required `Sheet.Title` is never empty.\n const resolvedName = assistantName || t('alia.name');\n const showBadge = typeof unseenCount === 'number' && unseenCount > 0;\n\n const triggerLabel = showBadge\n ? t('alia.unseenCount', { count: unseenCount })\n : t('alia.open');\n\n // Close button injected into the chat surface header via the\n // headerEndSlot hook — keeps the Sheet's title wiring and DialogClose\n // semantics without duplicating the header shell.\n const headerEndSlot = (\n <RadixDialog.Close asChild>\n <IconButton\n icon={<X aria-hidden=\"true\" />}\n intent=\"ghost\"\n size=\"sm\"\n aria-label={t('alia.close')}\n data-testid=\"alia-popout-close\"\n />\n </RadixDialog.Close>\n );\n\n return (\n <Sheet.Root open={open} onOpenChange={onOpenChange}>\n {/* FAB trigger — sits outside the Sheet.Trigger so the unseen-\n count badge can overlay it. A Sheet.Trigger wrapper would\n turn the FAB into a button-inside-a-button. Instead, we\n invoke `onOpenChange(true)` on click. */}\n <div\n ref={ref}\n className={[\n 'ds:fixed ds:z-[var(--z-fixed)]',\n 'ds:bottom-[calc(var(--spacing-lg)+env(safe-area-inset-bottom,0px))]',\n position === 'bottom-end'\n ? 'ds:end-[var(--spacing-lg)]'\n : 'ds:start-[var(--spacing-lg)]',\n ].join(' ')}\n data-testid=\"alia-popout-fab-wrapper\"\n >\n <div className=\"ds:relative\">\n <FloatingActionButton\n icon={<Sparkles aria-hidden=\"true\" />}\n aria-label={triggerLabel}\n variant=\"primary\"\n size=\"md\"\n position=\"static\"\n onClick={() => onOpenChange(true)}\n data-testid=\"alia-popout-fab\"\n />\n {showBadge ? (\n <span\n aria-hidden=\"true\"\n data-testid=\"alia-popout-badge\"\n className={[\n 'ds:absolute ds:-top-[var(--spacing-xs)] ds:-end-[var(--spacing-xs)]',\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:min-w-[calc(var(--spacing-md)+var(--spacing-xs))]',\n 'ds:h-[calc(var(--spacing-md)+var(--spacing-xs))]',\n 'ds:ps-[calc(var(--spacing-xs)/1.5)] ds:pe-[calc(var(--spacing-xs)/1.5)]',\n 'ds:rounded-[var(--radius-full)]',\n 'ds:bg-[color:var(--destructive)] ds:text-[color:var(--destructive-foreground)]',\n 'ds:text-[length:var(--font-size-xs)] ds:font-semibold ds:leading-none',\n 'ds:pointer-events-none ds:select-none',\n 'ds:forced-colors:outline ds:forced-colors:outline-1 ds:forced-colors:outline-[CanvasText]',\n ].join(' ')}\n >\n {formatBadgeCount(unseenCount)}\n </span>\n ) : null}\n </div>\n </div>\n\n <Sheet.Content\n side=\"end\"\n size=\"md\"\n aria-label={t('alia.panelLabel')}\n className=\"ds:flex ds:min-h-0 ds:flex-col ds:p-0\"\n data-testid=\"alia-popout-panel\"\n >\n {/* Sheet.Title is required by Radix Dialog for a11y. We hide it\n visually because AliaChatSurface renders its own header. */}\n <Sheet.Title className=\"ds:sr-only\">{resolvedName}</Sheet.Title>\n <AliaChatSurface\n {...surfaceProps}\n assistantName={resolvedName}\n assistantAvatar={assistantAvatar}\n density=\"compact\"\n headerEndSlot={headerEndSlot}\n />\n </Sheet.Content>\n </Sheet.Root>\n );\n },\n);\n\nAliaPopout.displayName = 'AliaPopout';\n","/**\n * Alia Assistant — sidebar (docked panel) mode.\n *\n * A persistent, non-modal panel that docks to the `inline-end` edge of\n * the layout. Unlike `AliaPopout` it does NOT trap focus or overlay\n * content — users can chat with Alia while continuing to interact with\n * the main surface. Collapses to an icon rail when `open={false}`.\n *\n * This is the intended **default desktop mode** for Alia once MCP tool\n * access and settings land: users will want Alia visible while they\n * configure servers, inspect tool runs, and reference data. On mobile\n * viewports the consuming app should flip to `AliaPopout` because a\n * 22rem sidebar would consume the entire screen.\n *\n * Unlike the popout (Radix Dialog) and embedded (full-page main) modes,\n * the sidebar is a plain `<aside>` landmark — it lives in the normal\n * layout flow and consumes inline space.\n */\nimport { forwardRef, type ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { ChevronsLeft, ChevronsRight, Sparkles } from 'lucide-react';\nimport { IconButton } from '../../components/button';\nimport { AliaChatSurface } from './alia-chat-surface';\nimport type { AliaChatSurfaceProps } from './alia-types';\n\nexport interface AliaSidebarProps extends AliaChatSurfaceProps {\n /** Whether the sidebar is expanded. When false, a narrow icon rail\n * stays visible and clicking it fires `onOpenChange(true)`. */\n open: boolean;\n /** Fires when the user expands or collapses the sidebar. */\n onOpenChange: (open: boolean) => void;\n /** Which edge of the container the sidebar docks to. Defaults to\n * `'end'` (inline-end). RTL flips automatically via logical\n * properties. */\n side?: 'end' | 'start';\n /** Optional unseen-message count shown on the collapsed rail. */\n unseenCount?: number;\n /** Optional slot rendered under the chat surface (e.g. an MCP server\n * list or settings accordion). Future hook for the MCP panel. */\n footerSlot?: ReactNode;\n}\n\nfunction formatBadgeCount(count: number): string {\n return count > 99 ? '99+' : String(count);\n}\n\n// Fixed tokenised widths — keeps the pattern constraint-compliant (no\n// prop-driven inline styles). Consuming apps that need a different size\n// can wrap the sidebar in their own container and override via CSS.\nconst EXPANDED_WIDTH = 'ds:[inline-size:22rem]';\nconst RAIL_WIDTH = 'ds:[inline-size:3rem]';\n\nexport const AliaSidebar = forwardRef<HTMLElement, AliaSidebarProps>(\n (\n {\n open,\n onOpenChange,\n side = 'end',\n unseenCount,\n footerSlot,\n assistantName,\n assistantAvatar,\n ...surfaceProps\n },\n ref,\n ) => {\n const { t } = useTranslation();\n // `|| t(…)` — also defaults when the host passes an empty string,\n // so the collapsed-rail `aria-label` is never empty.\n const resolvedName = assistantName || t('alia.name');\n const showBadge = typeof unseenCount === 'number' && unseenCount > 0;\n\n // Soft drop-shadow on the inline-edge that faces the main content\n // area. Replaces a flat `border-s`/`border-e` against `--border`,\n // which since the WCAG 1.4.11 bump (grey-600 → grey-800) reads as a\n // heavy charcoal line at this scale. A directional shadow keeps the\n // panel-edge cue without needing to clear contrast thresholds the\n // way an actual border would. Tokenised via `--shadow-chrome-start`\n // / `--shadow-chrome-end` (see `src/tokens/index.css`).\n const borderClass =\n side === 'end'\n ? 'ds:shadow-[var(--shadow-chrome-start)]'\n : 'ds:shadow-[var(--shadow-chrome-end)]';\n\n const triggerLabel = showBadge\n ? t('alia.unseenCount', { count: unseenCount })\n : t('alia.open');\n\n // Collapsed rail — a tall vertical strip with the Alia icon plus an\n // unseen badge. Clicking it expands the sidebar.\n if (!open) {\n return (\n <aside\n ref={ref}\n aria-label={t('alia.panelLabel')}\n className={[\n 'ds:flex ds:shrink-0 ds:flex-col ds:items-center',\n 'ds:bg-[var(--background)]',\n borderClass,\n 'ds:pt-[var(--spacing-md)] ds:pb-[var(--spacing-md)]',\n RAIL_WIDTH,\n ].join(' ')}\n data-testid=\"alia-sidebar-rail\"\n data-alia-sidebar-state=\"collapsed\"\n >\n <div className=\"ds:relative ds:[&_svg]:text-[color:var(--accent)]\">\n <IconButton\n icon={<Sparkles aria-hidden=\"true\" />}\n aria-label={triggerLabel}\n aria-expanded=\"false\"\n intent=\"ghost\"\n size=\"sm\"\n onClick={() => onOpenChange(true)}\n data-testid=\"alia-sidebar-rail-trigger\"\n />\n {showBadge ? (\n <span\n aria-hidden=\"true\"\n data-testid=\"alia-sidebar-badge\"\n className={[\n 'ds:absolute ds:-top-[var(--spacing-xs)] ds:-end-[var(--spacing-xs)]',\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:min-w-[calc(var(--spacing-md)+var(--spacing-xs))]',\n 'ds:h-[calc(var(--spacing-md)+var(--spacing-xs))]',\n 'ds:ps-[calc(var(--spacing-xs)/1.5)] ds:pe-[calc(var(--spacing-xs)/1.5)]',\n 'ds:rounded-[var(--radius-full)]',\n 'ds:bg-[color:var(--destructive)] ds:text-[color:var(--destructive-foreground)]',\n 'ds:text-[length:var(--font-size-xs)] ds:font-semibold ds:leading-none',\n 'ds:pointer-events-none ds:select-none',\n 'ds:forced-colors:outline ds:forced-colors:outline-1 ds:forced-colors:outline-[CanvasText]',\n ].join(' ')}\n >\n {formatBadgeCount(unseenCount)}\n </span>\n ) : null}\n </div>\n </aside>\n );\n }\n\n // Expanded panel — same AliaChatSurface as embedded / popout, in\n // compact density, with a collapse-toggle injected into the header.\n // Chevron points toward the docked edge so users read it as\n // \"collapse toward that side\".\n const headerEndSlot = (\n <IconButton\n icon={side === 'end' ? <ChevronsRight /> : <ChevronsLeft />}\n intent=\"ghost\"\n size=\"sm\"\n aria-label={t('alia.close')}\n aria-expanded=\"true\"\n onClick={() => onOpenChange(false)}\n data-testid=\"alia-sidebar-collapse\"\n />\n );\n\n return (\n <aside\n ref={ref}\n aria-label={t('alia.panelLabel')}\n className={[\n 'ds:flex ds:shrink-0 ds:flex-col ds:min-h-0',\n 'ds:bg-[var(--background)]',\n borderClass,\n EXPANDED_WIDTH,\n 'ds:h-full',\n ].join(' ')}\n data-testid=\"alia-sidebar\"\n data-alia-sidebar-state=\"expanded\"\n >\n <div className=\"ds:flex ds:min-h-0 ds:flex-1 ds:flex-col\">\n <AliaChatSurface\n {...surfaceProps}\n assistantName={resolvedName}\n assistantAvatar={assistantAvatar}\n density=\"compact\"\n headerEndSlot={headerEndSlot}\n />\n </div>\n {footerSlot ? (\n <div\n data-testid=\"alia-sidebar-footer-slot\"\n className=\"ds:shrink-0 ds:shadow-[var(--shadow-chrome-up)]\"\n >\n {footerSlot}\n </div>\n ) : null}\n </aside>\n );\n },\n);\n\nAliaSidebar.displayName = 'AliaSidebar';\n"],"names":["__iconNode","ShieldX","createLucideIcon","LEO_TILE_SIZES","AliaIdentityTile","size","label","appearance","loading","dims","jsx","Spinner","Sparkles","UserIdentityTile","User","EndedDivider","note","jsxs","resolveUserAvatar","userAvatar","defaultLabel","EmptyState","assistantName","avatarSrc","greeting","subtitle","suggestions","onSuggestion","t","useTranslation","headingId","Avatar","SuggestionChipGroup","s","SuggestionChip","StreamingMessage","message","renderMarkdown","i18n","roleLabel","formattedTime","useMemo","date","StreamingText","HeaderBar","onNewConversation","headerEndSlot","density","Button","Plus","clipboardWriteText","text","_a","downloadTextFile","filename","blob","url","anchor","promptFilename","stamp","clipboardAvailable","MessageActions","actions","canRegenerate","onCopyMessage","onDownloadMessage","onRegenerate","copied","setCopied","useState","handleCopy","useCallback","ok","handleDownload","Fragment","IconButton","Check","Copy","Download","RefreshCw","AttachmentChips","attachments","onRemove","att","Paperclip","X","getSpeechRecognitionCtor","w","VoiceMic","lang","disabled","onTranscript","listening","setListening","recognitionRef","useRef","stop","start","Ctor","rec","event","i","useEffect","onKey","e","Mic","MessageEditor","initialText","onSave","onCancel","setText","ChatInput","v","AliaChatSurface","forwardRef","messages","onSend","onRetry","isGenerating","onStopGenerating","usage","onUpgrade","assistantAvatar","onAttach","acceptedFileTypes","ended","messageActions","voiceInput","onVoiceTranscript","onRemoveAttachment","showScrollToLatest","onEditMessage","ref","editingId","setEditingId","composerText","setComposerText","voiceSupported","lastAssistantId","m","isEnded","resolvedName","resolvedGreeting","resolvedSubtitle","lastMessage","lastIsStreamingAssistant","listMessages","containerMessages","userLabel","base","avatar","Pencil","ChatMessage","TypingIndicator","usagePercent","usageFull","usageLabel","isEmpty","composer","Progress","prev","Square","ChatContainer","AliaEmbedded","headerSlot","surfaceProps","formatBadgeCount","count","AliaPopout","open","onOpenChange","position","unseenCount","showBadge","triggerLabel","RadixDialog","Sheet","FloatingActionButton","EXPANDED_WIDTH","RAIL_WIDTH","AliaSidebar","side","footerSlot","borderClass","ChevronsRight","ChevronsLeft"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -1,44 +1,34 @@
|
|
|
1
1
|
import { jsxs as R, jsx as s, Fragment as se } from "react/jsx-runtime";
|
|
2
|
-
import { forwardRef as
|
|
2
|
+
import { forwardRef as ae, useReducer as ne, useState as x, useRef as l, useEffect as D, useCallback as h, useMemo as de, useImperativeHandle as ce } from "react";
|
|
3
3
|
import { c as oe } from "./index-D2ZczOXr.js";
|
|
4
4
|
import { useTranslation as ue } from "react-i18next";
|
|
5
|
-
import { B as
|
|
6
|
-
import { I as
|
|
5
|
+
import { B as G } from "./button-DD_0Xdmr.js";
|
|
6
|
+
import { I as N } from "./icon-button-CKEOrN37.js";
|
|
7
7
|
import { S as pe } from "./select-hsCaJSX3.js";
|
|
8
8
|
import { A as le } from "./audio-visualiser-l6zPd0AG.js";
|
|
9
9
|
import { A as F } from "./alert-ywPR59NE.js";
|
|
10
10
|
import { u as me } from "./registry-nPAVE19X.js";
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
11
|
+
import { M as fe } from "./mic-B4Gog3Gi.js";
|
|
12
|
+
import { c as J } from "./createLucideIcon-CrFbzy84.js";
|
|
13
|
+
import { S as ge } from "./square-CZoGU14v.js";
|
|
14
|
+
import { X as he } from "./x-CCcI3eJp.js";
|
|
14
15
|
/**
|
|
15
16
|
* @license lucide-react v1.8.0 - ISC
|
|
16
17
|
*
|
|
17
18
|
* This source code is licensed under the ISC license.
|
|
18
19
|
* See the LICENSE file in the root directory of this source tree.
|
|
19
20
|
*/
|
|
20
|
-
const
|
|
21
|
-
["path", { d: "M12 19v3", key: "npa21l" }],
|
|
22
|
-
["path", { d: "M19 10v2a7 7 0 0 1-14 0v-2", key: "1vc78b" }],
|
|
23
|
-
["rect", { x: "9", y: "2", width: "6", height: "13", rx: "3", key: "s6n7sd" }]
|
|
24
|
-
], ve = V("mic", he);
|
|
25
|
-
/**
|
|
26
|
-
* @license lucide-react v1.8.0 - ISC
|
|
27
|
-
*
|
|
28
|
-
* This source code is licensed under the ISC license.
|
|
29
|
-
* See the LICENSE file in the root directory of this source tree.
|
|
30
|
-
*/
|
|
31
|
-
const ye = [
|
|
21
|
+
const ve = [
|
|
32
22
|
["rect", { x: "14", y: "3", width: "5", height: "18", rx: "1", key: "kaeet6" }],
|
|
33
23
|
["rect", { x: "5", y: "3", width: "5", height: "18", rx: "1", key: "1wsw3u" }]
|
|
34
|
-
],
|
|
24
|
+
], ye = J("pause", ve);
|
|
35
25
|
/**
|
|
36
26
|
* @license lucide-react v1.8.0 - ISC
|
|
37
27
|
*
|
|
38
28
|
* This source code is licensed under the ISC license.
|
|
39
29
|
* See the LICENSE file in the root directory of this source tree.
|
|
40
30
|
*/
|
|
41
|
-
const
|
|
31
|
+
const ke = [
|
|
42
32
|
[
|
|
43
33
|
"path",
|
|
44
34
|
{
|
|
@@ -46,7 +36,7 @@ const be = [
|
|
|
46
36
|
key: "10ikf1"
|
|
47
37
|
}
|
|
48
38
|
]
|
|
49
|
-
],
|
|
39
|
+
], be = J("play", ke), Re = {
|
|
50
40
|
id: "audio-recorder",
|
|
51
41
|
capabilities: ["submit"],
|
|
52
42
|
state: {
|
|
@@ -114,7 +104,7 @@ const be = [
|
|
|
114
104
|
}
|
|
115
105
|
}
|
|
116
106
|
};
|
|
117
|
-
function
|
|
107
|
+
function we(r, u) {
|
|
118
108
|
switch (u.type) {
|
|
119
109
|
case "request":
|
|
120
110
|
return { kind: "requesting" };
|
|
@@ -162,15 +152,15 @@ const Ae = oe(
|
|
|
162
152
|
},
|
|
163
153
|
defaultVariants: { size: "md" }
|
|
164
154
|
}
|
|
165
|
-
),
|
|
155
|
+
), Me = [
|
|
166
156
|
"audio/webm;codecs=opus",
|
|
167
157
|
"audio/webm",
|
|
168
158
|
"audio/mp4",
|
|
169
159
|
"audio/ogg;codecs=opus"
|
|
170
160
|
];
|
|
171
|
-
function
|
|
161
|
+
function xe() {
|
|
172
162
|
if (!(typeof MediaRecorder > "u")) {
|
|
173
|
-
for (const r of
|
|
163
|
+
for (const r of Me)
|
|
174
164
|
if (MediaRecorder.isTypeSupported(r)) return r;
|
|
175
165
|
}
|
|
176
166
|
}
|
|
@@ -178,7 +168,7 @@ function De(r, u) {
|
|
|
178
168
|
const m = Math.max(0, Math.floor(r / 1e3)), i = Math.floor(m / 60), f = m % 60, v = (S) => new Intl.NumberFormat(u, { minimumIntegerDigits: 2 }).format(S);
|
|
179
169
|
return `${v(i)}:${v(f)}`;
|
|
180
170
|
}
|
|
181
|
-
const
|
|
171
|
+
const Ne = ae(
|
|
182
172
|
({
|
|
183
173
|
size: r = "md",
|
|
184
174
|
onRecordingComplete: u,
|
|
@@ -189,23 +179,23 @@ const Se = ne(
|
|
|
189
179
|
className: S,
|
|
190
180
|
...I
|
|
191
181
|
}, Q) => {
|
|
192
|
-
const { t: d, i18n: W } = ue(), [t, p] =
|
|
193
|
-
|
|
182
|
+
const { t: d, i18n: W } = ue(), [t, p] = ne(we, { kind: "idle" }), [z, T] = x(null), [Y, Z] = x(Date.now()), [E, ee] = x([]), [w, te] = x(""), c = l(null), y = l([]), _ = l(0), V = l(0), g = l(null), B = l(!1), k = l(!1), H = l(0), b = typeof MediaRecorder < "u";
|
|
183
|
+
D(() => {
|
|
194
184
|
var e;
|
|
195
|
-
!b || !((e = navigator.mediaDevices) != null && e.enumerateDevices) || navigator.mediaDevices.enumerateDevices().then((
|
|
196
|
-
const o =
|
|
185
|
+
!b || !((e = navigator.mediaDevices) != null && e.enumerateDevices) || navigator.mediaDevices.enumerateDevices().then((a) => {
|
|
186
|
+
const o = a.filter((n) => n.kind === "audioinput");
|
|
197
187
|
ee(o);
|
|
198
188
|
}).catch(() => {
|
|
199
189
|
});
|
|
200
|
-
}, [b]),
|
|
190
|
+
}, [b]), D(() => {
|
|
201
191
|
if (t.kind !== "recording") return;
|
|
202
192
|
const e = window.setInterval(() => Z(Date.now()), 250);
|
|
203
193
|
return () => window.clearInterval(e);
|
|
204
194
|
}, [t.kind]);
|
|
205
|
-
const
|
|
195
|
+
const $ = h(() => {
|
|
206
196
|
const e = g.current ?? z;
|
|
207
|
-
e == null || e.getTracks().forEach((
|
|
208
|
-
}, [z]),
|
|
197
|
+
e == null || e.getTracks().forEach((a) => a.stop()), g.current = null, T(null);
|
|
198
|
+
}, [z]), A = h(async () => {
|
|
209
199
|
if (!b) {
|
|
210
200
|
p({ type: "error", kind: "unsupported" }), i == null || i("unsupported");
|
|
211
201
|
return;
|
|
@@ -216,17 +206,17 @@ const Se = ne(
|
|
|
216
206
|
audio: w ? { deviceId: { exact: w } } : !0
|
|
217
207
|
});
|
|
218
208
|
if (B.current || k.current) {
|
|
219
|
-
e.getTracks().forEach((
|
|
209
|
+
e.getTracks().forEach((n) => n.stop());
|
|
220
210
|
return;
|
|
221
211
|
}
|
|
222
212
|
g.current = e, T(e);
|
|
223
|
-
const
|
|
213
|
+
const a = xe(), o = new MediaRecorder(
|
|
224
214
|
e,
|
|
225
|
-
|
|
215
|
+
a ? { mimeType: a } : void 0
|
|
226
216
|
);
|
|
227
|
-
c.current = o, y.current = [], _.current = 0, o.ondataavailable = (
|
|
228
|
-
var
|
|
229
|
-
if (
|
|
217
|
+
c.current = o, y.current = [], _.current = 0, o.ondataavailable = (n) => {
|
|
218
|
+
var X;
|
|
219
|
+
if (n.data && n.data.size > 0 && (y.current.push(n.data), _.current += n.data.size, typeof v == "number" && _.current >= v && ((X = c.current) == null ? void 0 : X.state) === "recording")) {
|
|
230
220
|
i == null || i("max-size");
|
|
231
221
|
try {
|
|
232
222
|
c.current.stop();
|
|
@@ -235,16 +225,16 @@ const Se = ne(
|
|
|
235
225
|
}
|
|
236
226
|
}, o.onstop = () => {
|
|
237
227
|
if (!k.current) {
|
|
238
|
-
const
|
|
239
|
-
type:
|
|
228
|
+
const n = new Blob(y.current, {
|
|
229
|
+
type: a ?? "audio/webm"
|
|
240
230
|
});
|
|
241
|
-
u == null || u(
|
|
231
|
+
u == null || u(n, V.current);
|
|
242
232
|
}
|
|
243
|
-
y.current = [], c.current = null, e.getTracks().forEach((
|
|
233
|
+
y.current = [], c.current = null, e.getTracks().forEach((n) => n.stop()), g.current = null, T(null), k.current = !1;
|
|
244
234
|
}, H.current = performance.now(), o.start(1e3), p({ type: "start" });
|
|
245
235
|
} catch (e) {
|
|
246
|
-
const
|
|
247
|
-
|
|
236
|
+
const a = e instanceof Error ? e.name : "";
|
|
237
|
+
a === "NotAllowedError" || a === "SecurityError" ? (p({ type: "error", kind: "permission-denied" }), i == null || i("permission-denied")) : a === "NotFoundError" || a === "OverconstrainedError" ? (p({ type: "error", kind: "no-device" }), i == null || i("no-device")) : (p({ type: "error", kind: "capture-failed" }), i == null || i("capture-failed"));
|
|
248
238
|
}
|
|
249
239
|
}, [i, u, w, b]), re = h(() => {
|
|
250
240
|
var e;
|
|
@@ -255,8 +245,8 @@ const Se = ne(
|
|
|
255
245
|
}, []), q = h(() => {
|
|
256
246
|
var e;
|
|
257
247
|
if (t.kind === "recording" || t.kind === "paused") {
|
|
258
|
-
const
|
|
259
|
-
|
|
248
|
+
const a = t.startedAt, o = t.pausedMs, n = Date.now() - a - o;
|
|
249
|
+
V.current = Math.max(0, n), p({ type: "stop", duration: n });
|
|
260
250
|
}
|
|
261
251
|
try {
|
|
262
252
|
(e = c.current) == null || e.stop();
|
|
@@ -269,46 +259,46 @@ const Se = ne(
|
|
|
269
259
|
(e = c.current) == null || e.stop();
|
|
270
260
|
} catch {
|
|
271
261
|
}
|
|
272
|
-
y.current = [], c.current = null,
|
|
273
|
-
}, [
|
|
274
|
-
|
|
262
|
+
y.current = [], c.current = null, $(), p({ type: "cancel" }), m == null || m();
|
|
263
|
+
}, [$, m]);
|
|
264
|
+
D(() => {
|
|
275
265
|
if (t.kind !== "recording" || typeof f != "number" || f <= 0) return;
|
|
276
|
-
const e = performance.now() - H.current - t.pausedMs,
|
|
277
|
-
var
|
|
278
|
-
if (((
|
|
266
|
+
const e = performance.now() - H.current - t.pausedMs, a = Math.max(0, f - e), o = window.setTimeout(() => {
|
|
267
|
+
var n;
|
|
268
|
+
if (((n = c.current) == null ? void 0 : n.state) === "recording") {
|
|
279
269
|
i == null || i("max-duration");
|
|
280
270
|
try {
|
|
281
271
|
c.current.stop();
|
|
282
272
|
} catch {
|
|
283
273
|
}
|
|
284
274
|
}
|
|
285
|
-
},
|
|
275
|
+
}, a);
|
|
286
276
|
return () => window.clearTimeout(o);
|
|
287
|
-
}, [t, f, i]),
|
|
288
|
-
var e,
|
|
277
|
+
}, [t, f, i]), D(() => () => {
|
|
278
|
+
var e, a;
|
|
289
279
|
B.current = !0;
|
|
290
280
|
try {
|
|
291
281
|
(e = c.current) == null || e.stop();
|
|
292
282
|
} catch {
|
|
293
283
|
}
|
|
294
|
-
(
|
|
284
|
+
(a = g.current) == null || a.getTracks().forEach((o) => o.stop()), g.current = null;
|
|
295
285
|
}, []);
|
|
296
286
|
const j = t.kind === "recording" ? Y - t.startedAt - t.pausedMs : t.kind === "paused" ? t.pausedAt - t.startedAt - t.pausedMs : t.kind === "stopped" ? t.duration : 0, P = de(
|
|
297
287
|
() => ({
|
|
298
288
|
isRecording: () => t.kind === "recording",
|
|
299
289
|
getDuration: () => j,
|
|
300
290
|
hasRecording: () => t.kind === "stopped",
|
|
301
|
-
startRecording: () =>
|
|
291
|
+
startRecording: () => A(),
|
|
302
292
|
stopRecording: () => q(),
|
|
303
293
|
discard: () => K()
|
|
304
294
|
}),
|
|
305
|
-
[t, j,
|
|
295
|
+
[t, j, A, q, K]
|
|
306
296
|
);
|
|
307
|
-
ce(Q, () => P, [P]), me(
|
|
308
|
-
const
|
|
297
|
+
ce(Q, () => P, [P]), me(Re, P, I.id);
|
|
298
|
+
const C = E.map((e) => ({
|
|
309
299
|
value: e.deviceId,
|
|
310
300
|
label: e.label || d("chat.audio.selectDevice")
|
|
311
|
-
})),
|
|
301
|
+
})), O = (() => {
|
|
312
302
|
switch (t.kind) {
|
|
313
303
|
case "idle":
|
|
314
304
|
return d("chat.audio.idle");
|
|
@@ -323,7 +313,7 @@ const Se = ne(
|
|
|
323
313
|
case "error":
|
|
324
314
|
return t.type === "permission-denied" ? d("chat.audio.permissionDenied") : t.type === "unsupported" ? d("chat.audio.unsupported") : d("chat.audio.idle");
|
|
325
315
|
}
|
|
326
|
-
})(),
|
|
316
|
+
})(), M = t.kind === "recording", L = t.kind === "paused", U = t.kind === "error";
|
|
327
317
|
return /* @__PURE__ */ R(
|
|
328
318
|
"div",
|
|
329
319
|
{
|
|
@@ -339,9 +329,9 @@ const Se = ne(
|
|
|
339
329
|
"aria-hidden": "true",
|
|
340
330
|
className: [
|
|
341
331
|
"ds:relative ds:inline-flex ds:size-3 ds:items-center ds:justify-center ds:rounded-[var(--radius-full)]",
|
|
342
|
-
|
|
332
|
+
M ? "ds:bg-[color:var(--destructive)]" : "ds:bg-[color:var(--muted)]"
|
|
343
333
|
].join(" "),
|
|
344
|
-
children:
|
|
334
|
+
children: M ? /* @__PURE__ */ s(
|
|
345
335
|
"span",
|
|
346
336
|
{
|
|
347
337
|
className: [
|
|
@@ -373,44 +363,44 @@ const Se = ne(
|
|
|
373
363
|
}
|
|
374
364
|
)
|
|
375
365
|
] }),
|
|
376
|
-
/* @__PURE__ */ s("span", { role: "status", "aria-live": "polite", className: "ds:sr-only", children:
|
|
366
|
+
/* @__PURE__ */ s("span", { role: "status", "aria-live": "polite", className: "ds:sr-only", children: O }),
|
|
377
367
|
/* @__PURE__ */ R("div", { className: "ds:flex ds:items-center ds:gap-[var(--spacing-xs)]", children: [
|
|
378
|
-
t.kind === "idle" || t.kind === "stopped" ||
|
|
379
|
-
|
|
368
|
+
t.kind === "idle" || t.kind === "stopped" || U ? /* @__PURE__ */ s(
|
|
369
|
+
G,
|
|
380
370
|
{
|
|
381
371
|
intent: "primary",
|
|
382
372
|
size: "sm",
|
|
383
|
-
startIcon: /* @__PURE__ */ s(
|
|
384
|
-
onClick:
|
|
373
|
+
startIcon: /* @__PURE__ */ s(fe, {}),
|
|
374
|
+
onClick: A,
|
|
385
375
|
disabled: !b,
|
|
386
376
|
children: d("chat.audio.record")
|
|
387
377
|
}
|
|
388
378
|
) : null,
|
|
389
|
-
|
|
390
|
-
|
|
379
|
+
M ? /* @__PURE__ */ s(
|
|
380
|
+
N,
|
|
391
381
|
{
|
|
392
|
-
icon: /* @__PURE__ */ s(
|
|
382
|
+
icon: /* @__PURE__ */ s(ye, {}),
|
|
393
383
|
"aria-label": d("chat.audio.pause"),
|
|
394
384
|
intent: "secondary",
|
|
395
385
|
size: "sm",
|
|
396
386
|
onClick: re
|
|
397
387
|
}
|
|
398
388
|
) : null,
|
|
399
|
-
|
|
400
|
-
|
|
389
|
+
L ? /* @__PURE__ */ s(
|
|
390
|
+
N,
|
|
401
391
|
{
|
|
402
|
-
icon: /* @__PURE__ */ s(
|
|
392
|
+
icon: /* @__PURE__ */ s(be, {}),
|
|
403
393
|
"aria-label": d("chat.audio.resume"),
|
|
404
394
|
intent: "secondary",
|
|
405
395
|
size: "sm",
|
|
406
396
|
onClick: ie
|
|
407
397
|
}
|
|
408
398
|
) : null,
|
|
409
|
-
|
|
399
|
+
M || L ? /* @__PURE__ */ R(se, { children: [
|
|
410
400
|
/* @__PURE__ */ s(
|
|
411
|
-
|
|
401
|
+
N,
|
|
412
402
|
{
|
|
413
|
-
icon: /* @__PURE__ */ s(
|
|
403
|
+
icon: /* @__PURE__ */ s(ge, {}),
|
|
414
404
|
"aria-label": d("chat.audio.stop"),
|
|
415
405
|
intent: "primary",
|
|
416
406
|
size: "sm",
|
|
@@ -418,9 +408,9 @@ const Se = ne(
|
|
|
418
408
|
}
|
|
419
409
|
),
|
|
420
410
|
/* @__PURE__ */ s(
|
|
421
|
-
|
|
411
|
+
N,
|
|
422
412
|
{
|
|
423
|
-
icon: /* @__PURE__ */ s(
|
|
413
|
+
icon: /* @__PURE__ */ s(he, {}),
|
|
424
414
|
"aria-label": d("chat.audio.cancel"),
|
|
425
415
|
intent: "ghost",
|
|
426
416
|
size: "sm",
|
|
@@ -428,11 +418,11 @@ const Se = ne(
|
|
|
428
418
|
}
|
|
429
419
|
)
|
|
430
420
|
] }) : null,
|
|
431
|
-
t.kind === "idle" &&
|
|
421
|
+
t.kind === "idle" && C.length > 1 ? /* @__PURE__ */ s("div", { className: "ds:ms-auto ds:min-w-[160px]", children: /* @__PURE__ */ s(
|
|
432
422
|
pe,
|
|
433
423
|
{
|
|
434
424
|
"aria-label": d("chat.audio.selectDevice"),
|
|
435
|
-
options:
|
|
425
|
+
options: C,
|
|
436
426
|
value: w,
|
|
437
427
|
onValueChange: (e) => te(e),
|
|
438
428
|
size: "sm",
|
|
@@ -440,18 +430,18 @@ const Se = ne(
|
|
|
440
430
|
}
|
|
441
431
|
) }) : null
|
|
442
432
|
] }),
|
|
443
|
-
|
|
444
|
-
/* @__PURE__ */ s(F.Description, { children:
|
|
445
|
-
t.type === "permission-denied" ? /* @__PURE__ */ s(F.Action, { children: /* @__PURE__ */ s(
|
|
433
|
+
U && t.kind === "error" ? /* @__PURE__ */ R(F, { variant: "error", live: "polite", children: [
|
|
434
|
+
/* @__PURE__ */ s(F.Description, { children: O }),
|
|
435
|
+
t.type === "permission-denied" ? /* @__PURE__ */ s(F.Action, { children: /* @__PURE__ */ s(G, { intent: "ghost", size: "sm", onClick: A, children: d("chat.audio.retry") }) }) : null
|
|
446
436
|
] }) : null
|
|
447
437
|
]
|
|
448
438
|
}
|
|
449
439
|
);
|
|
450
440
|
}
|
|
451
441
|
);
|
|
452
|
-
|
|
442
|
+
Ne.displayName = "AudioRecorder";
|
|
453
443
|
export {
|
|
454
|
-
|
|
455
|
-
|
|
444
|
+
Ne as A,
|
|
445
|
+
Re as a
|
|
456
446
|
};
|
|
457
|
-
//# sourceMappingURL=audio-recorder-
|
|
447
|
+
//# sourceMappingURL=audio-recorder-DC-v9YFW.js.map
|