@ash-cloud/ash-ai 0.1.8

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.
Files changed (64) hide show
  1. package/dist/ash-widget.js +2 -0
  2. package/dist/ash-widget.js.map +1 -0
  3. package/dist/embed.cjs +19 -0
  4. package/dist/embed.cjs.map +1 -0
  5. package/dist/embed.d.cts +278 -0
  6. package/dist/embed.d.ts +278 -0
  7. package/dist/embed.js +16 -0
  8. package/dist/embed.js.map +1 -0
  9. package/dist/icons.cjs +156 -0
  10. package/dist/icons.cjs.map +1 -0
  11. package/dist/icons.d.cts +1 -0
  12. package/dist/icons.d.ts +1 -0
  13. package/dist/icons.js +3 -0
  14. package/dist/icons.js.map +1 -0
  15. package/dist/index-DJwpy-R5.js +6797 -0
  16. package/dist/index.cjs +17502 -0
  17. package/dist/index.cjs.map +1 -0
  18. package/dist/index.d.cts +9590 -0
  19. package/dist/index.d.ts +9590 -0
  20. package/dist/index.js +17328 -0
  21. package/dist/index.js.map +1 -0
  22. package/dist/playground/App.d.ts +2 -0
  23. package/dist/playground/App.d.ts.map +1 -0
  24. package/dist/playground/Playground.d.ts +62 -0
  25. package/dist/playground/Playground.d.ts.map +1 -0
  26. package/dist/playground/components/ChatInput.d.ts +60 -0
  27. package/dist/playground/components/ChatInput.d.ts.map +1 -0
  28. package/dist/playground/components/MessageList.d.ts +28 -0
  29. package/dist/playground/components/MessageList.d.ts.map +1 -0
  30. package/dist/playground/components/NormalizedMessageList.d.ts +26 -0
  31. package/dist/playground/components/NormalizedMessageList.d.ts.map +1 -0
  32. package/dist/playground/components/SandboxLogsPanel.d.ts +16 -0
  33. package/dist/playground/components/SandboxLogsPanel.d.ts.map +1 -0
  34. package/dist/playground/components/Sidebar.d.ts +7 -0
  35. package/dist/playground/components/Sidebar.d.ts.map +1 -0
  36. package/dist/playground/components/ToolCallCard.d.ts +9 -0
  37. package/dist/playground/components/ToolCallCard.d.ts.map +1 -0
  38. package/dist/playground/components/icons.d.ts +9 -0
  39. package/dist/playground/components/icons.d.ts.map +1 -0
  40. package/dist/playground/contexts/ThemeContext.d.ts +9 -0
  41. package/dist/playground/contexts/ThemeContext.d.ts.map +1 -0
  42. package/dist/playground/index.d.ts +30 -0
  43. package/dist/playground/index.d.ts.map +1 -0
  44. package/dist/playground/main.d.ts +1 -0
  45. package/dist/playground/main.d.ts.map +1 -0
  46. package/dist/playground/pages/AgentsPage.d.ts +2 -0
  47. package/dist/playground/pages/AgentsPage.d.ts.map +1 -0
  48. package/dist/playground/pages/ChatPage.d.ts +2 -0
  49. package/dist/playground/pages/ChatPage.d.ts.map +1 -0
  50. package/dist/playground/pages/SessionsPage.d.ts +2 -0
  51. package/dist/playground/pages/SessionsPage.d.ts.map +1 -0
  52. package/dist/playground.css +1 -0
  53. package/dist/playground.d.ts +18 -0
  54. package/dist/playground.d.ts.map +1 -0
  55. package/dist/playground.js +3753 -0
  56. package/dist/schema-B_CVsJm5.d.cts +1585 -0
  57. package/dist/schema-B_CVsJm5.d.ts +1585 -0
  58. package/dist/schema.cjs +254 -0
  59. package/dist/schema.cjs.map +1 -0
  60. package/dist/schema.d.cts +3 -0
  61. package/dist/schema.d.ts +3 -0
  62. package/dist/schema.js +235 -0
  63. package/dist/schema.js.map +1 -0
  64. package/package.json +108 -0
@@ -0,0 +1,2 @@
1
+ export declare function App(): import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=App.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"App.d.ts","sourceRoot":"","sources":["../../src/playground/App.tsx"],"names":[],"mappings":"AAQA,wBAAgB,GAAG,4CAyBlB"}
@@ -0,0 +1,62 @@
1
+ export interface Message {
2
+ id: string;
3
+ role: 'user' | 'assistant' | 'tool' | 'system';
4
+ content: Array<{
5
+ type: string;
6
+ text?: string;
7
+ name?: string;
8
+ input?: unknown;
9
+ toolUseId?: string;
10
+ content?: unknown;
11
+ }>;
12
+ createdAt: string;
13
+ }
14
+ export interface Agent {
15
+ name: string;
16
+ slug: string;
17
+ model: string;
18
+ description?: string;
19
+ systemPrompt?: string;
20
+ }
21
+ /** Backend queue item status */
22
+ export interface BackendQueueItem {
23
+ id: string;
24
+ sessionId: string | null;
25
+ agentName: string;
26
+ prompt: string;
27
+ status: 'pending' | 'processing' | 'completed' | 'failed' | 'cancelled';
28
+ priority: number;
29
+ createdAt: string;
30
+ error?: string;
31
+ }
32
+ export interface PlaygroundProps {
33
+ /**
34
+ * Base path for API calls (e.g., "/projects/my-project/playground/api")
35
+ * All harness API calls will be made relative to this path.
36
+ */
37
+ apiBasePath: string;
38
+ /**
39
+ * Initial agent to select (by slug or name)
40
+ */
41
+ initialAgent?: string;
42
+ /**
43
+ * Initial session ID to resume
44
+ */
45
+ initialSessionId?: string;
46
+ /**
47
+ * Callback when session changes
48
+ */
49
+ onSessionChange?: (sessionId: string | null) => void;
50
+ /**
51
+ * Custom class name for the container
52
+ */
53
+ className?: string;
54
+ /**
55
+ * Whether to use backend queue for message processing.
56
+ * When true, messages are queued in the backend and processed asynchronously.
57
+ * When false (default), messages are sent directly to the agent.
58
+ */
59
+ useBackendQueue?: boolean;
60
+ }
61
+ export declare function Playground({ apiBasePath, initialAgent, initialSessionId, onSessionChange, className, useBackendQueue, }: PlaygroundProps): import("react/jsx-runtime").JSX.Element;
62
+ //# sourceMappingURL=Playground.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Playground.d.ts","sourceRoot":"","sources":["../../src/playground/Playground.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,MAAM,GAAG,QAAQ,CAAC;IAC/C,OAAO,EAAE,KAAK,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,CAAC,CAAC;IACH,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,KAAK;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,gCAAgC;AAChC,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,SAAS,GAAG,YAAY,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,CAAC;IACxE,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B;;;OAGG;IACH,WAAW,EAAE,MAAM,CAAC;IAEpB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB;;OAEG;IACH,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B;;OAEG;IACH,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAErD;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;;;OAIG;IACH,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,wBAAgB,UAAU,CAAC,EACzB,WAAW,EACX,YAAY,EACZ,gBAAgB,EAChB,eAAe,EACf,SAAc,EACd,eAAuB,GACxB,EAAE,eAAe,2CAkgBjB"}
@@ -0,0 +1,60 @@
1
+ export interface QueuedMessage {
2
+ id: string;
3
+ text: string;
4
+ }
5
+ /** File attachment for upload */
6
+ export interface FileAttachment {
7
+ /** Original filename */
8
+ filename: string;
9
+ /** Base64-encoded file content */
10
+ content: string;
11
+ /** MIME type of the file */
12
+ mimeType: string;
13
+ /** File size in bytes */
14
+ size: number;
15
+ }
16
+ /** Info about a long text that was auto-converted to an attachment */
17
+ export interface LongTextConversionInfo {
18
+ /** Original text length in characters */
19
+ originalLength: number;
20
+ /** Generated filename */
21
+ filename: string;
22
+ /** Preview of the text (first 100 chars) */
23
+ preview: string;
24
+ /** Number of lines in the pasted text */
25
+ lineCount: number;
26
+ }
27
+ interface ChatInputProps {
28
+ onSend: (message: string, files?: FileAttachment[]) => void;
29
+ disabled?: boolean;
30
+ loading?: boolean;
31
+ placeholder?: string;
32
+ queue?: QueuedMessage[];
33
+ onCancelQueued?: (id: string) => void;
34
+ /** Current session context value */
35
+ sessionContext?: string;
36
+ /** Callback when session context changes */
37
+ onSessionContextChange?: (context: string) => void;
38
+ /** Current environment variables */
39
+ envVars?: Record<string, string>;
40
+ /** Callback when environment variables change */
41
+ onEnvVarsChange?: (envVars: Record<string, string>) => void;
42
+ /** Enable file uploads (default: true) */
43
+ enableFileUpload?: boolean;
44
+ /** Maximum file size in bytes (default: 100MB) */
45
+ maxFileSize?: number;
46
+ /** Maximum number of files (default: 10) */
47
+ maxFiles?: number;
48
+ /** Callback to stop the current execution */
49
+ onStop?: () => void;
50
+ /** Whether the current execution can be stopped */
51
+ canStop?: boolean;
52
+ /** Enable auto-conversion of long pasted text to attachments (default: true) */
53
+ enableLongTextConversion?: boolean;
54
+ /** Character threshold for auto-conversion (default: 5000) */
55
+ longTextThreshold?: number;
56
+ }
57
+ export declare function ChatInput({ onSend, disabled, loading, placeholder, queue, onCancelQueued, sessionContext, onSessionContextChange, envVars, onEnvVarsChange, enableFileUpload, maxFileSize, // 100MB
58
+ maxFiles, onStop, canStop, enableLongTextConversion, longTextThreshold, }: ChatInputProps): import("react/jsx-runtime").JSX.Element;
59
+ export {};
60
+ //# sourceMappingURL=ChatInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChatInput.d.ts","sourceRoot":"","sources":["../../../src/playground/components/ChatInput.tsx"],"names":[],"mappings":"AAEA,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd;AAKD,iCAAiC;AACjC,MAAM,WAAW,cAAc;IAC7B,wBAAwB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,kCAAkC;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,4BAA4B;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,yBAAyB;IACzB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,sEAAsE;AACtE,MAAM,WAAW,sBAAsB;IACrC,yCAAyC;IACzC,cAAc,EAAE,MAAM,CAAC;IACvB,yBAAyB;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,4CAA4C;IAC5C,OAAO,EAAE,MAAM,CAAC;IAChB,yCAAyC;IACzC,SAAS,EAAE,MAAM,CAAC;CACnB;AAUD,UAAU,cAAc;IACtB,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,cAAc,EAAE,KAAK,IAAI,CAAC;IAC5D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;IACxB,cAAc,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,oCAAoC;IACpC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,4CAA4C;IAC5C,sBAAsB,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IACnD,oCAAoC;IACpC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,iDAAiD;IACjD,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,IAAI,CAAC;IAC5D,0CAA0C;IAC1C,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,kDAAkD;IAClD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,4CAA4C;IAC5C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,mDAAmD;IACnD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,gFAAgF;IAChF,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,8DAA8D;IAC9D,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AASD,wBAAgB,SAAS,CAAC,EACxB,MAAM,EACN,QAAQ,EACR,OAAO,EACP,WAAoC,EACpC,KAAU,EACV,cAAc,EACd,cAAmB,EACnB,sBAAsB,EACtB,OAAY,EACZ,eAAe,EACf,gBAAuB,EACvB,WAA+B,EAAE,QAAQ;AACzC,QAAa,EACb,MAAM,EACN,OAAe,EACf,wBAA+B,EAC/B,iBAAuC,GACxC,EAAE,cAAc,2CA6pBhB"}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Legacy MessageList Component
3
+ *
4
+ * This is a backward-compatible component for consumers who were using
5
+ * the old MessageList interface. For new implementations, use the
6
+ * MessageList or NormalizedMessageList from @ash-cloud/ash-ui.
7
+ */
8
+ interface Message {
9
+ id: string;
10
+ role: 'user' | 'assistant' | 'tool' | 'system';
11
+ content: Array<{
12
+ type: string;
13
+ text?: string;
14
+ name?: string;
15
+ input?: unknown;
16
+ toolUseId?: string;
17
+ content?: unknown;
18
+ }>;
19
+ createdAt: string;
20
+ }
21
+ interface MessageListProps {
22
+ messages: Message[];
23
+ loading?: boolean;
24
+ streamingContent?: string;
25
+ }
26
+ export declare function MessageList({ messages, loading, streamingContent, }: MessageListProps): import("react/jsx-runtime").JSX.Element;
27
+ export {};
28
+ //# sourceMappingURL=MessageList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageList.d.ts","sourceRoot":"","sources":["../../../src/playground/components/MessageList.tsx"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,UAAU,OAAO;IACf,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,MAAM,GAAG,QAAQ,CAAC;IAC/C,OAAO,EAAE,KAAK,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,CAAC,CAAC;IACH,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,gBAAgB;IACxB,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,wBAAgB,WAAW,CAAC,EAC1B,QAAQ,EACR,OAAO,EACP,gBAAgB,GACjB,EAAE,gBAAgB,2CA4ClB"}
@@ -0,0 +1,26 @@
1
+ import { NormalizedEntry, ToolDisplayConfig } from '@ash-cloud/ash-ui';
2
+ export interface NormalizedMessageListProps {
3
+ /** Normalized conversation entries to display */
4
+ entries: NormalizedEntry[];
5
+ /** Whether a response is currently loading */
6
+ loading?: boolean;
7
+ /** Streaming text content (displayed during real-time streaming) */
8
+ streamingContent?: string;
9
+ /** Display configuration for tool calls */
10
+ displayConfig?: ToolDisplayConfig;
11
+ /** Callback when user selects an option from assistant message */
12
+ onOptionSelect?: (optionText: string) => void;
13
+ }
14
+ /**
15
+ * NormalizedMessageList - Wrapper around ash-ui's MessageList for harness compatibility
16
+ *
17
+ * This component re-exports the ash-ui MessageList with the same interface
18
+ * for backward compatibility with existing harness consumers.
19
+ *
20
+ * Supports display modes:
21
+ * - 'inline': Each tool call rendered as individual expandable cards (default)
22
+ * - 'compact': Consecutive tool calls grouped with animated status line
23
+ */
24
+ export declare function NormalizedMessageList({ entries, loading, streamingContent, displayConfig, onOptionSelect, }: NormalizedMessageListProps): import("react/jsx-runtime").JSX.Element;
25
+ export default NormalizedMessageList;
26
+ //# sourceMappingURL=NormalizedMessageList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NormalizedMessageList.d.ts","sourceRoot":"","sources":["../../../src/playground/components/NormalizedMessageList.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,eAAe,EACpB,KAAK,iBAAiB,EACvB,MAAM,mBAAmB,CAAC;AAM3B,MAAM,WAAW,0BAA0B;IACzC,iDAAiD;IACjD,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,8CAA8C;IAC9C,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,oEAAoE;IACpE,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,2CAA2C;IAC3C,aAAa,CAAC,EAAE,iBAAiB,CAAC;IAClC,kEAAkE;IAClE,cAAc,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;CAC/C;AAMD;;;;;;;;;GASG;AACH,wBAAgB,qBAAqB,CAAC,EACpC,OAAO,EACP,OAAO,EACP,gBAAgB,EAChB,aAAa,EACb,cAAc,GACf,EAAE,0BAA0B,2CAU5B;AAED,eAAe,qBAAqB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { SandboxLogEntry, SandboxLogLevel, SandboxLogCategory } from '../../types/index.js';
2
+ export type { SandboxLogEntry, SandboxLogLevel, SandboxLogCategory };
3
+ export interface SandboxLogsPanelProps {
4
+ logs: SandboxLogEntry[];
5
+ isLoading?: boolean;
6
+ className?: string;
7
+ }
8
+ /**
9
+ * SandboxLogsPanel - Display sandbox/execution logs
10
+ *
11
+ * This is a wrapper around the ash-ui LogsPanel that provides backward
12
+ * compatibility with the existing SandboxLogsPanel interface.
13
+ */
14
+ export declare function SandboxLogsPanel({ logs, isLoading, className }: SandboxLogsPanelProps): import("react/jsx-runtime").JSX.Element;
15
+ export default SandboxLogsPanel;
16
+ //# sourceMappingURL=SandboxLogsPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SandboxLogsPanel.d.ts","sourceRoot":"","sources":["../../../src/playground/components/SandboxLogsPanel.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAGjG,YAAY,EAAE,eAAe,EAAE,eAAe,EAAE,kBAAkB,EAAE,CAAC;AAErE,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,eAAe,EAAE,CAAC;IACxB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAMD;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,qBAAqB,2CAYrF;AAED,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,7 @@
1
+ interface SidebarProps {
2
+ open: boolean;
3
+ onToggle: () => void;
4
+ }
5
+ export declare function Sidebar({ open, onToggle }: SidebarProps): import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=Sidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sidebar.d.ts","sourceRoot":"","sources":["../../../src/playground/components/Sidebar.tsx"],"names":[],"mappings":"AAEA,UAAU,YAAY;IACpB,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAgCD,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,YAAY,2CAqEvD"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * ToolCallCard - Re-exported from @ash-cloud/ash-ui
3
+ *
4
+ * This file re-exports the ToolCallCard component from ash-ui
5
+ * for backward compatibility with existing harness consumers.
6
+ */
7
+ export { ToolCallCard } from '@ash-cloud/ash-ui';
8
+ export type { ToolCallCardProps } from '@ash-cloud/ash-ui';
9
+ //# sourceMappingURL=ToolCallCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToolCallCard.d.ts","sourceRoot":"","sources":["../../../src/playground/components/ToolCallCard.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,YAAY,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Shared Icon Components - Re-exported from @ash-cloud/ash-ui
3
+ *
4
+ * Icons are now provided by ash-ui. This file re-exports them
5
+ * for backward compatibility with existing harness consumers.
6
+ */
7
+ export { SunIcon, MoonIcon, ChevronDownIcon, ChevronRightIcon, ChevronLeftIcon, ChevronUpIcon, TerminalIcon, FileIcon, EditIcon, FilePlusIcon, SearchIcon, GlobeIcon, PlugIcon, ToolIcon, FolderSearchIcon, CodeIcon, CopyIcon, CheckIcon, XIcon, LoaderIcon, InfoIcon, AlertTriangleIcon, AlertCircleIcon, BugIcon, CheckCircleIcon, XCircleIcon, SendIcon, PaperclipIcon, StopCircleIcon, MessageSquareIcon, SparklesIcon, BrainIcon, } from '@ash-cloud/ash-ui';
8
+ export type { IconProps } from '@ash-cloud/ash-ui';
9
+ //# sourceMappingURL=icons.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.d.ts","sourceRoot":"","sources":["../../../src/playground/components/icons.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAEL,OAAO,EACP,QAAQ,EACR,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,aAAa,EAGb,YAAY,EACZ,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,UAAU,EACV,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,gBAAgB,EAChB,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,KAAK,EACL,UAAU,EAGV,QAAQ,EACR,iBAAiB,EACjB,eAAe,EACf,OAAO,EACP,eAAe,EACf,WAAW,EAGX,QAAQ,EACR,aAAa,EACb,cAAc,EACd,iBAAiB,EACjB,YAAY,EACZ,SAAS,GACV,MAAM,mBAAmB,CAAC;AAE3B,YAAY,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * ThemeContext - Re-exported from @ash-cloud/ash-ui
3
+ *
4
+ * Theme management is now provided by ash-ui. This file re-exports it
5
+ * for backward compatibility with existing harness consumers.
6
+ */
7
+ export { ThemeProvider, useTheme } from '@ash-cloud/ash-ui';
8
+ export type { Theme, ThemeContextType, ThemeProviderProps } from '@ash-cloud/ash-ui';
9
+ //# sourceMappingURL=ThemeContext.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemeContext.d.ts","sourceRoot":"","sources":["../../../src/playground/contexts/ThemeContext.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Harness Playground - React components for agent chat UI
3
+ *
4
+ * This package provides embeddable React components for building
5
+ * chat interfaces that work with the harness API.
6
+ *
7
+ * Core UI components are now provided by @ash-cloud/ash-ui,
8
+ * re-exported here for convenience.
9
+ */
10
+ export { ToolCallCard, MessageList, MessageEntry, UserMessage, AssistantMessage, ThinkingMessage, ToolCallMessage, ErrorMessage, LogsPanel, StatusIndicator, ActionIcon, CodeBlock, JsonDisplay, StreamingText, LoadingIndicator, ThemeProvider, useTheme, } from '@ash-cloud/ash-ui';
11
+ export type { ToolCallCardProps, MessageListProps, MessageEntryProps, UserMessageProps, AssistantMessageProps, ThinkingMessageProps, ToolCallMessageProps, ErrorMessageProps, LogsPanelProps, StatusIndicatorProps, ActionIconProps, CodeBlockProps, JsonDisplayProps, StreamingTextProps, LoadingIndicatorProps, Theme, ThemeContextType, ThemeProviderProps, } from '@ash-cloud/ash-ui';
12
+ export { SunIcon, MoonIcon, ChevronDownIcon, ChevronRightIcon, ChevronLeftIcon, ChevronUpIcon, TerminalIcon, FileIcon, EditIcon, FilePlusIcon, SearchIcon, GlobeIcon, PlugIcon, ToolIcon, FolderSearchIcon, CodeIcon, CopyIcon, CheckIcon, XIcon, LoaderIcon, InfoIcon, AlertTriangleIcon, AlertCircleIcon, BugIcon, CheckCircleIcon, XCircleIcon, SendIcon, PaperclipIcon, StopCircleIcon, MessageSquareIcon, SparklesIcon, BrainIcon, } from '@ash-cloud/ash-ui';
13
+ export type { IconProps } from '@ash-cloud/ash-ui';
14
+ export type { ToolStatus, ActionType, CommandRunAction, FileReadAction, FileEditAction, FileWriteAction, SearchAction, GlobAction, WebFetchAction, WebSearchAction, McpToolAction, GenericToolAction, CommandRunResult, ToolResult, NormalizedToolCall, NormalizedEntry, NormalizedEntryType, UserMessageEntry, AssistantMessageEntry, ThinkingEntry, ToolCallEntry, ErrorEntry, LogLevel, LogCategory, LogEntry, FileAttachment, } from '@ash-cloud/ash-ui';
15
+ export { isCommandRunAction, isFileReadAction, isFileEditAction, isFileWriteAction, isSearchAction, isGlobAction, isWebFetchAction, isWebSearchAction, isMcpToolAction, isGenericToolAction, isToolCallEntry, isErrorEntry, } from '@ash-cloud/ash-ui';
16
+ export { formatToolName, parseMcpToolName, mapToolToActionType, generateToolSummary, extractTextContent, normalizeToolResult, parseCommandResult, createToolCall, updateToolCallWithResult, getActionIcon, getActionLabel, formatFileSize, formatTimestamp, truncate, cn, } from '@ash-cloud/ash-ui';
17
+ export type { ToolUseInput } from '@ash-cloud/ash-ui';
18
+ export { Playground } from './Playground';
19
+ export type { PlaygroundProps, Agent, Message } from './Playground';
20
+ export { ChatInput } from './components/ChatInput';
21
+ export type { QueuedMessage } from './components/ChatInput';
22
+ export { MessageList as LegacyMessageList } from './components/MessageList';
23
+ export { NormalizedMessageList } from './components/NormalizedMessageList';
24
+ export type { NormalizedMessageListProps } from './components/NormalizedMessageList';
25
+ export { SandboxLogsPanel } from './components/SandboxLogsPanel';
26
+ export type { SandboxLogsPanelProps, SandboxLogEntry, SandboxLogLevel, SandboxLogCategory, } from './components/SandboxLogsPanel';
27
+ export { normalizeMessages, } from '../utils/normalize-messages.js';
28
+ export { ToolCallProcessor, createToolCallProcessor, } from '../utils/tool-call-processor.js';
29
+ export type { EntryListener } from '../utils/tool-call-processor.js';
30
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/playground/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,EACL,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,WAAW,EACX,gBAAgB,EAChB,eAAe,EACf,eAAe,EACf,YAAY,EACZ,SAAS,EACT,eAAe,EACf,UAAU,EACV,SAAS,EACT,WAAW,EACX,aAAa,EACb,gBAAgB,EAChB,aAAa,EACb,QAAQ,GACT,MAAM,mBAAmB,CAAC;AAE3B,YAAY,EACV,iBAAiB,EACjB,gBAAgB,EAChB,iBAAiB,EACjB,gBAAgB,EAChB,qBAAqB,EACrB,oBAAoB,EACpB,oBAAoB,EACpB,iBAAiB,EACjB,cAAc,EACd,oBAAoB,EACpB,eAAe,EACf,cAAc,EACd,gBAAgB,EAChB,kBAAkB,EAClB,qBAAqB,EACrB,KAAK,EACL,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EACL,OAAO,EACP,QAAQ,EACR,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,aAAa,EACb,YAAY,EACZ,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,UAAU,EACV,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,gBAAgB,EAChB,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,KAAK,EACL,UAAU,EACV,QAAQ,EACR,iBAAiB,EACjB,eAAe,EACf,OAAO,EACP,eAAe,EACf,WAAW,EACX,QAAQ,EACR,aAAa,EACb,cAAc,EACd,iBAAiB,EACjB,YAAY,EACZ,SAAS,GACV,MAAM,mBAAmB,CAAC;AAE3B,YAAY,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAGnD,YAAY,EACV,UAAU,EACV,UAAU,EACV,gBAAgB,EAChB,cAAc,EACd,cAAc,EACd,eAAe,EACf,YAAY,EACZ,UAAU,EACV,cAAc,EACd,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,gBAAgB,EAChB,UAAU,EACV,kBAAkB,EAClB,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,qBAAqB,EACrB,aAAa,EACb,aAAa,EACb,UAAU,EACV,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,cAAc,GACf,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,gBAAgB,EAChB,iBAAiB,EACjB,cAAc,EACd,YAAY,EACZ,gBAAgB,EAChB,iBAAiB,EACjB,eAAe,EACf,mBAAmB,EACnB,eAAe,EACf,YAAY,GACb,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EACL,cAAc,EACd,gBAAgB,EAChB,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,kBAAkB,EAClB,cAAc,EACd,wBAAwB,EACxB,aAAa,EACb,cAAc,EACd,cAAc,EACd,eAAe,EACf,QAAQ,EACR,EAAE,GACH,MAAM,mBAAmB,CAAC;AAE3B,YAAY,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAOtD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,YAAY,EAAE,eAAe,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAGpE,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,YAAY,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAG5D,OAAO,EAAE,WAAW,IAAI,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAG5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,YAAY,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AAGrF,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,YAAY,EACV,qBAAqB,EACrB,eAAe,EACf,eAAe,EACf,kBAAkB,GACnB,MAAM,+BAA+B,CAAC;AAOvC,OAAO,EACL,iBAAiB,GAClB,MAAM,gCAAgC,CAAC;AAGxC,OAAO,EACL,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,iCAAiC,CAAC;AACzC,YAAY,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAGrE,OAAO,aAAa,CAAC"}
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=main.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../../src/playground/main.tsx"],"names":[],"mappings":"AAGA,OAAO,aAAa,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function AgentsPage(): import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=AgentsPage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentsPage.d.ts","sourceRoot":"","sources":["../../../src/playground/pages/AgentsPage.tsx"],"names":[],"mappings":"AAoBA,wBAAgB,UAAU,4CAsHzB"}
@@ -0,0 +1,2 @@
1
+ export declare function ChatPage(): import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=ChatPage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChatPage.d.ts","sourceRoot":"","sources":["../../../src/playground/pages/ChatPage.tsx"],"names":[],"mappings":"AAqCA,wBAAgB,QAAQ,4CAsoBvB"}
@@ -0,0 +1,2 @@
1
+ export declare function SessionsPage(): import("react/jsx-runtime").JSX.Element;
2
+ //# sourceMappingURL=SessionsPage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SessionsPage.d.ts","sourceRoot":"","sources":["../../../src/playground/pages/SessionsPage.tsx"],"names":[],"mappings":"AAwBA,wBAAgB,YAAY,4CA8N3B"}
@@ -0,0 +1 @@
1
+ *,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-left-20{left:-5rem}.-left-\[10\%\]{left:-10%}.-left-\[15\%\]{left:-15%}.-right-\[10\%\]{right:-10%}.-right-\[5\%\]{right:-5%}.-top-20{top:-5rem}.-top-\[15\%\]{top:-15%}.-top-\[20\%\]{top:-20%}.bottom-\[10\%\]{bottom:10%}.bottom-\[20\%\]{bottom:20%}.left-4{left:1rem}.top-0{top:0}.top-4{top:1rem}.z-0{z-index:0}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[25vw\]{height:25vw}.h-\[30vw\]{height:30vw}.h-\[40vw\]{height:40vw}.h-full{height:100%}.h-screen{height:100vh}.max-h-32{max-height:8rem}.min-h-full{min-height:100%}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-40{width:10rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[25vw\]{width:25vw}.w-\[30vw\]{width:30vw}.w-\[40vw\]{width:40vw}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-\[120px\]{max-width:120px}.max-w-\[150px\]{max-width:150px}.max-w-\[80\%\]{max-width:80%}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.flex-1{flex:1 1 0%}.flex-\[2\]{flex:2}.shrink-0{flex-shrink:0}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-white\/5>:not([hidden])~:not([hidden]){border-color:#ffffff0d}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-2{border-left-width:2px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[\#ccff00\]{--tw-border-opacity: 1;border-color:rgb(204 255 0 / var(--tw-border-opacity, 1))}.border-\[\#ccff00\]\/20{border-color:#cf03}.border-\[\#ccff00\]\/50{border-color:#ccff0080}.border-blue-500\/30{border-color:#3b82f64d}.border-emerald-500\/20{border-color:#10b98133}.border-purple-500\/30{border-color:#a855f74d}.border-red-400\/30{border-color:#f871714d}.border-red-500\/20{border-color:#ef444433}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.border-yellow-400\/30{border-color:#facc154d}.border-yellow-500\/20{border-color:#eab30833}.bg-\[\#0a0a0a\]{--tw-bg-opacity: 1;background-color:rgb(10 10 10 / var(--tw-bg-opacity, 1))}.bg-\[\#ccff00\]{--tw-bg-opacity: 1;background-color:rgb(204 255 0 / var(--tw-bg-opacity, 1))}.bg-\[\#ccff00\]\/10{background-color:#ccff001a}.bg-\[\#ccff00\]\/20{background-color:#cf03}.bg-\[\#ccff00\]\/5{background-color:#ccff000d}.bg-black\/40{background-color:#0006}.bg-blue-500\/10{background-color:#3b82f61a}.bg-emerald-500\/10{background-color:#10b9811a}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-purple-500\/10{background-color:#a855f71a}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/80{background-color:#ef4444cc}.bg-white\/10{background-color:#ffffff1a}.bg-white\/5{background-color:#ffffff0d}.bg-yellow-500\/10{background-color:#eab3081a}.bg-yellow-500\/80{background-color:#eab308cc}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-\[\#ccff00\]{--tw-text-opacity: 1;color:rgb(204 255 0 / var(--tw-text-opacity, 1))}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-black\/40{color:#0006}.text-black\/60{color:#0009}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity, 1))}.text-blue-300\/70{color:#93c5fdb3}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-blue-400\/70{color:#60a5fab3}.text-emerald-300\/80{color:#6ee7b7cc}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-purple-200{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-purple-400\/70{color:#c084fcb3}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-400\/70{color:#f87171b3}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/20{color:#fff3}.text-white\/40{color:#fff6}.text-white\/50{color:#ffffff80}.text-white\/60{color:#fff9}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.text-yellow-400\/70{color:#facc15b3}.shadow-\[0_0_15px_rgba\(204\,255\,0\,0\.4\)\]{--tw-shadow: 0 0 15px rgba(204,255,0,.4);--tw-shadow-colored: 0 0 15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_20px_rgba\(204\,255\,0\,0\.1\)\]{--tw-shadow: 0 0 20px rgba(204,255,0,.1);--tw-shadow-colored: 0 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_20px_rgba\(204\,255\,0\,0\.2\)\]{--tw-shadow: 0 0 20px rgba(204,255,0,.2);--tw-shadow-colored: 0 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_20px_rgba\(204\,255\,0\,0\.3\)\]{--tw-shadow: 0 0 20px rgba(204,255,0,.3);--tw-shadow-colored: 0 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--accent: #ccff00;--accent-50: #f8ffe5;--accent-100: #eeffb8;--accent-200: #e0ff85;--accent-300: #d4ff52;--accent-400: #ccff00;--accent-500: #b8e600;--accent-600: #99cc00;--accent-700: #739900;--accent-800: #4d6600;--accent-900: #263300;--surface-dark: #0a0a0a;--surface-darker: #050505;--surface-card: #0c0c0c;--surface-elevated: #111111;--surface-border: rgba(255, 255, 255, .1)}body{--tw-bg-opacity: 1;background-color:rgb(10 10 10 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1));font-feature-settings:"rlig" 1,"calt" 1}.dark body{--tw-bg-opacity: 1;background-color:rgb(10 10 10 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.glass-panel{border-width:1px;border-color:#ffffff1a;background-color:#ffffff0d;--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-backdrop-blur: blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.glass-panel-elevated{background-color:#ffffff14;border-width:1px;--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-backdrop-blur: blur(40px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);border-color:#ffffff26}.card-glass{border-radius:1rem;border-width:1px;border-color:#ffffff1a;background-color:#ffffff0d;--tw-backdrop-blur: blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.card-glass:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);border-color:#fff3;background-color:#ffffff14}.btn-accent{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(204 255 0 / var(--tw-bg-opacity, 1));padding:.75rem 1.5rem;font-weight:500;--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1));border-width:1px;--tw-border-opacity: 1;border-color:rgb(204 255 0 / var(--tw-border-opacity, 1));box-shadow:0 0 20px #ccff004d;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-accent:hover{--tw-bg-opacity: 1;background-color:rgb(184 230 0 / var(--tw-bg-opacity, 1));box-shadow:0 0 30px #ccff0080}.btn-ghost{border-radius:.75rem;padding:.5rem 1rem;color:#ffffffb3}.btn-ghost:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.btn-ghost{border-width:1px;border-color:transparent;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-ghost:hover{background-color:#ffffff1a;border-color:#ffffff1a}.btn-outline{border-radius:.75rem;border-width:1px;border-color:#fff3;padding:.5rem 1rem;color:#fffc;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-outline:hover{border-color:#ffffff4d;background-color:#ffffff1a}.input-glass{width:100%;border-radius:.75rem;padding:.75rem 1rem;border-width:1px;border-color:#ffffff1a;background-color:#ffffff0d;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.input-glass::-moz-placeholder{color:#fff6}.input-glass::placeholder{color:#fff6}.input-glass:focus{border-color:#ccff0080;background-color:#ffffff1a;outline:2px solid transparent;outline-offset:2px}.input-glass{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.input-glass:focus{box-shadow:0 0 20px #ccff0026}.message-content pre{margin-top:.5rem;margin-bottom:.5rem;overflow-x:auto;border-radius:.75rem;background-color:#0006;padding:1rem;--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1));border-width:1px;border-color:#ffffff1a}.message-content code{border-radius:.25rem;background-color:#ffffff1a;padding:.125rem .375rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(204 255 0 / var(--tw-text-opacity, 1))}.message-content pre code{background-color:transparent;padding:0;--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}@keyframes tool-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #ccff004d}50%{box-shadow:0 0 40px #ccff0080}}.tool-status-pending{animation:tool-pulse 1.5s ease-in-out infinite}.tool-card-details{transition:max-height .2s ease-out,opacity .2s ease-out}.tool-code-block{overflow-x:auto;border-radius:.75rem;background-color:#0006;padding:.75rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;line-height:1rem;border-width:1px;border-color:#ffffff1a;word-break:break-word;white-space:pre-wrap}.tool-section-header{border-bottom-width:1px;border-color:#ffffff1a;background-color:#ffffff0d;padding:.5rem .75rem;font-size:.75rem;line-height:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em;color:#ffffff80}.status-pending{--tw-bg-opacity: 1;background-color:rgb(250 204 21 / var(--tw-bg-opacity, 1));animation:tool-pulse 1.5s ease-in-out infinite}.status-success{--tw-bg-opacity: 1;background-color:rgb(204 255 0 / var(--tw-bg-opacity, 1))}.status-failed{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.truncate-fade{background:linear-gradient(to top,rgba(10,10,10,1),transparent)}.ambient-glow{pointer-events:none;position:absolute;border-radius:9999px;opacity:.08;--tw-blur: blur(120px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ambient-glow-accent{background:radial-gradient(circle,rgba(204,255,0,.15) 0%,transparent 70%)}.ambient-glow-green{background:radial-gradient(circle,rgba(5,46,22,.25) 0%,transparent 70%)}.grid-pattern{background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:50px 50px}.noise-overlay{opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-slow{0%,to{opacity:.06}50%{opacity:.1}}.animate-fade-in{animation:fade-in .3s ease-out forwards}.animate-slide-up{animation:slide-up .4s ease-out forwards}.animate-pulse-slow{animation:pulse-slow 8s ease-in-out infinite}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.badge{display:inline-flex;align-items:center;border-radius:9999px;padding:.25rem .625rem;font-size:.75rem;line-height:1rem;font-weight:500}.badge-accent{border-width:1px;border-color:#ccff004d;background-color:#cf03;--tw-text-opacity: 1;color:rgb(204 255 0 / var(--tw-text-opacity, 1))}.badge-success{border-width:1px;border-color:#10b9814d;background-color:#10b98133;--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.badge-warning{border-width:1px;border-color:#eab3084d;background-color:#eab30833;--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.badge-error{border-width:1px;border-color:#ef44444d;background-color:#ef444433;--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.badge-info{border-width:1px;border-color:#3b82f64d;background-color:#3b82f633;--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.hover\:border-white\/20:hover{border-color:#fff3}.hover\:bg-\[\#b8e600\]:hover{--tw-bg-opacity: 1;background-color:rgb(184 230 0 / var(--tw-bg-opacity, 1))}.hover\:bg-\[\#ccff00\]\/30:hover{background-color:#ccff004d}.hover\:bg-red-500:hover{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.hover\:bg-red-500\/10:hover{background-color:#ef44441a}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/5:hover{background-color:#ffffff0d}.hover\:bg-yellow-500:hover{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.hover\:text-\[\#b8e600\]:hover{--tw-text-opacity: 1;color:rgb(184 230 0 / var(--tw-text-opacity, 1))}.hover\:text-\[\#ccff00\]:hover{--tw-text-opacity: 1;color:rgb(204 255 0 / var(--tw-text-opacity, 1))}.hover\:text-blue-300:hover{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.hover\:text-red-400:hover{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:text-white\/80:hover{color:#fffc}.hover\:shadow-\[0_0_30px_rgba\(204\,255\,0\,0\.1\)\]:hover{--tw-shadow: 0 0 30px rgba(204,255,0,.1);--tw-shadow-colored: 0 0 30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[0_0_30px_rgba\(204\,255\,0\,0\.5\)\]:hover{--tw-shadow: 0 0 30px rgba(204,255,0,.5);--tw-shadow-colored: 0 0 30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-\[\#ccff00\]\/50:focus{border-color:#ccff0080}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-1{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:border-\[\#ccff00\]\/30{border-color:#ccff004d}.group:hover .group-hover\:bg-\[\#ccff00\]\/20{background-color:#cf03}.group:hover .group-hover\:text-\[\#ccff00\]{--tw-text-opacity: 1;color:rgb(204 255 0 / var(--tw-text-opacity, 1))}@media(min-width:640px){.sm\:mb-6{margin-bottom:1.5rem}.sm\:mb-8{margin-bottom:2rem}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:hidden{display:none}.sm\:h-10{height:2.5rem}.sm\:h-20{height:5rem}.sm\:h-4{height:1rem}.sm\:h-5{height:1.25rem}.sm\:h-9{height:2.25rem}.sm\:w-10{width:2.5rem}.sm\:w-20{width:5rem}.sm\:w-4{width:1rem}.sm\:w-5{width:1.25rem}.sm\:w-9{width:2.25rem}.sm\:max-w-none{max-width:none}.sm\:gap-2{gap:.5rem}.sm\:gap-3{gap:.75rem}.sm\:p-4{padding:1rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-4{padding-left:1rem;padding-right:1rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:py-16{padding-top:4rem;padding-bottom:4rem}.sm\:py-2{padding-top:.5rem;padding-bottom:.5rem}.sm\:py-3{padding-top:.75rem;padding-bottom:.75rem}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(prefers-color-scheme:dark){.dark\:bg-gray-950{--tw-bg-opacity: 1;background-color:rgb(3 7 18 / var(--tw-bg-opacity, 1))}.dark\:text-gray-100{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Harness Playground - React components for agent chat UI
3
+ *
4
+ * This entry point provides embeddable React components for building
5
+ * chat interfaces that work with the harness API.
6
+ *
7
+ * @example
8
+ * ```tsx
9
+ * import { Playground } from '@ash-cloud/ash-ai/playground';
10
+ * import '@ash-cloud/ash-ai/styles.css';
11
+ *
12
+ * function App() {
13
+ * return <Playground apiBasePath="/api/harness" />;
14
+ * }
15
+ * ```
16
+ */
17
+ export * from './playground/index.js';
18
+ //# sourceMappingURL=playground.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"playground.d.ts","sourceRoot":"","sources":["../src/playground.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAGH,cAAc,uBAAuB,CAAC"}