@copilotz/admin 0.3.6 → 0.3.7
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/index.cjs +1515 -291
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +63 -20
- package/dist/index.d.ts +63 -20
- package/dist/index.js +1532 -293
- package/dist/index.js.map +1 -1
- package/dist/styles.css +1405 -84
- package/package.json +5 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/CopilotzAdmin.tsx","../src/config.ts","../src/useCopilotzAdmin.ts","../src/adminService.ts","../src/lib/utils.ts","../src/components/ui/card.tsx","../src/components/ui/button.tsx","../src/components/ui/input.tsx","../src/components/ui/badge.tsx","../src/components/ui/select.tsx"],"sourcesContent":["import React, {\n useDeferredValue,\n useMemo,\n useState,\n} from \"react\";\nimport { defaultAdminConfig, mergeAdminConfig } from \"./config\";\nimport { useCopilotzAdmin } from \"./useCopilotzAdmin\";\nimport { cn } from \"./lib/utils\";\nimport { Card, CardContent } from \"./components/ui/card\";\nimport { Button } from \"./components/ui/button\";\nimport { Input } from \"./components/ui/input\";\nimport { Badge } from \"./components/ui/badge\";\nimport {\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from \"./components/ui/select\";\nimport type {\n AdminActivityPoint,\n AdminAgentSummary,\n AdminConfig,\n AdminParticipantSummary,\n ResolvedAdminConfig,\n AdminThreadSummary,\n} from \"./types\";\n\nexport interface CopilotzAdminProps {\n config?: Partial<AdminConfig>;\n className?: string;\n}\n\nexport const CopilotzAdmin: React.FC<CopilotzAdminProps> = ({\n config: userConfig,\n className,\n}) => {\n const config = useMemo(\n () => mergeAdminConfig(defaultAdminConfig, userConfig),\n [userConfig],\n );\n const [threadSearch, setThreadSearch] = useState(\"\");\n const [participantSearch, setParticipantSearch] = useState(\"\");\n const [agentSearch, setAgentSearch] = useState(\"\");\n const deferredThreadSearch = useDeferredValue(threadSearch);\n const deferredParticipantSearch = useDeferredValue(participantSearch);\n const deferredAgentSearch = useDeferredValue(agentSearch);\n\n const admin = useCopilotzAdmin({\n baseUrl: config.baseUrl,\n getRequestHeaders: config.getRequestHeaders,\n namespace: config.namespace,\n range: config.initialRange,\n interval: config.initialInterval,\n threadSearch: deferredThreadSearch,\n participantSearch: deferredParticipantSearch,\n agentSearch: deferredAgentSearch,\n });\n\n const cards = [\n {\n label: config.labels.messagesCard,\n value: admin.overview?.messageTotals.total ?? 0,\n detail: `${admin.overview?.messageTotals.toolCallMessages ?? 0} tool-call messages`,\n },\n {\n label: config.labels.activeThreadsCard,\n value: admin.overview?.threadTotals.active ?? 0,\n detail: `${admin.overview?.threadTotals.total ?? 0} total threads`,\n },\n {\n label: config.labels.participantsCard,\n value: admin.overview?.participantTotals.total ?? 0,\n detail: `${admin.overview?.participantTotals.agents ?? 0} agents`,\n },\n {\n label: config.labels.tokensCard,\n value: admin.overview?.llmTotals.totalTokens ?? 0,\n detail: `${admin.overview?.llmTotals.totalCalls ?? 0} calls`,\n },\n {\n label: config.labels.queueCard,\n value: admin.overview?.queueTotals.pending ?? 0,\n detail: `${admin.overview?.queueTotals.failed ?? 0} failed`,\n },\n ];\n\n if (admin.isLoading && !admin.overview) {\n return (\n <Card className={cn(\"border-border\", className)}>\n <CardContent className=\"text-muted-foreground\">\n {config.labels.loading}\n </CardContent>\n </Card>\n );\n }\n\n if (admin.error && !admin.overview) {\n return (\n <Card className={cn(\"border-destructive/50 bg-destructive/10\", className)}>\n <CardContent className=\"space-y-4\">\n <p className=\"text-base font-semibold text-destructive\">\n {admin.error.message}\n </p>\n <Button\n variant=\"destructive\"\n onClick={() => void admin.refresh()}\n >\n {config.labels.retry}\n </Button>\n </CardContent>\n </Card>\n );\n }\n\n const isEmpty =\n cards.every((card) => card.value === 0) &&\n admin.activity.length === 0 &&\n admin.threads.length === 0 &&\n admin.participants.length === 0 &&\n admin.agents.length === 0;\n\n return (\n <Card className={cn(\"gap-0 overflow-hidden py-0\", className)}>\n <CardContent className=\"space-y-6 p-6\">\n {/* Header */}\n <header className=\"flex flex-col gap-4 lg:flex-row lg:items-center lg:justify-between\">\n <div className=\"space-y-1\">\n <div className=\"flex items-center gap-3\">\n {config.branding.logo ? (\n <div className=\"flex h-10 w-10 items-center justify-center rounded-xl border bg-background shadow-sm\">\n {config.branding.logo}\n </div>\n ) : null}\n <div>\n <h2 className=\"text-2xl font-semibold tracking-tight\">\n {config.branding.title}\n </h2>\n <p className=\"text-sm text-muted-foreground\">\n {config.branding.subtitle}\n </p>\n </div>\n </div>\n {config.namespace ? (\n <p className=\"text-xs font-medium uppercase tracking-[0.18em] text-muted-foreground\">\n Namespace: {config.namespace}\n </p>\n ) : null}\n </div>\n\n <div className=\"flex flex-wrap items-center gap-2\">\n <Button\n variant={admin.filters.range === \"24h\" ? \"default\" : \"outline\"}\n size=\"sm\"\n onClick={() => admin.setRange(\"24h\")}\n >\n {config.labels.range24h}\n </Button>\n <Button\n variant={admin.filters.range === \"7d\" ? \"default\" : \"outline\"}\n size=\"sm\"\n onClick={() => admin.setRange(\"7d\")}\n >\n {config.labels.range7d}\n </Button>\n <Button\n variant={admin.filters.range === \"30d\" ? \"default\" : \"outline\"}\n size=\"sm\"\n onClick={() => admin.setRange(\"30d\")}\n >\n {config.labels.range30d}\n </Button>\n\n <Select\n value={admin.filters.interval}\n onValueChange={(v) =>\n admin.setInterval(v as \"hour\" | \"day\")\n }\n >\n <SelectTrigger className=\"h-8 w-[110px]\">\n <SelectValue />\n </SelectTrigger>\n <SelectContent>\n <SelectItem value=\"hour\">\n {config.labels.intervalHour}\n </SelectItem>\n <SelectItem value=\"day\">\n {config.labels.intervalDay}\n </SelectItem>\n </SelectContent>\n </Select>\n\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={() => void admin.refresh()}\n >\n {config.labels.refresh}\n </Button>\n {config.branding.actions}\n </div>\n </header>\n\n {isEmpty ? (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <h3 className=\"text-lg font-semibold\">\n {config.labels.emptyTitle}\n </h3>\n <p className=\"mt-2 text-sm text-muted-foreground\">\n {config.labels.emptyDescription}\n </p>\n </div>\n ) : null}\n\n {/* Overview */}\n {config.features.showOverview ? (\n <section className=\"space-y-4\">\n <SectionHeading title={config.labels.overviewTitle} />\n <div className=\"grid grid-cols-2 gap-4 md:grid-cols-3 lg:grid-cols-5\">\n {cards.map((card) => (\n <div\n className=\"rounded-xl border bg-background p-5 shadow-sm\"\n key={card.label}\n >\n <p className=\"text-sm font-medium text-muted-foreground\">\n {card.label}\n </p>\n <p className=\"mt-3 text-3xl font-semibold tracking-tight\">\n {formatNumber(card.value)}\n </p>\n <p className=\"mt-2 text-xs text-muted-foreground\">\n {card.detail}\n </p>\n </div>\n ))}\n </div>\n </section>\n ) : null}\n\n {/* Activity */}\n {config.features.showActivity ? (\n <section className=\"space-y-4\">\n <SectionHeading title={config.labels.activityTitle} />\n <ActivityChart\n interval={admin.filters.interval}\n labels={config.labels}\n maxBars={config.ui.maxActivityBars}\n points={admin.activity}\n />\n </section>\n ) : null}\n\n {/* Data Tables */}\n <div className=\"grid gap-6 lg:grid-cols-3\">\n {config.features.showThreads ? (\n <DataTable\n rows={admin.threads}\n searchPlaceholder={config.labels.threadSearchPlaceholder}\n searchValue={threadSearch}\n setSearchValue={setThreadSearch}\n title={config.labels.threadsTitle}\n >\n <ThreadsTable rows={admin.threads} labels={config.labels} />\n </DataTable>\n ) : null}\n {config.features.showParticipants ? (\n <DataTable\n rows={admin.participants}\n searchPlaceholder={config.labels.participantSearchPlaceholder}\n searchValue={participantSearch}\n setSearchValue={setParticipantSearch}\n title={config.labels.participantsTitle}\n >\n <ParticipantsTable\n rows={admin.participants}\n labels={config.labels}\n />\n </DataTable>\n ) : null}\n {config.features.showAgents ? (\n <DataTable\n rows={admin.agents}\n searchPlaceholder={config.labels.agentSearchPlaceholder}\n searchValue={agentSearch}\n setSearchValue={setAgentSearch}\n title={config.labels.agentsTitle}\n >\n <AgentsTable rows={admin.agents} labels={config.labels} />\n </DataTable>\n ) : null}\n </div>\n </CardContent>\n </Card>\n );\n};\n\nfunction SectionHeading({ title }: { title: string }) {\n return <h3 className=\"text-lg font-semibold tracking-tight\">{title}</h3>;\n}\n\nfunction ActivityChart(props: {\n points: AdminActivityPoint[];\n interval: \"hour\" | \"day\";\n maxBars: number;\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n const trimmedPoints = props.points.slice(-props.maxBars);\n const maxMessages = Math.max(\n ...trimmedPoints.map((point) => point.messageCount),\n 1,\n );\n\n return (\n <div className=\"rounded-xl border bg-background p-5 shadow-sm\">\n {trimmedPoints.length === 0 ? (\n <p className=\"text-sm text-muted-foreground\">\n {props.labels.noResults}\n </p>\n ) : (\n <div className=\"flex min-h-48 items-end gap-2\">\n {trimmedPoints.map((point) => (\n <div\n className=\"flex min-w-0 flex-1 flex-col items-center gap-2\"\n key={point.bucket}\n >\n <div className=\"flex h-36 w-full items-end rounded-lg bg-muted px-1 pb-1\">\n <div\n className=\"w-full rounded-md bg-primary transition-all\"\n style={{\n height: `${Math.max((point.messageCount / maxMessages) * 100, 8)}%`,\n }}\n />\n </div>\n <div className=\"text-center\">\n <p className=\"text-xs font-medium\">\n {formatBucket(point.bucket, props.interval)}\n </p>\n <p className=\"text-[11px] text-muted-foreground\">\n {formatNumber(point.messageCount)} msg\n </p>\n </div>\n </div>\n ))}\n </div>\n )}\n </div>\n );\n}\n\nfunction DataTable<T>(props: {\n title: string;\n searchPlaceholder: string;\n searchValue: string;\n setSearchValue: (value: string) => void;\n rows: T[];\n children: React.ReactNode;\n}) {\n return (\n <div className=\"rounded-xl border bg-background p-5 shadow-sm\">\n <div className=\"mb-4 flex items-center justify-between gap-3\">\n <SectionHeading title={props.title} />\n <Input\n className=\"h-8 w-full max-w-44\"\n onChange={(event) => props.setSearchValue(event.target.value)}\n placeholder={props.searchPlaceholder}\n value={props.searchValue}\n />\n </div>\n {props.rows.length === 0 ? (\n <p className=\"text-sm text-muted-foreground\">No results</p>\n ) : (\n props.children\n )}\n </div>\n );\n}\n\nfunction ThreadsTable({\n rows,\n labels,\n}: {\n rows: AdminThreadSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((thread) => (\n <div\n className=\"rounded-lg border bg-muted/50 p-4\"\n key={thread.threadId}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{thread.name}</p>\n <p className=\"mt-1 truncate text-xs text-muted-foreground\">\n {thread.summary ??\n thread.lastMessagePreview ??\n \"No summary yet\"}\n </p>\n </div>\n <Badge\n variant={\n thread.status === \"archived\" ? \"secondary\" : \"default\"\n }\n >\n {thread.status === \"archived\"\n ? labels.statusArchived\n : labels.statusActive}\n </Badge>\n </div>\n <div className=\"mt-3 flex flex-wrap gap-3 text-xs text-muted-foreground\">\n <span>{formatNumber(thread.messageCount)} messages</span>\n <span>{thread.participantIds.length} participants</span>\n <span>{formatDate(thread.lastActivityAt)}</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction ParticipantsTable({\n rows,\n labels,\n}: {\n rows: AdminParticipantSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((participant) => (\n <div\n className=\"rounded-lg border bg-muted/50 p-4\"\n key={`${participant.namespace}:${participant.externalId}`}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{participant.displayName}</p>\n <p className=\"mt-1 text-xs uppercase tracking-[0.18em] text-muted-foreground\">\n {participant.participantType}\n </p>\n </div>\n <Badge variant=\"outline\">\n {participant.isGlobal\n ? labels.scopeGlobal\n : labels.scopeScoped}\n </Badge>\n </div>\n <div className=\"mt-3 flex flex-wrap gap-3 text-xs text-muted-foreground\">\n <span>\n {formatNumber(participant.messageCount)} messages\n </span>\n <span>\n {formatNumber(participant.threadCount)} threads\n </span>\n <span>{formatDate(participant.lastActivityAt)}</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction AgentsTable({\n rows,\n labels,\n}: {\n rows: AdminAgentSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((agent) => (\n <div\n className=\"rounded-lg border bg-muted/50 p-4\"\n key={`${agent.namespace}:${agent.agentId}`}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{agent.displayName}</p>\n <p className=\"mt-1 truncate text-xs text-muted-foreground\">\n {agent.description ?? agent.agentId}\n </p>\n </div>\n <Badge variant=\"outline\">\n {agent.isConfigured\n ? labels.configured\n : labels.unconfigured}\n </Badge>\n </div>\n <div className=\"mt-3 grid grid-cols-2 gap-2 text-xs text-muted-foreground\">\n <span>{formatNumber(agent.messageCount)} messages</span>\n <span>{formatNumber(agent.llmCallCount)} LLM calls</span>\n <span>\n {formatNumber(agent.toolCallMessageCount)} tool calls\n </span>\n <span>{formatNumber(agent.totalTokens)} tokens</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction formatBucket(bucket: string, interval: \"hour\" | \"day\") {\n const date = new Date(bucket);\n if (Number.isNaN(date.getTime())) return bucket;\n return interval === \"hour\"\n ? date.toLocaleString(undefined, {\n hour: \"numeric\",\n month: \"short\",\n day: \"numeric\",\n })\n : date.toLocaleDateString(undefined, {\n month: \"short\",\n day: \"numeric\",\n });\n}\n\nfunction formatDate(value: string | null) {\n if (!value) return \"No activity\";\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) return value;\n return date.toLocaleString(undefined, {\n month: \"short\",\n day: \"numeric\",\n hour: \"numeric\",\n minute: \"2-digit\",\n });\n}\n\nfunction formatNumber(value: number) {\n return new Intl.NumberFormat().format(value);\n}\n","import type { AdminConfig, ResolvedAdminConfig } from \"./types\";\n\nexport const defaultAdminConfig: ResolvedAdminConfig = {\n branding: {\n title: \"Copilotz Admin\",\n subtitle: \"Read-only operational visibility for Copilotz clients\",\n logo: null,\n actions: null,\n },\n labels: {\n overviewTitle: \"Overview\",\n activityTitle: \"Activity\",\n threadsTitle: \"Threads\",\n participantsTitle: \"Participants\",\n agentsTitle: \"Agents\",\n range24h: \"24h\",\n range7d: \"7d\",\n range30d: \"30d\",\n intervalHour: \"Hourly\",\n intervalDay: \"Daily\",\n refresh: \"Refresh\",\n retry: \"Try again\",\n loading: \"Loading admin data...\",\n emptyTitle: \"No activity yet\",\n emptyDescription: \"Admin metrics will appear after threads, events, and graph data start flowing.\",\n threadSearchPlaceholder: \"Search threads\",\n participantSearchPlaceholder: \"Search participants\",\n agentSearchPlaceholder: \"Search agents\",\n messagesCard: \"Messages\",\n activeThreadsCard: \"Active threads\",\n participantsCard: \"Participants\",\n tokensCard: \"LLM tokens\",\n queueCard: \"Queued events\",\n statusActive: \"Active\",\n statusArchived: \"Archived\",\n scopeGlobal: \"Global\",\n scopeScoped: \"Scoped\",\n configured: \"Configured\",\n unconfigured: \"Observed only\",\n noResults: \"No results\",\n },\n features: {\n showOverview: true,\n showActivity: true,\n showThreads: true,\n showParticipants: true,\n showAgents: true,\n },\n ui: {\n compact: false,\n maxActivityBars: 18,\n },\n baseUrl: \"\",\n getRequestHeaders: async () => ({}),\n namespace: \"\",\n initialRange: \"7d\",\n initialInterval: \"day\",\n};\n\nexport function mergeAdminConfig(\n _baseConfig: AdminConfig,\n userConfig?: Partial<AdminConfig>,\n): ResolvedAdminConfig {\n if (!userConfig) return defaultAdminConfig;\n\n return {\n branding: {\n ...defaultAdminConfig.branding,\n ...userConfig.branding,\n },\n labels: {\n ...defaultAdminConfig.labels,\n ...userConfig.labels,\n },\n features: {\n ...defaultAdminConfig.features,\n ...userConfig.features,\n },\n ui: {\n ...defaultAdminConfig.ui,\n ...userConfig.ui,\n },\n baseUrl: userConfig.baseUrl ?? defaultAdminConfig.baseUrl,\n getRequestHeaders: userConfig.getRequestHeaders ??\n defaultAdminConfig.getRequestHeaders,\n namespace: userConfig.namespace ?? defaultAdminConfig.namespace,\n initialRange: userConfig.initialRange ?? defaultAdminConfig.initialRange,\n initialInterval: userConfig.initialInterval ??\n defaultAdminConfig.initialInterval,\n };\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport {\n fetchAdminActivity,\n fetchAdminAgents,\n fetchAdminOverview,\n fetchAdminParticipants,\n fetchAdminThreads,\n} from \"./adminService\";\nimport type {\n AdminActivityInterval,\n AdminDatePreset,\n UseCopilotzAdminOptions,\n UseCopilotzAdminResult,\n} from \"./types\";\n\nexport function useCopilotzAdmin(\n options: UseCopilotzAdminOptions = {},\n): UseCopilotzAdminResult {\n const [range, setRange] = useState<AdminDatePreset>(options.range ?? \"7d\");\n const [interval, setInterval] = useState<AdminActivityInterval>(\n options.interval ?? \"day\",\n );\n const [overview, setOverview] = useState<UseCopilotzAdminResult[\"overview\"]>(\n null,\n );\n const [activity, setActivity] = useState<UseCopilotzAdminResult[\"activity\"]>(\n [],\n );\n const [threads, setThreads] = useState<UseCopilotzAdminResult[\"threads\"]>([]);\n const [participants, setParticipants] = useState<\n UseCopilotzAdminResult[\"participants\"]\n >([]);\n const [agents, setAgents] = useState<UseCopilotzAdminResult[\"agents\"]>([]);\n const [isLoading, setIsLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n\n const fetchAll = useCallback(async () => {\n setIsLoading(true);\n setError(null);\n try {\n const shared = {\n baseUrl: options.baseUrl,\n getRequestHeaders: options.getRequestHeaders,\n };\n const [\n nextOverview,\n nextActivity,\n nextThreads,\n nextParticipants,\n nextAgents,\n ] = await Promise.all([\n fetchAdminOverview(range, options.namespace, shared),\n fetchAdminActivity(range, interval, options.namespace, shared),\n fetchAdminThreads(options.threadSearch, options.namespace, shared),\n fetchAdminParticipants(\n options.participantSearch,\n options.namespace,\n shared,\n ),\n fetchAdminAgents(options.agentSearch, options.namespace, shared),\n ]);\n\n setOverview(nextOverview);\n setActivity(nextActivity);\n setThreads(nextThreads);\n setParticipants(nextParticipants);\n setAgents(nextAgents);\n } catch (nextError) {\n setError(nextError instanceof Error\n ? nextError\n : new Error(\"Failed to load admin data\"));\n } finally {\n setIsLoading(false);\n }\n }, [\n interval,\n options.agentSearch,\n options.baseUrl,\n options.getRequestHeaders,\n options.namespace,\n options.participantSearch,\n options.threadSearch,\n range,\n ]);\n\n useEffect(() => {\n void fetchAll();\n }, [fetchAll]);\n\n return useMemo(() => ({\n overview,\n activity,\n threads,\n participants,\n agents,\n filters: {\n namespace: options.namespace,\n threadSearch: options.threadSearch,\n participantSearch: options.participantSearch,\n agentSearch: options.agentSearch,\n range,\n interval,\n },\n isLoading,\n error,\n refresh: fetchAll,\n setRange,\n setInterval,\n }), [\n activity,\n agents,\n error,\n fetchAll,\n interval,\n isLoading,\n options.agentSearch,\n options.namespace,\n options.participantSearch,\n options.threadSearch,\n overview,\n participants,\n range,\n threads,\n ]);\n}\n","import type {\n AdminActivityInterval,\n AdminActivityPoint,\n AdminAgentSummary,\n AdminDatePreset,\n AdminOverview,\n AdminParticipantSummary,\n AdminThreadSummary,\n RequestHeadersProvider,\n} from \"./types\";\n\nconst rawBaseValue =\n (import.meta as { env?: Record<string, string | undefined> }).env\n ?.VITE_API_URL;\nconst rawBase = typeof rawBaseValue === \"string\" && rawBaseValue.length > 0\n ? rawBaseValue\n : \"/api\";\nconst normalizedBase = rawBase.replace(/\\/$/, \"\");\n\nconst runtimeProcess: typeof process | undefined =\n typeof process !== \"undefined\" ? process : undefined;\n\nconst API_KEY = (() => {\n const env =\n (import.meta as { env?: Record<string, string | undefined> }).env ?? {};\n const candidates = [\n env.VITE_API_KEY,\n env.VITE_COPILOTZ_API_KEY,\n runtimeProcess?.env?.COPILOTZ_API_KEY,\n runtimeProcess?.env?.API_KEY,\n ];\n return candidates.find((value) =>\n typeof value === \"string\" && value.length > 0\n );\n})();\n\nconst resolveBaseUrl = (baseUrl?: string) => {\n const candidate = (baseUrl && baseUrl.length > 0 ? baseUrl : normalizedBase)\n .replace(/\\/$/, \"\");\n return candidate.startsWith(\"http\") || candidate.startsWith(\"/\")\n ? candidate\n : `/${candidate}`;\n};\n\nconst withAuthHeaders = async (\n headers: Record<string, string> = {},\n getRequestHeaders?: RequestHeadersProvider,\n): Promise<Record<string, string>> => {\n const providedHeaders = getRequestHeaders\n ? await getRequestHeaders()\n : undefined;\n if (providedHeaders && Object.keys(providedHeaders).length > 0) {\n return { ...headers, ...providedHeaders };\n }\n if (API_KEY) {\n return { ...headers, Authorization: `Bearer ${API_KEY}` };\n }\n return headers;\n};\n\nconst getRangeWindow = (range: AdminDatePreset) => {\n const to = new Date();\n const from = new Date(to);\n if (range === \"24h\") {\n from.setHours(from.getHours() - 24);\n } else if (range === \"30d\") {\n from.setDate(from.getDate() - 30);\n } else {\n from.setDate(from.getDate() - 7);\n }\n return {\n from: from.toISOString(),\n to: to.toISOString(),\n };\n};\n\nasync function fetchAdminJson<T>(\n path: string,\n params: Record<string, string | undefined>,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<T> {\n const url = new URL(`${resolveBaseUrl(options?.baseUrl)}${path}`, window.location.origin);\n for (const [key, value] of Object.entries(params)) {\n if (typeof value === \"string\" && value.length > 0) {\n url.searchParams.set(key, value);\n }\n }\n\n const response = await fetch(url.toString(), {\n headers: await withAuthHeaders({}, options?.getRequestHeaders),\n });\n\n if (!response.ok) {\n throw new Error(`Admin request failed (${response.status})`);\n }\n\n const payload = await response.json() as { data?: T };\n return payload.data as T;\n}\n\nexport async function fetchAdminOverview(\n range: AdminDatePreset,\n namespace?: string,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<AdminOverview> {\n const windowRange = getRangeWindow(range);\n return await fetchAdminJson<AdminOverview>(\"/v1/admin/overview\", {\n namespace,\n from: windowRange.from,\n to: windowRange.to,\n }, options);\n}\n\nexport async function fetchAdminActivity(\n range: AdminDatePreset,\n interval: AdminActivityInterval,\n namespace?: string,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<AdminActivityPoint[]> {\n const windowRange = getRangeWindow(range);\n return await fetchAdminJson<AdminActivityPoint[]>(\"/v1/admin/activity\", {\n namespace,\n interval,\n from: windowRange.from,\n to: windowRange.to,\n }, options);\n}\n\nexport async function fetchAdminThreads(\n search?: string,\n namespace?: string,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<AdminThreadSummary[]> {\n return await fetchAdminJson<AdminThreadSummary[]>(\"/v1/admin/threads\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\n\nexport async function fetchAdminParticipants(\n search?: string,\n namespace?: string,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<AdminParticipantSummary[]> {\n return await fetchAdminJson<AdminParticipantSummary[]>(\"/v1/admin/participants\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\n\nexport async function fetchAdminAgents(\n search?: string,\n namespace?: string,\n options?: {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n },\n): Promise<AdminAgentSummary[]> {\n return await fetchAdminJson<AdminAgentSummary[]>(\"/v1/admin/agents\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\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","import * as React from \"react\"\n\nimport { cn } from \"../../lib/utils\"\n\nfunction Card({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card\"\n className={cn(\n \"bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-header\"\n className={cn(\n \"@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-title\"\n className={cn(\"leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-action\"\n className={cn(\n \"col-start-2 row-span-2 row-start-1 self-start justify-self-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-content\"\n className={cn(\"px-6\", className)}\n {...props}\n />\n )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-footer\"\n className={cn(\"flex items-center px-6 [.border-t]:pt-6\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Card,\n CardHeader,\n CardFooter,\n CardTitle,\n CardAction,\n CardDescription,\n CardContent,\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 * 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 \"file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n \"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]\",\n \"aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Input }\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 badgeVariants = cva(\n \"inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-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 transition-[color,box-shadow] overflow-hidden\",\n {\n variants: {\n variant: {\n default:\n \"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90\",\n secondary:\n \"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90\",\n destructive:\n \"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Badge({\n className,\n variant,\n asChild = false,\n ...props\n}: React.ComponentProps<\"span\"> &\n VariantProps<typeof badgeVariants> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"span\"\n\n return (\n <Comp\n data-slot=\"badge\"\n className={cn(badgeVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nexport { Badge, badgeVariants }\n","import * as React from \"react\"\nimport * as SelectPrimitive from \"@radix-ui/react-select\"\nimport { Check, ChevronDown, ChevronUp } from \"lucide-react\"\nimport { cn } from \"../../lib/utils\"\n\nconst Select = SelectPrimitive.Root\nconst SelectGroup = SelectPrimitive.Group\nconst SelectValue = SelectPrimitive.Value\n\nconst SelectTrigger = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Trigger>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger>\n>(({ className, children, ...props }, ref) => (\n <SelectPrimitive.Trigger\n ref={ref}\n className={cn(\n \"flex h-9 w-full items-center justify-between gap-2 rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-xs outline-none transition-colors placeholder:text-muted-foreground focus:ring-2 focus:ring-ring/40 disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDown className=\"h-4 w-4 opacity-50\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n))\nSelectTrigger.displayName = SelectPrimitive.Trigger.displayName\n\nconst SelectContent = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content>\n>(({ className, children, position = \"popper\", ...props }, ref) => (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n ref={ref}\n className={cn(\n \"relative z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md\",\n position === \"popper\" && \"translate-y-1\",\n className\n )}\n position={position}\n {...props}\n >\n <SelectPrimitive.ScrollUpButton className=\"flex cursor-default items-center justify-center py-1\">\n <ChevronUp className=\"h-4 w-4\" />\n </SelectPrimitive.ScrollUpButton>\n <SelectPrimitive.Viewport\n className={cn(\n \"p-1\",\n position === \"popper\" &&\n \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectPrimitive.ScrollDownButton className=\"flex cursor-default items-center justify-center py-1\">\n <ChevronDown className=\"h-4 w-4\" />\n </SelectPrimitive.ScrollDownButton>\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n))\nSelectContent.displayName = SelectPrimitive.Content.displayName\n\nconst SelectItem = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item>\n>(({ className, children, ...props }, ref) => (\n <SelectPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className\n )}\n {...props}\n >\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n <SelectPrimitive.ItemIndicator className=\"absolute right-2 inline-flex items-center justify-center\">\n <Check className=\"h-4 w-4\" />\n </SelectPrimitive.ItemIndicator>\n </SelectPrimitive.Item>\n))\nSelectItem.displayName = SelectPrimitive.Item.displayName\n\nexport {\n Select,\n SelectGroup,\n SelectValue,\n SelectTrigger,\n SelectContent,\n SelectItem,\n}\n"],"mappings":"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","names":["useMemo","useState","jsx","jsx","Slot","cva","jsx","cva","Slot","jsx","jsx","jsx","jsxs","useMemo","useState"]}
|
|
1
|
+
{"version":3,"sources":["../src/CopilotzAdmin.tsx","../src/config.ts","../src/useCopilotzAdmin.ts","../src/adminService.ts","../src/lib/utils.ts","../src/components/ui/card.tsx","../src/components/ui/button.tsx","../src/components/ui/tooltip.tsx","../src/components/ui/sidebar.tsx","../src/hooks/use-mobile.ts","../src/components/ui/input.tsx","../src/components/ui/sheet.tsx","../src/components/layout/AdminSidebar.tsx","../src/components/layout/AdminHeader.tsx","../src/components/ui/select.tsx","../src/components/ui/badge.tsx","../src/components/views/DashboardView.tsx","../src/components/views/ThreadsView.tsx","../src/components/views/ThreadDetailView.tsx"],"sourcesContent":["import React, {\n useCallback,\n useDeferredValue,\n useMemo,\n useState,\n} from \"react\";\nimport { defaultAdminConfig, mergeAdminConfig } from \"./config\";\nimport { useCopilotzAdmin } from \"./useCopilotzAdmin\";\nimport { cn } from \"./lib/utils\";\nimport { Card, CardContent } from \"./components/ui/card\";\nimport { Button } from \"./components/ui/button\";\nimport { TooltipProvider } from \"./components/ui/tooltip\";\nimport { SidebarProvider, SidebarInset } from \"./components/ui/sidebar\";\nimport { AdminSidebar } from \"./components/layout/AdminSidebar\";\nimport { AdminHeader } from \"./components/layout/AdminHeader\";\nimport { DashboardView } from \"./components/views/DashboardView\";\nimport { ThreadsView } from \"./components/views/ThreadsView\";\nimport { ThreadDetailView } from \"./components/views/ThreadDetailView\";\nimport type {\n AdminConfig,\n AdminPage,\n AdminRoute,\n} from \"./types\";\n\nexport interface CopilotzAdminProps {\n config?: Partial<AdminConfig>;\n className?: string;\n}\n\nexport const CopilotzAdmin: React.FC<CopilotzAdminProps> = ({\n config: userConfig,\n className,\n}) => {\n const config = useMemo(\n () => mergeAdminConfig(defaultAdminConfig, userConfig),\n [userConfig],\n );\n\n const [route, setRoute] = useState<AdminRoute>({ page: config.defaultPage });\n\n const [threadSearch, setThreadSearch] = useState(\"\");\n const [participantSearch, setParticipantSearch] = useState(\"\");\n const [agentSearch, setAgentSearch] = useState(\"\");\n const deferredThreadSearch = useDeferredValue(threadSearch);\n const deferredParticipantSearch = useDeferredValue(participantSearch);\n const deferredAgentSearch = useDeferredValue(agentSearch);\n\n const admin = useCopilotzAdmin({\n baseUrl: config.baseUrl,\n getRequestHeaders: config.getRequestHeaders,\n namespace: config.namespace,\n range: config.initialRange,\n interval: config.initialInterval,\n threadSearch: deferredThreadSearch,\n participantSearch: deferredParticipantSearch,\n agentSearch: deferredAgentSearch,\n });\n\n const navigate = useCallback(\n (next: AdminRoute) => {\n setRoute(next);\n config.onNavigate?.(next);\n },\n [config],\n );\n\n const handleSidebarNavigate = useCallback(\n (page: AdminPage) => navigate({ page }),\n [navigate],\n );\n\n const handleThreadClick = useCallback(\n (threadId: string) => navigate({ page: \"thread-detail\", resourceId: threadId }),\n [navigate],\n );\n\n const handleBackToThreads = useCallback(\n () => navigate({ page: \"threads\" }),\n [navigate],\n );\n\n // For sidebar highlighting, thread-detail maps to \"threads\"\n const sidebarPage = route.page === \"thread-detail\" ? \"threads\" : route.page;\n\n if (admin.isLoading && !admin.overview) {\n return (\n <Card className={cn(\"border-border\", className)}>\n <CardContent className=\"text-muted-foreground flex items-center justify-center min-h-[200px]\">\n {config.labels.loading}\n </CardContent>\n </Card>\n );\n }\n\n if (admin.error && !admin.overview) {\n return (\n <Card\n className={cn(\"border-destructive/50 bg-destructive/10\", className)}\n >\n <CardContent className=\"space-y-4\">\n <p className=\"text-base font-semibold text-destructive\">\n {admin.error.message}\n </p>\n <Button\n variant=\"destructive\"\n onClick={() => void admin.refresh()}\n >\n {config.labels.retry}\n </Button>\n </CardContent>\n </Card>\n );\n }\n\n const renderCurrentView = () => {\n switch (route.page) {\n case \"dashboard\":\n return (\n <DashboardView\n config={config}\n overview={admin.overview}\n activity={admin.activity}\n threads={admin.threads}\n participants={admin.participants}\n agents={admin.agents}\n interval={admin.filters.interval}\n threadSearch={threadSearch}\n participantSearch={participantSearch}\n agentSearch={agentSearch}\n onThreadSearchChange={setThreadSearch}\n onParticipantSearchChange={setParticipantSearch}\n onAgentSearchChange={setAgentSearch}\n onThreadClick={handleThreadClick}\n />\n );\n case \"threads\":\n return (\n <ThreadsView\n config={config}\n threads={admin.threads}\n searchValue={threadSearch}\n onSearchChange={setThreadSearch}\n onThreadClick={handleThreadClick}\n />\n );\n case \"thread-detail\":\n return route.resourceId ? (\n <ThreadDetailView\n threadId={route.resourceId}\n config={config}\n onBack={handleBackToThreads}\n />\n ) : null;\n case \"participants\":\n return (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <h3 className=\"text-lg font-semibold\">\n {config.labels.participantsTitle}\n </h3>\n <p className=\"mt-2 text-sm text-muted-foreground\">\n Detailed participant management coming soon.\n </p>\n </div>\n );\n case \"agents\":\n return (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <h3 className=\"text-lg font-semibold\">\n {config.labels.agentsTitle}\n </h3>\n <p className=\"mt-2 text-sm text-muted-foreground\">\n Agent configuration management coming soon.\n </p>\n </div>\n );\n case \"events\":\n return (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <h3 className=\"text-lg font-semibold\">\n {config.labels.eventsTitle}\n </h3>\n <p className=\"mt-2 text-sm text-muted-foreground\">\n Event inspector coming soon.\n </p>\n </div>\n );\n default:\n return null;\n }\n };\n\n return (\n <TooltipProvider>\n <SidebarProvider defaultOpen={config.sidebar.defaultOpen}>\n <div\n className={cn(\n \"flex h-[100svh] md:h-screen bg-background w-full overflow-hidden\",\n className,\n )}\n >\n <AdminSidebar\n config={config}\n currentPage={sidebarPage}\n onNavigate={handleSidebarNavigate}\n />\n\n <SidebarInset>\n <div className=\"flex flex-col h-full min-h-0\">\n <AdminHeader\n config={config}\n currentPage={route.page}\n range={admin.filters.range}\n interval={admin.filters.interval}\n onRangeChange={admin.setRange}\n onIntervalChange={admin.setInterval}\n onRefresh={() => void admin.refresh()}\n isLoading={admin.isLoading}\n />\n\n <div className=\"flex-1 overflow-auto p-6\">\n {renderCurrentView()}\n </div>\n </div>\n </SidebarInset>\n </div>\n </SidebarProvider>\n </TooltipProvider>\n );\n};\n","import type { AdminConfig, ResolvedAdminConfig } from \"./types\";\n\nexport const defaultAdminConfig: ResolvedAdminConfig = {\n branding: {\n title: \"Copilotz Admin\",\n subtitle: \"Operational visibility for Copilotz clients\",\n logo: null,\n actions: null,\n },\n labels: {\n overviewTitle: \"Overview\",\n activityTitle: \"Activity\",\n threadsTitle: \"Threads\",\n participantsTitle: \"Participants\",\n agentsTitle: \"Agents\",\n range24h: \"24h\",\n range7d: \"7d\",\n range30d: \"30d\",\n intervalHour: \"Hourly\",\n intervalDay: \"Daily\",\n refresh: \"Refresh\",\n retry: \"Try again\",\n loading: \"Loading admin data...\",\n emptyTitle: \"No activity yet\",\n emptyDescription: \"Admin metrics will appear after threads, events, and graph data start flowing.\",\n threadSearchPlaceholder: \"Search threads\",\n participantSearchPlaceholder: \"Search participants\",\n agentSearchPlaceholder: \"Search agents\",\n messagesCard: \"Messages\",\n activeThreadsCard: \"Active threads\",\n participantsCard: \"Participants\",\n tokensCard: \"LLM tokens\",\n queueCard: \"Queued events\",\n statusActive: \"Active\",\n statusArchived: \"Archived\",\n scopeGlobal: \"Global\",\n scopeScoped: \"Scoped\",\n configured: \"Configured\",\n unconfigured: \"Observed only\",\n noResults: \"No results\",\n eventsTitle: \"Events\",\n dashboardTitle: \"Dashboard\",\n },\n features: {\n showOverview: true,\n showActivity: true,\n showThreads: true,\n showParticipants: true,\n showAgents: true,\n showEvents: false,\n },\n ui: {\n compact: false,\n maxActivityBars: 18,\n },\n sidebar: {\n defaultOpen: true,\n collapsible: \"icon\",\n },\n baseUrl: \"\",\n getRequestHeaders: async () => ({}),\n namespace: \"\",\n initialRange: \"7d\",\n initialInterval: \"day\",\n defaultPage: \"dashboard\",\n onNavigate: null,\n};\n\nexport function mergeAdminConfig(\n _baseConfig: ResolvedAdminConfig,\n userConfig?: Partial<AdminConfig>,\n): ResolvedAdminConfig {\n if (!userConfig) return defaultAdminConfig;\n\n return {\n branding: {\n ...defaultAdminConfig.branding,\n ...userConfig.branding,\n },\n labels: {\n ...defaultAdminConfig.labels,\n ...userConfig.labels,\n },\n features: {\n ...defaultAdminConfig.features,\n ...userConfig.features,\n },\n ui: {\n ...defaultAdminConfig.ui,\n ...userConfig.ui,\n },\n sidebar: {\n ...defaultAdminConfig.sidebar,\n ...userConfig.sidebar,\n },\n baseUrl: userConfig.baseUrl ?? defaultAdminConfig.baseUrl,\n getRequestHeaders: userConfig.getRequestHeaders ??\n defaultAdminConfig.getRequestHeaders,\n namespace: userConfig.namespace ?? defaultAdminConfig.namespace,\n initialRange: userConfig.initialRange ?? defaultAdminConfig.initialRange,\n initialInterval: userConfig.initialInterval ??\n defaultAdminConfig.initialInterval,\n defaultPage: userConfig.defaultPage ?? defaultAdminConfig.defaultPage,\n onNavigate: userConfig.onNavigate ?? defaultAdminConfig.onNavigate,\n };\n}\n","import {\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport {\n fetchAdminActivity,\n fetchAdminAgents,\n fetchAdminOverview,\n fetchAdminParticipants,\n fetchAdminThreads,\n} from \"./adminService\";\nimport type {\n AdminActivityInterval,\n AdminDatePreset,\n UseCopilotzAdminOptions,\n UseCopilotzAdminResult,\n} from \"./types\";\n\nexport function useCopilotzAdmin(\n options: UseCopilotzAdminOptions = {},\n): UseCopilotzAdminResult {\n const [range, setRange] = useState<AdminDatePreset>(options.range ?? \"7d\");\n const [interval, setInterval] = useState<AdminActivityInterval>(\n options.interval ?? \"day\",\n );\n const [overview, setOverview] = useState<UseCopilotzAdminResult[\"overview\"]>(\n null,\n );\n const [activity, setActivity] = useState<UseCopilotzAdminResult[\"activity\"]>(\n [],\n );\n const [threads, setThreads] = useState<UseCopilotzAdminResult[\"threads\"]>([]);\n const [participants, setParticipants] = useState<\n UseCopilotzAdminResult[\"participants\"]\n >([]);\n const [agents, setAgents] = useState<UseCopilotzAdminResult[\"agents\"]>([]);\n const [isLoading, setIsLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n\n const fetchAll = useCallback(async () => {\n setIsLoading(true);\n setError(null);\n try {\n const shared = {\n baseUrl: options.baseUrl,\n getRequestHeaders: options.getRequestHeaders,\n };\n const [\n nextOverview,\n nextActivity,\n nextThreads,\n nextParticipants,\n nextAgents,\n ] = await Promise.all([\n fetchAdminOverview(range, options.namespace, shared),\n fetchAdminActivity(range, interval, options.namespace, shared),\n fetchAdminThreads(options.threadSearch, options.namespace, shared),\n fetchAdminParticipants(\n options.participantSearch,\n options.namespace,\n shared,\n ),\n fetchAdminAgents(options.agentSearch, options.namespace, shared),\n ]);\n\n setOverview(nextOverview);\n setActivity(nextActivity);\n setThreads(nextThreads);\n setParticipants(nextParticipants);\n setAgents(nextAgents);\n } catch (nextError) {\n setError(nextError instanceof Error\n ? nextError\n : new Error(\"Failed to load admin data\"));\n } finally {\n setIsLoading(false);\n }\n }, [\n interval,\n options.agentSearch,\n options.baseUrl,\n options.getRequestHeaders,\n options.namespace,\n options.participantSearch,\n options.threadSearch,\n range,\n ]);\n\n useEffect(() => {\n void fetchAll();\n }, [fetchAll]);\n\n return useMemo(() => ({\n overview,\n activity,\n threads,\n participants,\n agents,\n filters: {\n namespace: options.namespace,\n threadSearch: options.threadSearch,\n participantSearch: options.participantSearch,\n agentSearch: options.agentSearch,\n range,\n interval,\n },\n isLoading,\n error,\n refresh: fetchAll,\n setRange,\n setInterval,\n }), [\n activity,\n agents,\n error,\n fetchAll,\n interval,\n isLoading,\n options.agentSearch,\n options.namespace,\n options.participantSearch,\n options.threadSearch,\n overview,\n participants,\n range,\n threads,\n ]);\n}\n","import type {\n AdminActivityInterval,\n AdminActivityPoint,\n AdminAgentSummary,\n AdminDatePreset,\n AdminOverview,\n AdminParticipantSummary,\n AdminThreadSummary,\n AdminThreadDetail,\n AdminMessage,\n AdminMessagePage,\n RequestHeadersProvider,\n} from \"./types\";\n\nconst rawBaseValue =\n (import.meta as { env?: Record<string, string | undefined> }).env\n ?.VITE_API_URL;\nconst rawBase = typeof rawBaseValue === \"string\" && rawBaseValue.length > 0\n ? rawBaseValue\n : \"/api\";\nconst normalizedBase = rawBase.replace(/\\/$/, \"\");\n\nconst runtimeProcess: typeof process | undefined =\n typeof process !== \"undefined\" ? process : undefined;\n\nconst API_KEY = (() => {\n const env =\n (import.meta as { env?: Record<string, string | undefined> }).env ?? {};\n const candidates = [\n env.VITE_API_KEY,\n env.VITE_COPILOTZ_API_KEY,\n runtimeProcess?.env?.COPILOTZ_API_KEY,\n runtimeProcess?.env?.API_KEY,\n ];\n return candidates.find((value) =>\n typeof value === \"string\" && value.length > 0\n );\n})();\n\nconst resolveBaseUrl = (baseUrl?: string) => {\n const candidate = (baseUrl && baseUrl.length > 0 ? baseUrl : normalizedBase)\n .replace(/\\/$/, \"\");\n return candidate.startsWith(\"http\") || candidate.startsWith(\"/\")\n ? candidate\n : `/${candidate}`;\n};\n\nconst withAuthHeaders = async (\n headers: Record<string, string> = {},\n getRequestHeaders?: RequestHeadersProvider,\n): Promise<Record<string, string>> => {\n const providedHeaders = getRequestHeaders\n ? await getRequestHeaders()\n : undefined;\n if (providedHeaders && Object.keys(providedHeaders).length > 0) {\n return { ...headers, ...providedHeaders };\n }\n if (API_KEY) {\n return { ...headers, Authorization: `Bearer ${API_KEY}` };\n }\n return headers;\n};\n\nconst getRangeWindow = (range: AdminDatePreset) => {\n const to = new Date();\n const from = new Date(to);\n if (range === \"24h\") {\n from.setHours(from.getHours() - 24);\n } else if (range === \"30d\") {\n from.setDate(from.getDate() - 30);\n } else {\n from.setDate(from.getDate() - 7);\n }\n return {\n from: from.toISOString(),\n to: to.toISOString(),\n };\n};\n\ninterface FetchOptions {\n baseUrl?: string;\n getRequestHeaders?: RequestHeadersProvider;\n}\n\nasync function fetchAdminJson<T>(\n path: string,\n params: Record<string, string | undefined>,\n options?: FetchOptions,\n): Promise<T> {\n const url = new URL(`${resolveBaseUrl(options?.baseUrl)}${path}`, window.location.origin);\n for (const [key, value] of Object.entries(params)) {\n if (typeof value === \"string\" && value.length > 0) {\n url.searchParams.set(key, value);\n }\n }\n\n const response = await fetch(url.toString(), {\n headers: await withAuthHeaders({}, options?.getRequestHeaders),\n });\n\n if (!response.ok) {\n throw new Error(`Admin request failed (${response.status})`);\n }\n\n const payload = await response.json() as { data?: T };\n return payload.data as T;\n}\n\nasync function fetchRawJson<T>(\n path: string,\n params: Record<string, string | undefined>,\n options?: FetchOptions,\n): Promise<T> {\n const url = new URL(`${resolveBaseUrl(options?.baseUrl)}${path}`, window.location.origin);\n for (const [key, value] of Object.entries(params)) {\n if (typeof value === \"string\" && value.length > 0) {\n url.searchParams.set(key, value);\n }\n }\n\n const response = await fetch(url.toString(), {\n headers: await withAuthHeaders({}, options?.getRequestHeaders),\n });\n\n if (!response.ok) {\n throw new Error(`Admin request failed (${response.status})`);\n }\n\n return await response.json() as T;\n}\n\n// --- Admin aggregate endpoints ---\n\nexport async function fetchAdminOverview(\n range: AdminDatePreset,\n namespace?: string,\n options?: FetchOptions,\n): Promise<AdminOverview> {\n const windowRange = getRangeWindow(range);\n return await fetchAdminJson<AdminOverview>(\"/v1/admin/overview\", {\n namespace,\n from: windowRange.from,\n to: windowRange.to,\n }, options);\n}\n\nexport async function fetchAdminActivity(\n range: AdminDatePreset,\n interval: AdminActivityInterval,\n namespace?: string,\n options?: FetchOptions,\n): Promise<AdminActivityPoint[]> {\n const windowRange = getRangeWindow(range);\n return await fetchAdminJson<AdminActivityPoint[]>(\"/v1/admin/activity\", {\n namespace,\n interval,\n from: windowRange.from,\n to: windowRange.to,\n }, options);\n}\n\nexport async function fetchAdminThreads(\n search?: string,\n namespace?: string,\n options?: FetchOptions,\n): Promise<AdminThreadSummary[]> {\n return await fetchAdminJson<AdminThreadSummary[]>(\"/v1/admin/threads\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\n\nexport async function fetchAdminParticipants(\n search?: string,\n namespace?: string,\n options?: FetchOptions,\n): Promise<AdminParticipantSummary[]> {\n return await fetchAdminJson<AdminParticipantSummary[]>(\"/v1/admin/participants\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\n\nexport async function fetchAdminAgents(\n search?: string,\n namespace?: string,\n options?: FetchOptions,\n): Promise<AdminAgentSummary[]> {\n return await fetchAdminJson<AdminAgentSummary[]>(\"/v1/admin/agents\", {\n search,\n namespace,\n limit: \"8\",\n }, options);\n}\n\n// --- Thread detail + messages ---\n\nexport async function fetchThreadDetail(\n threadId: string,\n options?: FetchOptions,\n): Promise<AdminThreadDetail> {\n return await fetchAdminJson<AdminThreadDetail>(\n `/v1/threads/${encodeURIComponent(threadId)}`,\n {},\n options,\n );\n}\n\nexport async function fetchThreadMessages(\n threadId: string,\n messageOptions?: { limit?: number; before?: string },\n options?: FetchOptions,\n): Promise<AdminMessagePage> {\n return await fetchRawJson<AdminMessagePage>(\n `/v1/threads/${encodeURIComponent(threadId)}/messages`,\n {\n limit: messageOptions?.limit?.toString(),\n before: messageOptions?.before,\n },\n options,\n );\n}\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","import * as React from \"react\"\n\nimport { cn } from \"../../lib/utils\"\n\nfunction Card({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card\"\n className={cn(\n \"bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-header\"\n className={cn(\n \"@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-title\"\n className={cn(\"leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-action\"\n className={cn(\n \"col-start-2 row-span-2 row-start-1 self-start justify-self-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-content\"\n className={cn(\"px-6\", className)}\n {...props}\n />\n )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-footer\"\n className={cn(\"flex items-center px-6 [.border-t]:pt-6\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Card,\n CardHeader,\n CardFooter,\n CardTitle,\n CardAction,\n CardDescription,\n CardContent,\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 * 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 \"bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-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 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance\",\n className\n )}\n {...props}\n >\n {children}\n <TooltipPrimitive.Arrow className=\"bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]\" />\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n )\n}\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }\n","import * 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 \"./button\"\nimport { Input } from \"./input\"\nimport { Separator } from \"./separator\"\nimport {\n Sheet,\n SheetContent,\n SheetDescription,\n SheetHeader,\n SheetTitle,\n} from \"./sheet\"\nimport { Skeleton } from \"./skeleton\"\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"./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\"\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}\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 const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\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 document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open]\n )\n\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\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 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 }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]\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\": SIDEBAR_WIDTH,\n \"--sidebar-width-icon\": SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn(\n \"group/sidebar-wrapper has-data-[variant=inset]:bg-sidebar flex min-h-svh w-full\",\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 \n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === \"none\") {\n return (\n <div\n data-slot=\"sidebar\"\n className={cn(\n \"bg-sidebar text-sidebar-foreground flex h-full w-(--sidebar-width) flex-col\",\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=\"bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>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 return (\n <div\n className=\"group peer text-sidebar-foreground hidden md:block\"\n data-state={state}\n data-collapsible={state === \"collapsed\" ? collapsible : \"\"}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\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-svh 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 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=\"bg-sidebar group-data-[variant=floating]:border-sidebar-border flex h-full w-full flex-col group-data-[variant=floating]:rounded-lg group-data-[variant=floating]: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 } = useSidebar()\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n \"hover:after:bg-sidebar-border 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] sm:flex\",\n \"in-data-[side=left]:cursor-w-resize in-data-[side=right]:cursor-e-resize\",\n \"[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize\",\n \"hover:group-data-[collapsible=offcanvas]:bg-sidebar group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full\",\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(\n \"bg-background relative flex w-full flex-1 flex-col\",\n \"md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2\",\n className\n )}\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(\"bg-background h-8 w-full 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 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(\"bg-sidebar-border mx-2 w-auto\", 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 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 \"text-sidebar-foreground/70 ring-sidebar-ring flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium 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 \"text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\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 \"text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\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 \"peer-data-[active=true]/menu-button:text-sidebar-accent-foreground group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 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 \"text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium 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 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 \"border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l 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 \"text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground [&>svg]:text-sidebar-accent-foreground flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden focus-visible:ring-2 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\",\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>(undefined)\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 \"file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n \"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]\",\n \"aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Input }\n","import * 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 cleanupBodyStyles() {\n if (typeof document !== 'undefined' && document.body.style.pointerEvents === 'none') {\n document.body.style.pointerEvents = '';\n }\n}\n\nfunction Sheet({ open, onOpenChange, ...props }: React.ComponentProps<typeof SheetPrimitive.Root>) {\n const prevOpenRef = React.useRef(open);\n\n React.useEffect(() => {\n if (prevOpenRef.current === true && open === false) {\n const timeout = setTimeout(cleanupBodyStyles, 350);\n return () => clearTimeout(timeout);\n }\n prevOpenRef.current = open;\n }, [open]);\n\n React.useEffect(() => {\n return () => {\n cleanupBodyStyles();\n };\n }, []);\n\n return <SheetPrimitive.Root data-slot=\"sheet\" open={open} onOpenChange={onOpenChange} {...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\",\n \"data-[state=open]:animate-in data-[state=closed]:animate-out\",\n \"data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n \"data-[state=closed]:pointer-events-none\",\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 aria-describedby={undefined}\n className={cn(\n \"bg-background data-[state=open]:animate-in data-[state=closed]:animate-out fixed z-50 flex flex-col gap-4 shadow-lg transition ease-in-out data-[state=closed]:duration-300 data-[state=open]:duration-500\",\n side === \"right\" &&\n \"data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right inset-y-0 right-0 h-full w-3/4 border-l sm:max-w-sm\",\n side === \"left\" &&\n \"data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left inset-y-0 left-0 h-full w-3/4 border-r sm:max-w-sm\",\n side === \"top\" &&\n \"data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top inset-x-0 top-0 h-auto border-b\",\n side === \"bottom\" &&\n \"data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom inset-x-0 bottom-0 h-auto border-t\",\n className\n )}\n {...props}\n >\n {children}\n <SheetPrimitive.Close className=\"ring-offset-background focus:ring-ring data-[state=open]:bg-secondary absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none\">\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(\"text-foreground font-semibold\", 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-muted-foreground text-sm\", 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 React from \"react\";\nimport {\n LayoutDashboard,\n MessageSquare,\n Users,\n Bot,\n Activity,\n} from \"lucide-react\";\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupContent,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarRail,\n} from \"../ui/sidebar\";\nimport type { AdminPage, ResolvedAdminConfig } from \"../../types\";\n\ninterface NavItem {\n page: AdminPage;\n label: string;\n icon: React.ElementType;\n featureKey?: keyof ResolvedAdminConfig[\"features\"];\n}\n\nconst NAV_ITEMS: NavItem[] = [\n {\n page: \"dashboard\",\n label: \"Dashboard\",\n icon: LayoutDashboard,\n },\n {\n page: \"threads\",\n label: \"Threads\",\n icon: MessageSquare,\n featureKey: \"showThreads\",\n },\n {\n page: \"participants\",\n label: \"Participants\",\n icon: Users,\n featureKey: \"showParticipants\",\n },\n {\n page: \"agents\",\n label: \"Agents\",\n icon: Bot,\n featureKey: \"showAgents\",\n },\n {\n page: \"events\",\n label: \"Events\",\n icon: Activity,\n featureKey: \"showEvents\",\n },\n];\n\nexport interface AdminSidebarProps {\n config: ResolvedAdminConfig;\n currentPage: AdminPage;\n onNavigate: (page: AdminPage) => void;\n}\n\nexport const AdminSidebar: React.FC<AdminSidebarProps> = ({\n config,\n currentPage,\n onNavigate,\n}) => {\n const visibleItems = NAV_ITEMS.filter(\n (item) => !item.featureKey || config.features[item.featureKey],\n );\n\n return (\n <Sidebar collapsible={config.sidebar.collapsible}>\n <SidebarHeader>\n <div className=\"flex items-center gap-3 px-2 py-3\">\n <div className=\"flex items-center justify-center shrink-0\">\n {config.branding.logo || (\n <div className=\"flex h-8 w-8 items-center justify-center rounded-lg bg-primary text-primary-foreground\">\n <LayoutDashboard className=\"h-4 w-4\" />\n </div>\n )}\n </div>\n <div className=\"flex flex-col min-w-0 group-data-[collapsible=icon]:hidden\">\n <span className=\"text-sm font-semibold truncate\">\n {config.branding.title}\n </span>\n {config.branding.subtitle && (\n <span className=\"text-xs text-muted-foreground truncate\">\n {config.branding.subtitle}\n </span>\n )}\n </div>\n </div>\n </SidebarHeader>\n\n <SidebarContent>\n <SidebarGroup>\n <SidebarGroupLabel className=\"group-data-[collapsible=icon]:hidden\">\n Navigation\n </SidebarGroupLabel>\n <SidebarGroupContent>\n <SidebarMenu>\n {visibleItems.map((item) => {\n const Icon = item.icon;\n const label =\n config.labels[\n `${item.page}Title` as keyof typeof config.labels\n ] || item.label;\n return (\n <SidebarMenuItem key={item.page}>\n <SidebarMenuButton\n isActive={currentPage === item.page}\n onClick={() => onNavigate(item.page)}\n tooltip={label}\n >\n <Icon />\n <span>{label}</span>\n </SidebarMenuButton>\n </SidebarMenuItem>\n );\n })}\n </SidebarMenu>\n </SidebarGroupContent>\n </SidebarGroup>\n </SidebarContent>\n\n {config.namespace && (\n <SidebarFooter>\n <div className=\"px-2 py-2 text-xs text-muted-foreground group-data-[collapsible=icon]:hidden\">\n <span className=\"font-medium uppercase tracking-[0.18em]\">\n {config.namespace}\n </span>\n </div>\n </SidebarFooter>\n )}\n\n <SidebarRail />\n </Sidebar>\n );\n};\n","import React from \"react\";\nimport { RefreshCw } from \"lucide-react\";\nimport { Card, CardHeader } from \"../ui/card\";\nimport { Button } from \"../ui/button\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"../ui/tooltip\";\nimport { SidebarTrigger } from \"../ui/sidebar\";\nimport {\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from \"../ui/select\";\nimport type {\n AdminDatePreset,\n AdminActivityInterval,\n AdminPage,\n ResolvedAdminConfig,\n} from \"../../types\";\n\nconst PAGE_TITLES: Record<AdminPage, string> = {\n dashboard: \"Dashboard\",\n threads: \"Threads\",\n \"thread-detail\": \"Thread Detail\",\n participants: \"Participants\",\n agents: \"Agents\",\n events: \"Events\",\n};\n\nexport interface AdminHeaderProps {\n config: ResolvedAdminConfig;\n currentPage: AdminPage;\n range: AdminDatePreset;\n interval: AdminActivityInterval;\n onRangeChange: (range: AdminDatePreset) => void;\n onIntervalChange: (interval: AdminActivityInterval) => void;\n onRefresh: () => void;\n isLoading?: boolean;\n}\n\nexport const AdminHeader: React.FC<AdminHeaderProps> = ({\n config,\n currentPage,\n range,\n interval,\n onRangeChange,\n onIntervalChange,\n onRefresh,\n isLoading,\n}) => {\n const pageTitle =\n config.labels[`${currentPage}Title` as keyof typeof config.labels] ||\n PAGE_TITLES[currentPage];\n\n return (\n <Card className=\"py-0 border-b rounded-none relative z-10 bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/80\">\n <CardHeader className=\"p-2\">\n <div className=\"flex items-center justify-between gap-2\">\n {/* Left: sidebar trigger + page title */}\n <div className=\"flex items-center gap-1\">\n <Tooltip>\n <TooltipTrigger asChild>\n <SidebarTrigger className=\"-ml-1\" />\n </TooltipTrigger>\n <TooltipContent>Toggle Sidebar</TooltipContent>\n </Tooltip>\n\n <h1 className=\"text-sm font-medium ml-2\">{pageTitle}</h1>\n </div>\n\n {/* Spacer */}\n <div className=\"flex-1\" />\n\n {/* Right: filters + actions */}\n <div className=\"flex items-center gap-1\">\n {currentPage === \"dashboard\" && (\n <>\n <Button\n variant={range === \"24h\" ? \"default\" : \"ghost\"}\n size=\"sm\"\n className=\"h-7 text-xs\"\n onClick={() => onRangeChange(\"24h\")}\n >\n {config.labels.range24h}\n </Button>\n <Button\n variant={range === \"7d\" ? \"default\" : \"ghost\"}\n size=\"sm\"\n className=\"h-7 text-xs\"\n onClick={() => onRangeChange(\"7d\")}\n >\n {config.labels.range7d}\n </Button>\n <Button\n variant={range === \"30d\" ? \"default\" : \"ghost\"}\n size=\"sm\"\n className=\"h-7 text-xs\"\n onClick={() => onRangeChange(\"30d\")}\n >\n {config.labels.range30d}\n </Button>\n\n <Select\n value={interval}\n onValueChange={(v) =>\n onIntervalChange(v as AdminActivityInterval)\n }\n >\n <SelectTrigger className=\"h-7 w-[90px] text-xs\">\n <SelectValue />\n </SelectTrigger>\n <SelectContent>\n <SelectItem value=\"hour\">\n {config.labels.intervalHour}\n </SelectItem>\n <SelectItem value=\"day\">\n {config.labels.intervalDay}\n </SelectItem>\n </SelectContent>\n </Select>\n </>\n )}\n\n <Tooltip>\n <TooltipTrigger asChild>\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={onRefresh}\n disabled={isLoading}\n >\n <RefreshCw\n className={`h-4 w-4 ${isLoading ? \"animate-spin\" : \"\"}`}\n />\n </Button>\n </TooltipTrigger>\n <TooltipContent>{config.labels.refresh}</TooltipContent>\n </Tooltip>\n\n {config.branding.actions}\n </div>\n </div>\n </CardHeader>\n </Card>\n );\n};\n","import * as React from \"react\"\nimport * as SelectPrimitive from \"@radix-ui/react-select\"\nimport { Check, ChevronDown, ChevronUp } from \"lucide-react\"\nimport { cn } from \"../../lib/utils\"\n\nconst Select = SelectPrimitive.Root\nconst SelectGroup = SelectPrimitive.Group\nconst SelectValue = SelectPrimitive.Value\n\nconst SelectTrigger = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Trigger>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger>\n>(({ className, children, ...props }, ref) => (\n <SelectPrimitive.Trigger\n ref={ref}\n className={cn(\n \"flex h-9 w-full items-center justify-between gap-2 rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-xs outline-none transition-colors placeholder:text-muted-foreground focus:ring-2 focus:ring-ring/40 disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDown className=\"h-4 w-4 opacity-50\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n))\nSelectTrigger.displayName = SelectPrimitive.Trigger.displayName\n\nconst SelectContent = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content>\n>(({ className, children, position = \"popper\", ...props }, ref) => (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n ref={ref}\n className={cn(\n \"relative z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md\",\n position === \"popper\" && \"translate-y-1\",\n className\n )}\n position={position}\n {...props}\n >\n <SelectPrimitive.ScrollUpButton className=\"flex cursor-default items-center justify-center py-1\">\n <ChevronUp className=\"h-4 w-4\" />\n </SelectPrimitive.ScrollUpButton>\n <SelectPrimitive.Viewport\n className={cn(\n \"p-1\",\n position === \"popper\" &&\n \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectPrimitive.ScrollDownButton className=\"flex cursor-default items-center justify-center py-1\">\n <ChevronDown className=\"h-4 w-4\" />\n </SelectPrimitive.ScrollDownButton>\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n))\nSelectContent.displayName = SelectPrimitive.Content.displayName\n\nconst SelectItem = React.forwardRef<\n React.ElementRef<typeof SelectPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item>\n>(({ className, children, ...props }, ref) => (\n <SelectPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className\n )}\n {...props}\n >\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n <SelectPrimitive.ItemIndicator className=\"absolute right-2 inline-flex items-center justify-center\">\n <Check className=\"h-4 w-4\" />\n </SelectPrimitive.ItemIndicator>\n </SelectPrimitive.Item>\n))\nSelectItem.displayName = SelectPrimitive.Item.displayName\n\nexport {\n Select,\n SelectGroup,\n SelectValue,\n SelectTrigger,\n SelectContent,\n SelectItem,\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 badgeVariants = cva(\n \"inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-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 transition-[color,box-shadow] overflow-hidden\",\n {\n variants: {\n variant: {\n default:\n \"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90\",\n secondary:\n \"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90\",\n destructive:\n \"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Badge({\n className,\n variant,\n asChild = false,\n ...props\n}: React.ComponentProps<\"span\"> &\n VariantProps<typeof badgeVariants> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"span\"\n\n return (\n <Comp\n data-slot=\"badge\"\n className={cn(badgeVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nexport { Badge, badgeVariants }\n","import React from \"react\";\nimport { cn } from \"../../lib/utils\";\nimport { Input } from \"../ui/input\";\nimport { Badge } from \"../ui/badge\";\nimport type {\n AdminActivityPoint,\n AdminAgentSummary,\n AdminParticipantSummary,\n AdminThreadSummary,\n AdminOverview,\n ResolvedAdminConfig,\n} from \"../../types\";\n\ninterface DashboardViewProps {\n config: ResolvedAdminConfig;\n overview: AdminOverview | null;\n activity: AdminActivityPoint[];\n threads: AdminThreadSummary[];\n participants: AdminParticipantSummary[];\n agents: AdminAgentSummary[];\n interval: \"hour\" | \"day\";\n threadSearch: string;\n participantSearch: string;\n agentSearch: string;\n onThreadSearchChange: (value: string) => void;\n onParticipantSearchChange: (value: string) => void;\n onAgentSearchChange: (value: string) => void;\n onThreadClick?: (threadId: string) => void;\n}\n\nexport const DashboardView: React.FC<DashboardViewProps> = ({\n config,\n overview,\n activity,\n threads,\n participants,\n agents,\n interval,\n threadSearch,\n participantSearch,\n agentSearch,\n onThreadSearchChange,\n onParticipantSearchChange,\n onAgentSearchChange,\n onThreadClick,\n}) => {\n const cards = [\n {\n label: config.labels.messagesCard,\n value: overview?.messageTotals.total ?? 0,\n detail: `${overview?.messageTotals.toolCallMessages ?? 0} tool-call messages`,\n },\n {\n label: config.labels.activeThreadsCard,\n value: overview?.threadTotals.active ?? 0,\n detail: `${overview?.threadTotals.total ?? 0} total threads`,\n },\n {\n label: config.labels.participantsCard,\n value: overview?.participantTotals.total ?? 0,\n detail: `${overview?.participantTotals.agents ?? 0} agents`,\n },\n {\n label: config.labels.tokensCard,\n value: overview?.llmTotals.totalTokens ?? 0,\n detail: `${overview?.llmTotals.totalCalls ?? 0} calls`,\n },\n {\n label: config.labels.queueCard,\n value: overview?.queueTotals.pending ?? 0,\n detail: `${overview?.queueTotals.failed ?? 0} failed`,\n },\n ];\n\n const isEmpty =\n cards.every((card) => card.value === 0) &&\n activity.length === 0 &&\n threads.length === 0 &&\n participants.length === 0 &&\n agents.length === 0;\n\n return (\n <div className=\"space-y-6\">\n {isEmpty && (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <h3 className=\"text-lg font-semibold\">{config.labels.emptyTitle}</h3>\n <p className=\"mt-2 text-sm text-muted-foreground\">\n {config.labels.emptyDescription}\n </p>\n </div>\n )}\n\n {/* Overview Cards */}\n {config.features.showOverview && (\n <section className=\"space-y-4\">\n <SectionHeading title={config.labels.overviewTitle} />\n <div className=\"grid grid-cols-2 gap-4 md:grid-cols-3 lg:grid-cols-5\">\n {cards.map((card) => (\n <div\n className=\"rounded-xl border bg-card p-5 shadow-sm\"\n key={card.label}\n >\n <p className=\"text-sm font-medium text-muted-foreground\">\n {card.label}\n </p>\n <p className=\"mt-3 text-3xl font-semibold tracking-tight\">\n {formatNumber(card.value)}\n </p>\n <p className=\"mt-2 text-xs text-muted-foreground\">\n {card.detail}\n </p>\n </div>\n ))}\n </div>\n </section>\n )}\n\n {/* Activity Chart */}\n {config.features.showActivity && (\n <section className=\"space-y-4\">\n <SectionHeading title={config.labels.activityTitle} />\n <ActivityChart\n interval={interval}\n labels={config.labels}\n maxBars={config.ui.maxActivityBars}\n points={activity}\n />\n </section>\n )}\n\n {/* Data Tables */}\n <div className=\"grid gap-6 lg:grid-cols-3\">\n {config.features.showThreads && (\n <DataTable\n rows={threads}\n searchPlaceholder={config.labels.threadSearchPlaceholder}\n searchValue={threadSearch}\n setSearchValue={onThreadSearchChange}\n title={config.labels.threadsTitle}\n >\n <ThreadsTable\n rows={threads}\n labels={config.labels}\n onThreadClick={onThreadClick}\n />\n </DataTable>\n )}\n {config.features.showParticipants && (\n <DataTable\n rows={participants}\n searchPlaceholder={config.labels.participantSearchPlaceholder}\n searchValue={participantSearch}\n setSearchValue={onParticipantSearchChange}\n title={config.labels.participantsTitle}\n >\n <ParticipantsTable rows={participants} labels={config.labels} />\n </DataTable>\n )}\n {config.features.showAgents && (\n <DataTable\n rows={agents}\n searchPlaceholder={config.labels.agentSearchPlaceholder}\n searchValue={agentSearch}\n setSearchValue={onAgentSearchChange}\n title={config.labels.agentsTitle}\n >\n <AgentsTable rows={agents} labels={config.labels} />\n </DataTable>\n )}\n </div>\n </div>\n );\n};\n\nfunction SectionHeading({ title }: { title: string }) {\n return <h3 className=\"text-lg font-semibold tracking-tight\">{title}</h3>;\n}\n\nfunction ActivityChart(props: {\n points: AdminActivityPoint[];\n interval: \"hour\" | \"day\";\n maxBars: number;\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n const trimmedPoints = props.points.slice(-props.maxBars);\n const maxMessages = Math.max(\n ...trimmedPoints.map((point) => point.messageCount),\n 1,\n );\n\n return (\n <div className=\"rounded-xl border bg-card p-5 shadow-sm\">\n {trimmedPoints.length === 0 ? (\n <p className=\"text-sm text-muted-foreground\">\n {props.labels.noResults}\n </p>\n ) : (\n <div className=\"flex min-h-48 items-end gap-2\">\n {trimmedPoints.map((point) => (\n <div\n className=\"flex min-w-0 flex-1 flex-col items-center gap-2\"\n key={point.bucket}\n >\n <div className=\"flex h-36 w-full items-end rounded-lg bg-muted px-1 pb-1\">\n <div\n className=\"w-full rounded-md bg-primary transition-all\"\n style={{\n height: `${Math.max((point.messageCount / maxMessages) * 100, 8)}%`,\n }}\n />\n </div>\n <div className=\"text-center\">\n <p className=\"text-xs font-medium\">\n {formatBucket(point.bucket, props.interval)}\n </p>\n <p className=\"text-[11px] text-muted-foreground\">\n {formatNumber(point.messageCount)} msg\n </p>\n </div>\n </div>\n ))}\n </div>\n )}\n </div>\n );\n}\n\nfunction DataTable<T>(props: {\n title: string;\n searchPlaceholder: string;\n searchValue: string;\n setSearchValue: (value: string) => void;\n rows: T[];\n children: React.ReactNode;\n}) {\n return (\n <div className=\"rounded-xl border bg-card p-5 shadow-sm\">\n <div className=\"mb-4 flex items-center justify-between gap-3\">\n <SectionHeading title={props.title} />\n <Input\n className=\"h-8 w-full max-w-44\"\n onChange={(event) => props.setSearchValue(event.target.value)}\n placeholder={props.searchPlaceholder}\n value={props.searchValue}\n />\n </div>\n {props.rows.length === 0 ? (\n <p className=\"text-sm text-muted-foreground\">No results</p>\n ) : (\n props.children\n )}\n </div>\n );\n}\n\nfunction ThreadsTable({\n rows,\n labels,\n onThreadClick,\n}: {\n rows: AdminThreadSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n onThreadClick?: (threadId: string) => void;\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((thread) => (\n <div\n className={cn(\n \"rounded-lg border bg-muted/50 p-4\",\n onThreadClick && \"cursor-pointer hover:bg-muted transition-colors\",\n )}\n key={thread.threadId}\n onClick={() => onThreadClick?.(thread.threadId)}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{thread.name}</p>\n <p className=\"mt-1 truncate text-xs text-muted-foreground\">\n {thread.summary ??\n thread.lastMessagePreview ??\n \"No summary yet\"}\n </p>\n </div>\n <Badge\n variant={\n thread.status === \"archived\" ? \"secondary\" : \"default\"\n }\n >\n {thread.status === \"archived\"\n ? labels.statusArchived\n : labels.statusActive}\n </Badge>\n </div>\n <div className=\"mt-3 flex flex-wrap gap-3 text-xs text-muted-foreground\">\n <span>{formatNumber(thread.messageCount)} messages</span>\n <span>{thread.participantIds.length} participants</span>\n <span>{formatDate(thread.lastActivityAt)}</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction ParticipantsTable({\n rows,\n labels,\n}: {\n rows: AdminParticipantSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((participant) => (\n <div\n className=\"rounded-lg border bg-muted/50 p-4\"\n key={`${participant.namespace}:${participant.externalId}`}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{participant.displayName}</p>\n <p className=\"mt-1 text-xs uppercase tracking-[0.18em] text-muted-foreground\">\n {participant.participantType}\n </p>\n </div>\n <Badge variant=\"outline\">\n {participant.isGlobal\n ? labels.scopeGlobal\n : labels.scopeScoped}\n </Badge>\n </div>\n <div className=\"mt-3 flex flex-wrap gap-3 text-xs text-muted-foreground\">\n <span>{formatNumber(participant.messageCount)} messages</span>\n <span>{formatNumber(participant.threadCount)} threads</span>\n <span>{formatDate(participant.lastActivityAt)}</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction AgentsTable({\n rows,\n labels,\n}: {\n rows: AdminAgentSummary[];\n labels: ResolvedAdminConfig[\"labels\"];\n}) {\n return (\n <div className=\"space-y-3\">\n {rows.map((agent) => (\n <div\n className=\"rounded-lg border bg-muted/50 p-4\"\n key={`${agent.namespace}:${agent.agentId}`}\n >\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"min-w-0\">\n <p className=\"font-medium\">{agent.displayName}</p>\n <p className=\"mt-1 truncate text-xs text-muted-foreground\">\n {agent.description ?? agent.agentId}\n </p>\n </div>\n <Badge variant=\"outline\">\n {agent.isConfigured\n ? labels.configured\n : labels.unconfigured}\n </Badge>\n </div>\n <div className=\"mt-3 grid grid-cols-2 gap-2 text-xs text-muted-foreground\">\n <span>{formatNumber(agent.messageCount)} messages</span>\n <span>{formatNumber(agent.llmCallCount)} LLM calls</span>\n <span>{formatNumber(agent.toolCallMessageCount)} tool calls</span>\n <span>{formatNumber(agent.totalTokens)} tokens</span>\n </div>\n </div>\n ))}\n </div>\n );\n}\n\nfunction formatBucket(bucket: string, interval: \"hour\" | \"day\") {\n const date = new Date(bucket);\n if (Number.isNaN(date.getTime())) return bucket;\n return interval === \"hour\"\n ? date.toLocaleString(undefined, {\n hour: \"numeric\",\n month: \"short\",\n day: \"numeric\",\n })\n : date.toLocaleDateString(undefined, {\n month: \"short\",\n day: \"numeric\",\n });\n}\n\nfunction formatDate(value: string | null) {\n if (!value) return \"No activity\";\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) return value;\n return date.toLocaleString(undefined, {\n month: \"short\",\n day: \"numeric\",\n hour: \"numeric\",\n minute: \"2-digit\",\n });\n}\n\nfunction formatNumber(value: number) {\n return new Intl.NumberFormat().format(value);\n}\n","import React from \"react\";\nimport { Search, MessageSquare } from \"lucide-react\";\nimport { Input } from \"../ui/input\";\nimport { Badge } from \"../ui/badge\";\nimport type { AdminThreadSummary, ResolvedAdminConfig } from \"../../types\";\n\ninterface ThreadsViewProps {\n config: ResolvedAdminConfig;\n threads: AdminThreadSummary[];\n searchValue: string;\n onSearchChange: (value: string) => void;\n onThreadClick?: (threadId: string) => void;\n}\n\nexport const ThreadsView: React.FC<ThreadsViewProps> = ({\n config,\n threads,\n searchValue,\n onSearchChange,\n onThreadClick,\n}) => {\n return (\n <div className=\"space-y-4\">\n {/* Search bar */}\n <div className=\"relative max-w-sm\">\n <Search className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n className=\"pl-9\"\n placeholder={config.labels.threadSearchPlaceholder}\n value={searchValue}\n onChange={(e) => onSearchChange(e.target.value)}\n />\n </div>\n\n {/* Thread list */}\n {threads.length === 0 ? (\n <div className=\"rounded-xl border border-dashed p-10 text-center\">\n <MessageSquare className=\"mx-auto h-8 w-8 text-muted-foreground/50\" />\n <p className=\"mt-3 text-sm text-muted-foreground\">\n {searchValue\n ? config.labels.noResults\n : config.labels.emptyDescription}\n </p>\n </div>\n ) : (\n <div className=\"space-y-2\">\n {threads.map((thread) => (\n <div\n key={thread.threadId}\n className=\"flex items-center gap-4 rounded-lg border bg-card p-4 transition-colors hover:bg-muted/50 cursor-pointer\"\n onClick={() => onThreadClick?.(thread.threadId)}\n >\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-2\">\n <p className=\"font-medium truncate\">{thread.name}</p>\n <Badge\n variant={\n thread.status === \"archived\" ? \"secondary\" : \"default\"\n }\n className=\"shrink-0\"\n >\n {thread.status === \"archived\"\n ? config.labels.statusArchived\n : config.labels.statusActive}\n </Badge>\n </div>\n <p className=\"mt-1 text-sm text-muted-foreground truncate\">\n {thread.summary ??\n thread.lastMessagePreview ??\n \"No summary yet\"}\n </p>\n </div>\n <div className=\"text-right text-xs text-muted-foreground shrink-0 space-y-1\">\n <p>{formatNumber(thread.messageCount)} messages</p>\n <p>{thread.participantIds.length} participants</p>\n <p>{formatDate(thread.lastActivityAt)}</p>\n </div>\n </div>\n ))}\n </div>\n )}\n </div>\n );\n};\n\nfunction formatDate(value: string | null) {\n if (!value) return \"No activity\";\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) return value;\n return date.toLocaleString(undefined, {\n month: \"short\",\n day: \"numeric\",\n hour: \"numeric\",\n minute: \"2-digit\",\n });\n}\n\nfunction formatNumber(value: number) {\n return new Intl.NumberFormat().format(value);\n}\n","import React, { useCallback, useEffect, useState } from \"react\";\nimport {\n ArrowLeft,\n Bot,\n ChevronUp,\n Loader2,\n User,\n Wrench,\n Cpu,\n} from \"lucide-react\";\nimport { Button } from \"../ui/button\";\nimport { Badge } from \"../ui/badge\";\nimport { cn } from \"../../lib/utils\";\nimport { fetchThreadDetail, fetchThreadMessages } from \"../../adminService\";\nimport type {\n AdminThreadDetail,\n AdminMessage,\n AdminMessagePageInfo,\n ResolvedAdminConfig,\n RequestHeadersProvider,\n} from \"../../types\";\n\ninterface ThreadDetailViewProps {\n threadId: string;\n config: ResolvedAdminConfig;\n onBack: () => void;\n}\n\nconst MESSAGES_PAGE_SIZE = 50;\n\nexport const ThreadDetailView: React.FC<ThreadDetailViewProps> = ({\n threadId,\n config,\n onBack,\n}) => {\n const [thread, setThread] = useState<AdminThreadDetail | null>(null);\n const [messages, setMessages] = useState<AdminMessage[]>([]);\n const [pageInfo, setPageInfo] = useState<AdminMessagePageInfo | null>(null);\n const [isLoading, setIsLoading] = useState(true);\n const [isLoadingMore, setIsLoadingMore] = useState(false);\n const [error, setError] = useState<Error | null>(null);\n\n const fetchOptions = {\n baseUrl: config.baseUrl,\n getRequestHeaders: config.getRequestHeaders,\n };\n\n const loadInitial = useCallback(async () => {\n setIsLoading(true);\n setError(null);\n try {\n const [threadData, messagesData] = await Promise.all([\n fetchThreadDetail(threadId, fetchOptions),\n fetchThreadMessages(threadId, { limit: MESSAGES_PAGE_SIZE }, fetchOptions),\n ]);\n setThread(threadData);\n setMessages(messagesData.data);\n setPageInfo(messagesData.pageInfo);\n } catch (err) {\n setError(\n err instanceof Error ? err : new Error(\"Failed to load thread\"),\n );\n } finally {\n setIsLoading(false);\n }\n }, [threadId, config.baseUrl, config.getRequestHeaders]);\n\n useEffect(() => {\n void loadInitial();\n }, [loadInitial]);\n\n const loadMore = useCallback(async () => {\n if (!pageInfo?.hasMoreBefore || !pageInfo.oldestMessageId || isLoadingMore) {\n return;\n }\n setIsLoadingMore(true);\n try {\n const older = await fetchThreadMessages(\n threadId,\n { limit: MESSAGES_PAGE_SIZE, before: pageInfo.oldestMessageId },\n fetchOptions,\n );\n setMessages((prev) => [...older.data, ...prev]);\n setPageInfo(older.pageInfo);\n } catch {\n // silently fail on pagination\n } finally {\n setIsLoadingMore(false);\n }\n }, [threadId, pageInfo, isLoadingMore, config.baseUrl, config.getRequestHeaders]);\n\n if (isLoading) {\n return (\n <div className=\"flex items-center justify-center py-20\">\n <Loader2 className=\"h-6 w-6 animate-spin text-muted-foreground\" />\n </div>\n );\n }\n\n if (error) {\n return (\n <div className=\"space-y-4 py-10 text-center\">\n <p className=\"text-destructive font-medium\">{error.message}</p>\n <div className=\"flex justify-center gap-2\">\n <Button variant=\"outline\" onClick={onBack}>\n <ArrowLeft className=\"mr-2 h-4 w-4\" />\n Back\n </Button>\n <Button variant=\"destructive\" onClick={() => void loadInitial()}>\n {config.labels.retry}\n </Button>\n </div>\n </div>\n );\n }\n\n return (\n <div className=\"space-y-6\">\n {/* Header */}\n <div className=\"flex items-start gap-4\">\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"mt-1 shrink-0\"\n onClick={onBack}\n >\n <ArrowLeft className=\"h-4 w-4\" />\n </Button>\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-2\">\n <h2 className=\"text-xl font-semibold truncate\">\n {thread?.name ?? threadId}\n </h2>\n <Badge\n variant={thread?.status === \"archived\" ? \"secondary\" : \"default\"}\n >\n {thread?.status === \"archived\"\n ? config.labels.statusArchived\n : config.labels.statusActive}\n </Badge>\n </div>\n {thread?.summary && (\n <p className=\"mt-1 text-sm text-muted-foreground\">\n {thread.summary}\n </p>\n )}\n <div className=\"mt-2 flex flex-wrap gap-4 text-xs text-muted-foreground\">\n {thread?.createdAt && (\n <span>Created {formatDate(thread.createdAt)}</span>\n )}\n {thread?.updatedAt && (\n <span>Updated {formatDate(thread.updatedAt)}</span>\n )}\n {thread?.participants && (\n <span>{thread.participants.length} participants</span>\n )}\n </div>\n </div>\n </div>\n\n {/* Messages */}\n <div className=\"space-y-1\">\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-sm font-medium text-muted-foreground\">\n Messages ({messages.length}\n {pageInfo?.hasMoreBefore ? \"+\" : \"\"})\n </h3>\n </div>\n\n {/* Load more */}\n {pageInfo?.hasMoreBefore && (\n <div className=\"flex justify-center py-2\">\n <Button\n variant=\"ghost\"\n size=\"sm\"\n onClick={() => void loadMore()}\n disabled={isLoadingMore}\n >\n {isLoadingMore ? (\n <Loader2 className=\"mr-2 h-3 w-3 animate-spin\" />\n ) : (\n <ChevronUp className=\"mr-2 h-3 w-3\" />\n )}\n Load older messages\n </Button>\n </div>\n )}\n\n {/* Message list */}\n <div className=\"rounded-lg border bg-card\">\n {messages.length === 0 ? (\n <p className=\"p-6 text-center text-sm text-muted-foreground\">\n No messages in this thread yet.\n </p>\n ) : (\n <div className=\"divide-y\">\n {messages.map((message) => (\n <MessageRow key={message.id} message={message} />\n ))}\n </div>\n )}\n </div>\n </div>\n </div>\n );\n};\n\nfunction MessageRow({ message }: { message: AdminMessage }) {\n const [expanded, setExpanded] = useState(false);\n const hasToolCalls =\n Array.isArray(message.toolCalls) && message.toolCalls.length > 0;\n const hasReasoning = !!message.reasoning;\n\n return (\n <div className=\"px-4 py-3\">\n <div className=\"flex items-start gap-3\">\n <SenderIcon senderType={message.senderType} />\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-2 text-xs\">\n <span className=\"font-medium\">\n {message.senderId ?? message.senderUserId ?? message.senderType}\n </span>\n <Badge variant=\"outline\" className=\"text-[10px] px-1.5 py-0\">\n {message.senderType}\n </Badge>\n {message.createdAt && (\n <span className=\"text-muted-foreground\">\n {formatTimestamp(message.createdAt)}\n </span>\n )}\n </div>\n\n {message.content && (\n <p className=\"mt-1 text-sm whitespace-pre-wrap break-words\">\n {message.content}\n </p>\n )}\n\n {(hasToolCalls || hasReasoning) && (\n <div className=\"mt-2 space-y-2\">\n {hasToolCalls && (\n <button\n type=\"button\"\n onClick={() => setExpanded(!expanded)}\n className=\"inline-flex items-center gap-1 text-xs text-muted-foreground hover:text-foreground transition-colors\"\n >\n <Wrench className=\"h-3 w-3\" />\n {(message.toolCalls as unknown[]).length} tool call\n {(message.toolCalls as unknown[]).length > 1 ? \"s\" : \"\"}\n </button>\n )}\n {hasReasoning && (\n <button\n type=\"button\"\n onClick={() => setExpanded(!expanded)}\n className=\"inline-flex items-center gap-1 text-xs text-muted-foreground hover:text-foreground transition-colors\"\n >\n <Cpu className=\"h-3 w-3\" />\n Reasoning\n </button>\n )}\n {expanded && (\n <pre className=\"mt-2 rounded-md bg-muted p-3 text-xs overflow-auto max-h-60\">\n {JSON.stringify(\n {\n ...(hasToolCalls ? { toolCalls: message.toolCalls } : {}),\n ...(hasReasoning ? { reasoning: message.reasoning } : {}),\n },\n null,\n 2,\n )}\n </pre>\n )}\n </div>\n )}\n </div>\n </div>\n </div>\n );\n}\n\nfunction SenderIcon({ senderType }: { senderType: string }) {\n const base =\n \"flex h-7 w-7 shrink-0 items-center justify-center rounded-full\";\n switch (senderType) {\n case \"agent\":\n return (\n <div className={cn(base, \"bg-primary/10 text-primary\")}>\n <Bot className=\"h-3.5 w-3.5\" />\n </div>\n );\n case \"user\":\n return (\n <div className={cn(base, \"bg-secondary text-secondary-foreground\")}>\n <User className=\"h-3.5 w-3.5\" />\n </div>\n );\n case \"tool\":\n return (\n <div className={cn(base, \"bg-muted text-muted-foreground\")}>\n <Wrench className=\"h-3.5 w-3.5\" />\n </div>\n );\n default:\n return (\n <div className={cn(base, \"bg-muted text-muted-foreground\")}>\n <Cpu className=\"h-3.5 w-3.5\" />\n </div>\n );\n }\n}\n\nfunction formatDate(value: string) {\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) return value;\n return date.toLocaleDateString(undefined, {\n month: \"short\",\n day: \"numeric\",\n year: \"numeric\",\n });\n}\n\nfunction formatTimestamp(value: string) {\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) return value;\n return date.toLocaleString(undefined, {\n month: \"short\",\n day: \"numeric\",\n hour: \"numeric\",\n minute: \"2-digit\",\n second: \"2-digit\",\n });\n}\n"],"mappings":"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","names":["useCallback","useMemo","useState","jsx","jsx","React","Slot","cva","jsx","React","jsx","jsxs","jsx","jsxs","jsx","jsx","jsxs","open","jsx","jsx","Slot","jsx","cva","Slot","jsxs","jsx","jsxs","Icon","React","jsx","jsxs","jsxs","jsx","jsx","jsxs","Slot","cva","jsx","cva","Slot","jsx","jsxs","MessageSquare","jsx","jsxs","MessageSquare","formatNumber","formatDate","useCallback","useEffect","useState","Bot","ChevronUp","jsx","jsxs","useState","useCallback","useEffect","formatDate","ChevronUp","Bot","jsx","jsxs","useMemo","useState","useCallback"]}
|