@agentuity/workbench 0.0.86 → 0.0.88
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/components/App.d.ts.map +1 -1
- package/dist/components/App.js +18 -2
- package/dist/components/App.js.map +1 -1
- package/dist/components/ai-elements/code-block.d.ts +3 -3
- package/dist/components/ai-elements/code-block.d.ts.map +1 -1
- package/dist/components/ai-elements/code-block.js +29 -7
- package/dist/components/ai-elements/code-block.js.map +1 -1
- package/dist/components/internal/Chat.d.ts +3 -2
- package/dist/components/internal/Chat.d.ts.map +1 -1
- package/dist/components/internal/Chat.js +23 -24
- package/dist/components/internal/Chat.js.map +1 -1
- package/dist/components/internal/InputSection.d.ts +3 -2
- package/dist/components/internal/InputSection.d.ts.map +1 -1
- package/dist/components/internal/InputSection.js +68 -6
- package/dist/components/internal/InputSection.js.map +1 -1
- package/dist/components/internal/MonacoJsonEditor.d.ts +3 -1
- package/dist/components/internal/MonacoJsonEditor.d.ts.map +1 -1
- package/dist/components/internal/MonacoJsonEditor.js +41 -57
- package/dist/components/internal/MonacoJsonEditor.js.map +1 -1
- package/dist/components/internal/Schema.d.ts +1 -2
- package/dist/components/internal/Schema.d.ts.map +1 -1
- package/dist/components/internal/Schema.js +2 -3
- package/dist/components/internal/Schema.js.map +1 -1
- package/dist/components/internal/WorkbenchProvider.d.ts.map +1 -1
- package/dist/components/internal/WorkbenchProvider.js +55 -8
- package/dist/components/internal/WorkbenchProvider.js.map +1 -1
- package/dist/components/ui/button.d.ts +1 -1
- package/dist/components/ui/input-group.js +2 -2
- package/dist/components/ui/input-group.js.map +1 -1
- package/dist/components/ui/input.d.ts.map +1 -1
- package/dist/components/ui/input.js +1 -1
- package/dist/components/ui/input.js.map +1 -1
- package/dist/index.d.ts +3 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -6
- package/dist/index.js.map +1 -1
- package/dist/{styles.css → standalone.css} +206 -1554
- package/package.json +29 -29
- package/src/{styles.css → base.css} +36 -52
- package/src/components/App.tsx +41 -5
- package/src/components/ai-elements/code-block.tsx +42 -10
- package/src/components/internal/Chat.tsx +112 -119
- package/src/components/internal/InputSection.tsx +79 -9
- package/src/components/internal/MonacoJsonEditor.tsx +59 -65
- package/src/components/internal/Schema.tsx +74 -86
- package/src/components/internal/WorkbenchProvider.tsx +69 -10
- package/src/components/ui/input-group.tsx +2 -2
- package/src/components/ui/input.tsx +2 -3
- package/src/index.ts +5 -14
- package/src/integration.css +15 -0
- package/src/standalone.css +25 -0
- package/dist/components/ConnectionStatus.d.ts +0 -7
- package/dist/components/ConnectionStatus.d.ts.map +0 -1
- package/dist/components/ConnectionStatus.js +0 -52
- package/dist/components/ConnectionStatus.js.map +0 -1
- package/dist/components/Inline.d.ts +0 -10
- package/dist/components/Inline.d.ts.map +0 -1
- package/dist/components/Inline.js +0 -11
- package/dist/components/Inline.js.map +0 -1
- package/dist/components/ai-elements/artifact.d.ts +0 -24
- package/dist/components/ai-elements/artifact.d.ts.map +0 -1
- package/dist/components/ai-elements/artifact.js +0 -21
- package/dist/components/ai-elements/artifact.js.map +0 -1
- package/dist/components/ai-elements/branch.d.ts +0 -21
- package/dist/components/ai-elements/branch.d.ts.map +0 -1
- package/dist/components/ai-elements/branch.js +0 -71
- package/dist/components/ai-elements/branch.js.map +0 -1
- package/dist/components/ai-elements/canvas.d.ts +0 -9
- package/dist/components/ai-elements/canvas.d.ts.map +0 -1
- package/dist/components/ai-elements/canvas.js +0 -6
- package/dist/components/ai-elements/canvas.js.map +0 -1
- package/dist/components/ai-elements/chain-of-thought.d.ts +0 -30
- package/dist/components/ai-elements/chain-of-thought.d.ts.map +0 -1
- package/dist/components/ai-elements/chain-of-thought.js +0 -52
- package/dist/components/ai-elements/chain-of-thought.js.map +0 -1
- package/dist/components/ai-elements/confirmation.d.ts +0 -27
- package/dist/components/ai-elements/confirmation.d.ts.map +0 -1
- package/dist/components/ai-elements/confirmation.js +0 -57
- package/dist/components/ai-elements/confirmation.js.map +0 -1
- package/dist/components/ai-elements/connection.d.ts +0 -3
- package/dist/components/ai-elements/connection.d.ts.map +0 -1
- package/dist/components/ai-elements/connection.js +0 -4
- package/dist/components/ai-elements/connection.js.map +0 -1
- package/dist/components/ai-elements/context.d.ts +0 -33
- package/dist/components/ai-elements/context.d.ts.map +0 -1
- package/dist/components/ai-elements/context.js +0 -167
- package/dist/components/ai-elements/context.js.map +0 -1
- package/dist/components/ai-elements/controls.d.ts +0 -5
- package/dist/components/ai-elements/controls.d.ts.map +0 -1
- package/dist/components/ai-elements/controls.js +0 -6
- package/dist/components/ai-elements/controls.js.map +0 -1
- package/dist/components/ai-elements/edge.d.ts +0 -6
- package/dist/components/ai-elements/edge.d.ts.map +0 -1
- package/dist/components/ai-elements/edge.js +0 -83
- package/dist/components/ai-elements/edge.js.map +0 -1
- package/dist/components/ai-elements/image.d.ts +0 -7
- package/dist/components/ai-elements/image.d.ts.map +0 -1
- package/dist/components/ai-elements/image.js +0 -4
- package/dist/components/ai-elements/image.js.map +0 -1
- package/dist/components/ai-elements/inline-citation.d.ts +0 -39
- package/dist/components/ai-elements/inline-citation.d.ts.map +0 -1
- package/dist/components/ai-elements/inline-citation.js +0 -62
- package/dist/components/ai-elements/inline-citation.js.map +0 -1
- package/dist/components/ai-elements/loader.d.ts +0 -6
- package/dist/components/ai-elements/loader.d.ts.map +0 -1
- package/dist/components/ai-elements/loader.js +0 -5
- package/dist/components/ai-elements/loader.js.map +0 -1
- package/dist/components/ai-elements/node.d.ts +0 -22
- package/dist/components/ai-elements/node.d.ts.map +0 -1
- package/dist/components/ai-elements/node.js +0 -12
- package/dist/components/ai-elements/node.js.map +0 -1
- package/dist/components/ai-elements/open-in-chat.d.ts +0 -29
- package/dist/components/ai-elements/open-in-chat.d.ts.map +0 -1
- package/dist/components/ai-elements/open-in-chat.js +0 -97
- package/dist/components/ai-elements/open-in-chat.js.map +0 -1
- package/dist/components/ai-elements/panel.d.ts +0 -6
- package/dist/components/ai-elements/panel.d.ts.map +0 -1
- package/dist/components/ai-elements/panel.js +0 -5
- package/dist/components/ai-elements/panel.js.map +0 -1
- package/dist/components/ai-elements/plan.d.ts +0 -26
- package/dist/components/ai-elements/plan.d.ts.map +0 -1
- package/dist/components/ai-elements/plan.js +0 -32
- package/dist/components/ai-elements/plan.js.map +0 -1
- package/dist/components/ai-elements/queue.d.ts +0 -62
- package/dist/components/ai-elements/queue.d.ts.map +0 -1
- package/dist/components/ai-elements/queue.js +0 -25
- package/dist/components/ai-elements/queue.js.map +0 -1
- package/dist/components/ai-elements/reasoning.d.ts +0 -17
- package/dist/components/ai-elements/reasoning.d.ts.map +0 -1
- package/dist/components/ai-elements/reasoning.js +0 -77
- package/dist/components/ai-elements/reasoning.js.map +0 -1
- package/dist/components/ai-elements/response.d.ts +0 -6
- package/dist/components/ai-elements/response.d.ts.map +0 -1
- package/dist/components/ai-elements/response.js +0 -8
- package/dist/components/ai-elements/response.js.map +0 -1
- package/dist/components/ai-elements/sources.d.ts +0 -13
- package/dist/components/ai-elements/sources.d.ts.map +0 -1
- package/dist/components/ai-elements/sources.js +0 -10
- package/dist/components/ai-elements/sources.js.map +0 -1
- package/dist/components/ai-elements/suggestion.d.ts +0 -11
- package/dist/components/ai-elements/suggestion.d.ts.map +0 -1
- package/dist/components/ai-elements/suggestion.js +0 -13
- package/dist/components/ai-elements/suggestion.js.map +0 -1
- package/dist/components/ai-elements/task.d.ts +0 -15
- package/dist/components/ai-elements/task.d.ts.map +0 -1
- package/dist/components/ai-elements/task.js +0 -11
- package/dist/components/ai-elements/task.js.map +0 -1
- package/dist/components/ai-elements/tool.d.ts +0 -24
- package/dist/components/ai-elements/tool.d.ts.map +0 -1
- package/dist/components/ai-elements/tool.js +0 -47
- package/dist/components/ai-elements/tool.js.map +0 -1
- package/dist/components/ai-elements/toolbar.d.ts +0 -6
- package/dist/components/ai-elements/toolbar.d.ts.map +0 -1
- package/dist/components/ai-elements/toolbar.js +0 -5
- package/dist/components/ai-elements/toolbar.js.map +0 -1
- package/dist/components/ai-elements/web-preview.d.ts +0 -35
- package/dist/components/ai-elements/web-preview.d.ts.map +0 -1
- package/dist/components/ai-elements/web-preview.js +0 -63
- package/dist/components/ai-elements/web-preview.js.map +0 -1
- package/dist/components/ui/alert.d.ts +0 -10
- package/dist/components/ui/alert.d.ts.map +0 -1
- package/dist/components/ui/alert.js +0 -25
- package/dist/components/ui/alert.js.map +0 -1
- package/dist/components/ui/badge.d.ts +0 -10
- package/dist/components/ui/badge.d.ts.map +0 -1
- package/dist/components/ui/badge.js +0 -23
- package/dist/components/ui/badge.js.map +0 -1
- package/dist/components/ui/card.d.ts +0 -10
- package/dist/components/ui/card.d.ts.map +0 -1
- package/dist/components/ui/card.js +0 -25
- package/dist/components/ui/card.js.map +0 -1
- package/dist/components/ui/carousel.d.ts +0 -20
- package/dist/components/ui/carousel.d.ts.map +0 -1
- package/dist/components/ui/carousel.js +0 -92
- package/dist/components/ui/carousel.js.map +0 -1
- package/dist/components/ui/checkbox.d.ts +0 -5
- package/dist/components/ui/checkbox.d.ts.map +0 -1
- package/dist/components/ui/checkbox.js +0 -9
- package/dist/components/ui/checkbox.js.map +0 -1
- package/dist/components/ui/collapsible.d.ts +0 -6
- package/dist/components/ui/collapsible.d.ts.map +0 -1
- package/dist/components/ui/collapsible.js +0 -14
- package/dist/components/ui/collapsible.js.map +0 -1
- package/dist/components/ui/field.d.ts +0 -25
- package/dist/components/ui/field.d.ts.map +0 -1
- package/dist/components/ui/field.js +0 -74
- package/dist/components/ui/field.js.map +0 -1
- package/dist/components/ui/form.d.ts +0 -25
- package/dist/components/ui/form.d.ts.map +0 -1
- package/dist/components/ui/form.js +0 -58
- package/dist/components/ui/form.js.map +0 -1
- package/dist/components/ui/label.d.ts +0 -5
- package/dist/components/ui/label.d.ts.map +0 -1
- package/dist/components/ui/label.js +0 -9
- package/dist/components/ui/label.js.map +0 -1
- package/dist/components/ui/progress.d.ts +0 -5
- package/dist/components/ui/progress.d.ts.map +0 -1
- package/dist/components/ui/progress.js +0 -9
- package/dist/components/ui/progress.js.map +0 -1
- package/dist/components/ui/separator.d.ts +0 -5
- package/dist/components/ui/separator.d.ts.map +0 -1
- package/dist/components/ui/separator.js +0 -9
- package/dist/components/ui/separator.js.map +0 -1
- package/dist/components/ui/switch.d.ts +0 -5
- package/dist/components/ui/switch.d.ts.map +0 -1
- package/dist/components/ui/switch.js +0 -8
- package/dist/components/ui/switch.js.map +0 -1
- package/dist/components/ui/tabs.d.ts +0 -8
- package/dist/components/ui/tabs.d.ts.map +0 -1
- package/dist/components/ui/tabs.js +0 -17
- package/dist/components/ui/tabs.js.map +0 -1
- package/dist/components/ui/toggle.d.ts +0 -10
- package/dist/components/ui/toggle.d.ts.map +0 -1
- package/dist/components/ui/toggle.js +0 -26
- package/dist/components/ui/toggle.js.map +0 -1
- package/dist/components.d.ts +0 -12
- package/dist/components.d.ts.map +0 -1
- package/dist/components.js +0 -13
- package/dist/components.js.map +0 -1
- package/dist/hooks/index.d.ts +0 -7
- package/dist/hooks/index.d.ts.map +0 -1
- package/dist/hooks/index.js +0 -5
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/useWorkbenchSchemas.d.ts +0 -56
- package/dist/hooks/useWorkbenchSchemas.d.ts.map +0 -1
- package/dist/hooks/useWorkbenchSchemas.js +0 -63
- package/dist/hooks/useWorkbenchSchemas.js.map +0 -1
- package/src/components/ConnectionStatus.tsx +0 -67
- package/src/components/Inline.tsx +0 -16
- package/src/components/ai-elements/artifact.tsx +0 -118
- package/src/components/ai-elements/branch.tsx +0 -187
- package/src/components/ai-elements/canvas.tsx +0 -24
- package/src/components/ai-elements/chain-of-thought.tsx +0 -198
- package/src/components/ai-elements/confirmation.tsx +0 -119
- package/src/components/ai-elements/connection.tsx +0 -16
- package/src/components/ai-elements/context.tsx +0 -357
- package/src/components/ai-elements/controls.tsx +0 -18
- package/src/components/ai-elements/edge.tsx +0 -131
- package/src/components/ai-elements/image.tsx +0 -16
- package/src/components/ai-elements/inline-citation.tsx +0 -246
- package/src/components/ai-elements/loader.tsx +0 -88
- package/src/components/ai-elements/node.tsx +0 -66
- package/src/components/ai-elements/open-in-chat.tsx +0 -333
- package/src/components/ai-elements/panel.tsx +0 -12
- package/src/components/ai-elements/plan.tsx +0 -123
- package/src/components/ai-elements/queue.tsx +0 -231
- package/src/components/ai-elements/reasoning.tsx +0 -163
- package/src/components/ai-elements/response.tsx +0 -19
- package/src/components/ai-elements/sources.tsx +0 -53
- package/src/components/ai-elements/suggestion.tsx +0 -47
- package/src/components/ai-elements/task.tsx +0 -64
- package/src/components/ai-elements/tool.tsx +0 -136
- package/src/components/ai-elements/toolbar.tsx +0 -13
- package/src/components/ai-elements/web-preview.tsx +0 -238
- package/src/components/ui/alert.tsx +0 -60
- package/src/components/ui/badge.tsx +0 -40
- package/src/components/ui/card.tsx +0 -41
- package/src/components/ui/carousel.tsx +0 -234
- package/src/components/ui/checkbox.tsx +0 -27
- package/src/components/ui/collapsible.tsx +0 -21
- package/src/components/ui/field.tsx +0 -234
- package/src/components/ui/form.tsx +0 -154
- package/src/components/ui/label.tsx +0 -21
- package/src/components/ui/progress.tsx +0 -28
- package/src/components/ui/separator.tsx +0 -28
- package/src/components/ui/switch.tsx +0 -26
- package/src/components/ui/tabs.tsx +0 -52
- package/src/components/ui/toggle.tsx +0 -44
- package/src/components.tsx +0 -29
- package/src/hooks/index.ts +0 -20
- package/src/hooks/useWorkbenchSchemas.ts +0 -69
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { Badge } from '../ui/badge';
|
|
4
|
-
import { Collapsible, CollapsibleContent, CollapsibleTrigger } from '../ui/collapsible';
|
|
5
|
-
import { cn } from '../../lib/utils';
|
|
6
|
-
import type { ToolUIPart } from 'ai';
|
|
7
|
-
import {
|
|
8
|
-
CheckCircleIcon,
|
|
9
|
-
ChevronDownIcon,
|
|
10
|
-
CircleIcon,
|
|
11
|
-
ClockIcon,
|
|
12
|
-
WrenchIcon,
|
|
13
|
-
XCircleIcon,
|
|
14
|
-
} from 'lucide-react';
|
|
15
|
-
import type { ComponentProps, ReactNode } from 'react';
|
|
16
|
-
import { isValidElement } from 'react';
|
|
17
|
-
import { CodeBlock } from './code-block';
|
|
18
|
-
|
|
19
|
-
export type ToolProps = ComponentProps<typeof Collapsible>;
|
|
20
|
-
|
|
21
|
-
export const Tool = ({ className, ...props }: ToolProps) => (
|
|
22
|
-
<Collapsible className={cn('not-prose mb-4 w-full rounded-md border', className)} {...props} />
|
|
23
|
-
);
|
|
24
|
-
|
|
25
|
-
export type ToolHeaderProps = {
|
|
26
|
-
title?: string;
|
|
27
|
-
type: ToolUIPart['type'];
|
|
28
|
-
state: any;
|
|
29
|
-
className?: string;
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
const getStatusBadge = (status: any) => {
|
|
33
|
-
const labels: Record<string, string> = {
|
|
34
|
-
'input-streaming': 'Pending',
|
|
35
|
-
'input-available': 'Running',
|
|
36
|
-
'approval-requested': 'Awaiting Approval',
|
|
37
|
-
'approval-responded': 'Responded',
|
|
38
|
-
'output-available': 'Completed',
|
|
39
|
-
'output-error': 'Error',
|
|
40
|
-
'output-denied': 'Denied',
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
const icons: Record<string, ReactNode> = {
|
|
44
|
-
'input-streaming': <CircleIcon className="size-4" />,
|
|
45
|
-
'input-available': <ClockIcon className="size-4 animate-pulse" />,
|
|
46
|
-
'approval-requested': <ClockIcon className="size-4 text-yellow-600" />,
|
|
47
|
-
'approval-responded': <CheckCircleIcon className="size-4 text-blue-600" />,
|
|
48
|
-
'output-available': <CheckCircleIcon className="size-4 text-green-600" />,
|
|
49
|
-
'output-error': <XCircleIcon className="size-4 text-red-600" />,
|
|
50
|
-
'output-denied': <XCircleIcon className="size-4 text-orange-600" />,
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
return (
|
|
54
|
-
<Badge className="gap-1.5 rounded-full text-xs" variant="secondary">
|
|
55
|
-
{icons[status]}
|
|
56
|
-
{labels[status]}
|
|
57
|
-
</Badge>
|
|
58
|
-
);
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
export const ToolHeader = ({ className, title, type, state, ...props }: ToolHeaderProps) => (
|
|
62
|
-
<CollapsibleTrigger
|
|
63
|
-
className={cn('flex w-full items-center justify-between gap-4 p-3', className)}
|
|
64
|
-
{...props}
|
|
65
|
-
>
|
|
66
|
-
<div className="flex items-center gap-2">
|
|
67
|
-
<WrenchIcon className="size-4 text-muted-foreground" />
|
|
68
|
-
<span className="font-medium text-sm">{title ?? type.split('-').slice(1).join('-')}</span>
|
|
69
|
-
{getStatusBadge(state)}
|
|
70
|
-
</div>
|
|
71
|
-
<ChevronDownIcon className="size-4 text-muted-foreground transition-transform group-data-[state=open]:rotate-180" />
|
|
72
|
-
</CollapsibleTrigger>
|
|
73
|
-
);
|
|
74
|
-
|
|
75
|
-
export type ToolContentProps = ComponentProps<typeof CollapsibleContent>;
|
|
76
|
-
|
|
77
|
-
export const ToolContent = ({ className, ...props }: ToolContentProps) => (
|
|
78
|
-
<CollapsibleContent
|
|
79
|
-
className={cn(
|
|
80
|
-
'data-[state=closed]:fade-out-0 data-[state=closed]:slide-out-to-top-2 data-[state=open]:slide-in-from-top-2 text-popover-foreground outline-none data-[state=closed]:animate-out data-[state=open]:animate-in',
|
|
81
|
-
className
|
|
82
|
-
)}
|
|
83
|
-
{...props}
|
|
84
|
-
/>
|
|
85
|
-
);
|
|
86
|
-
|
|
87
|
-
export type ToolInputProps = ComponentProps<'div'> & {
|
|
88
|
-
input: ToolUIPart['input'];
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
export const ToolInput = ({ className, input, ...props }: ToolInputProps) => (
|
|
92
|
-
<div className={cn('space-y-2 overflow-hidden p-4', className)} {...props}>
|
|
93
|
-
<h4 className="font-medium text-muted-foreground text-xs uppercase tracking-wide">
|
|
94
|
-
Parameters
|
|
95
|
-
</h4>
|
|
96
|
-
<div className="rounded-md bg-muted/50">
|
|
97
|
-
<CodeBlock code={JSON.stringify(input, null, 2)} language="json" />
|
|
98
|
-
</div>
|
|
99
|
-
</div>
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
export type ToolOutputProps = ComponentProps<'div'> & {
|
|
103
|
-
output: ToolUIPart['output'];
|
|
104
|
-
errorText: ToolUIPart['errorText'];
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
export const ToolOutput = ({ className, output, errorText, ...props }: ToolOutputProps) => {
|
|
108
|
-
if (!(output || errorText)) {
|
|
109
|
-
return null;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
let Output = <div>{output as ReactNode}</div>;
|
|
113
|
-
|
|
114
|
-
if (typeof output === 'object' && !isValidElement(output)) {
|
|
115
|
-
Output = <CodeBlock code={JSON.stringify(output, null, 2)} language="json" />;
|
|
116
|
-
} else if (typeof output === 'string') {
|
|
117
|
-
Output = <CodeBlock code={output} language="json" />;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
return (
|
|
121
|
-
<div className={cn('space-y-2 p-4', className)} {...props}>
|
|
122
|
-
<h4 className="font-medium text-muted-foreground text-xs uppercase tracking-wide">
|
|
123
|
-
{errorText ? 'Error' : 'Result'}
|
|
124
|
-
</h4>
|
|
125
|
-
<div
|
|
126
|
-
className={cn(
|
|
127
|
-
'overflow-x-auto rounded-md text-xs [&_table]:w-full',
|
|
128
|
-
errorText ? 'bg-destructive/10 text-destructive' : 'bg-muted/50 text-foreground'
|
|
129
|
-
)}
|
|
130
|
-
>
|
|
131
|
-
{errorText && <div>{errorText}</div>}
|
|
132
|
-
{Output}
|
|
133
|
-
</div>
|
|
134
|
-
</div>
|
|
135
|
-
);
|
|
136
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { cn } from '../../lib/utils';
|
|
2
|
-
import { NodeToolbar, Position } from '@xyflow/react';
|
|
3
|
-
import type { ComponentProps } from 'react';
|
|
4
|
-
|
|
5
|
-
type ToolbarProps = ComponentProps<typeof NodeToolbar>;
|
|
6
|
-
|
|
7
|
-
export const Toolbar = ({ className, ...props }: ToolbarProps) => (
|
|
8
|
-
<NodeToolbar
|
|
9
|
-
className={cn('flex items-center gap-1 rounded-sm border bg-background p-1.5', className)}
|
|
10
|
-
position={Position.Bottom}
|
|
11
|
-
{...props}
|
|
12
|
-
/>
|
|
13
|
-
);
|
|
@@ -1,238 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { Button } from '../ui/button';
|
|
4
|
-
import { Collapsible, CollapsibleContent, CollapsibleTrigger } from '../ui/collapsible';
|
|
5
|
-
import { Input } from '../ui/input';
|
|
6
|
-
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '../ui/tooltip';
|
|
7
|
-
import { cn } from '../../lib/utils';
|
|
8
|
-
import { ChevronDownIcon } from 'lucide-react';
|
|
9
|
-
import type { ComponentProps, ReactNode } from 'react';
|
|
10
|
-
import { createContext, useContext, useEffect, useState } from 'react';
|
|
11
|
-
|
|
12
|
-
export type WebPreviewContextValue = {
|
|
13
|
-
url: string;
|
|
14
|
-
setUrl: (url: string) => void;
|
|
15
|
-
consoleOpen: boolean;
|
|
16
|
-
setConsoleOpen: (open: boolean) => void;
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
const WebPreviewContext = createContext<WebPreviewContextValue | null>(null);
|
|
20
|
-
|
|
21
|
-
const useWebPreview = () => {
|
|
22
|
-
const context = useContext(WebPreviewContext);
|
|
23
|
-
if (!context) {
|
|
24
|
-
throw new Error('WebPreview components must be used within a WebPreview');
|
|
25
|
-
}
|
|
26
|
-
return context;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
export type WebPreviewProps = ComponentProps<'div'> & {
|
|
30
|
-
defaultUrl?: string;
|
|
31
|
-
onUrlChange?: (url: string) => void;
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
export const WebPreview = ({
|
|
35
|
-
className,
|
|
36
|
-
children,
|
|
37
|
-
defaultUrl = '',
|
|
38
|
-
onUrlChange,
|
|
39
|
-
...props
|
|
40
|
-
}: WebPreviewProps) => {
|
|
41
|
-
const [url, setUrl] = useState(defaultUrl);
|
|
42
|
-
const [consoleOpen, setConsoleOpen] = useState(false);
|
|
43
|
-
|
|
44
|
-
const handleUrlChange = (newUrl: string) => {
|
|
45
|
-
setUrl(newUrl);
|
|
46
|
-
onUrlChange?.(newUrl);
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
const contextValue: WebPreviewContextValue = {
|
|
50
|
-
url,
|
|
51
|
-
setUrl: handleUrlChange,
|
|
52
|
-
consoleOpen,
|
|
53
|
-
setConsoleOpen,
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
return (
|
|
57
|
-
<WebPreviewContext.Provider value={contextValue}>
|
|
58
|
-
<div
|
|
59
|
-
className={cn('flex size-full flex-col rounded-lg border bg-card', className)}
|
|
60
|
-
{...props}
|
|
61
|
-
>
|
|
62
|
-
{children}
|
|
63
|
-
</div>
|
|
64
|
-
</WebPreviewContext.Provider>
|
|
65
|
-
);
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
export type WebPreviewNavigationProps = ComponentProps<'div'>;
|
|
69
|
-
|
|
70
|
-
export const WebPreviewNavigation = ({
|
|
71
|
-
className,
|
|
72
|
-
children,
|
|
73
|
-
...props
|
|
74
|
-
}: WebPreviewNavigationProps) => (
|
|
75
|
-
<div className={cn('flex items-center gap-1 border-b p-2', className)} {...props}>
|
|
76
|
-
{children}
|
|
77
|
-
</div>
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
export type WebPreviewNavigationButtonProps = ComponentProps<typeof Button> & {
|
|
81
|
-
tooltip?: string;
|
|
82
|
-
};
|
|
83
|
-
|
|
84
|
-
export const WebPreviewNavigationButton = ({
|
|
85
|
-
onClick,
|
|
86
|
-
disabled,
|
|
87
|
-
tooltip,
|
|
88
|
-
children,
|
|
89
|
-
...props
|
|
90
|
-
}: WebPreviewNavigationButtonProps) => (
|
|
91
|
-
<TooltipProvider>
|
|
92
|
-
<Tooltip>
|
|
93
|
-
<TooltipTrigger asChild>
|
|
94
|
-
<Button
|
|
95
|
-
className="h-8 w-8 p-0 hover:text-foreground"
|
|
96
|
-
disabled={disabled}
|
|
97
|
-
onClick={onClick}
|
|
98
|
-
size="sm"
|
|
99
|
-
variant="ghost"
|
|
100
|
-
{...props}
|
|
101
|
-
>
|
|
102
|
-
{children}
|
|
103
|
-
</Button>
|
|
104
|
-
</TooltipTrigger>
|
|
105
|
-
<TooltipContent>
|
|
106
|
-
<p>{tooltip}</p>
|
|
107
|
-
</TooltipContent>
|
|
108
|
-
</Tooltip>
|
|
109
|
-
</TooltipProvider>
|
|
110
|
-
);
|
|
111
|
-
|
|
112
|
-
export type WebPreviewUrlProps = ComponentProps<typeof Input>;
|
|
113
|
-
|
|
114
|
-
export const WebPreviewUrl = ({ value, onChange, onKeyDown, ...props }: WebPreviewUrlProps) => {
|
|
115
|
-
const { url, setUrl } = useWebPreview();
|
|
116
|
-
const [inputValue, setInputValue] = useState(url);
|
|
117
|
-
|
|
118
|
-
// Sync input value with context URL when it changes externally
|
|
119
|
-
useEffect(() => {
|
|
120
|
-
setInputValue(url);
|
|
121
|
-
}, [url]);
|
|
122
|
-
|
|
123
|
-
const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {
|
|
124
|
-
setInputValue(event.target.value);
|
|
125
|
-
onChange?.(event);
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {
|
|
129
|
-
if (event.key === 'Enter') {
|
|
130
|
-
const target = event.target as HTMLInputElement;
|
|
131
|
-
setUrl(target.value);
|
|
132
|
-
}
|
|
133
|
-
onKeyDown?.(event);
|
|
134
|
-
};
|
|
135
|
-
|
|
136
|
-
return (
|
|
137
|
-
<Input
|
|
138
|
-
className="h-8 flex-1 text-sm"
|
|
139
|
-
onChange={onChange ?? handleChange}
|
|
140
|
-
onKeyDown={handleKeyDown}
|
|
141
|
-
placeholder="Enter URL..."
|
|
142
|
-
value={value ?? inputValue}
|
|
143
|
-
{...props}
|
|
144
|
-
/>
|
|
145
|
-
);
|
|
146
|
-
};
|
|
147
|
-
|
|
148
|
-
export type WebPreviewBodyProps = ComponentProps<'iframe'> & {
|
|
149
|
-
loading?: ReactNode;
|
|
150
|
-
};
|
|
151
|
-
|
|
152
|
-
export const WebPreviewBody = ({ className, loading, src, ...props }: WebPreviewBodyProps) => {
|
|
153
|
-
const { url } = useWebPreview();
|
|
154
|
-
|
|
155
|
-
return (
|
|
156
|
-
<div className="flex-1">
|
|
157
|
-
<iframe
|
|
158
|
-
className={cn('size-full', className)}
|
|
159
|
-
sandbox="allow-scripts allow-same-origin allow-forms allow-popups allow-presentation"
|
|
160
|
-
src={(src ?? url) || undefined}
|
|
161
|
-
title="Preview"
|
|
162
|
-
{...props}
|
|
163
|
-
/>
|
|
164
|
-
{loading}
|
|
165
|
-
</div>
|
|
166
|
-
);
|
|
167
|
-
};
|
|
168
|
-
|
|
169
|
-
export type WebPreviewConsoleProps = ComponentProps<'div'> & {
|
|
170
|
-
logs?: Array<{
|
|
171
|
-
level: 'log' | 'warn' | 'error';
|
|
172
|
-
message: string;
|
|
173
|
-
timestamp: Date;
|
|
174
|
-
}>;
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
export const WebPreviewConsole = ({
|
|
178
|
-
className,
|
|
179
|
-
logs = [],
|
|
180
|
-
children,
|
|
181
|
-
...props
|
|
182
|
-
}: WebPreviewConsoleProps) => {
|
|
183
|
-
const { consoleOpen, setConsoleOpen } = useWebPreview();
|
|
184
|
-
|
|
185
|
-
return (
|
|
186
|
-
<Collapsible
|
|
187
|
-
className={cn('border-t bg-muted/50 font-mono text-sm', className)}
|
|
188
|
-
onOpenChange={setConsoleOpen}
|
|
189
|
-
open={consoleOpen}
|
|
190
|
-
{...props}
|
|
191
|
-
>
|
|
192
|
-
<CollapsibleTrigger asChild>
|
|
193
|
-
<Button
|
|
194
|
-
className="flex w-full items-center justify-between p-4 text-left font-medium hover:bg-muted/50"
|
|
195
|
-
variant="ghost"
|
|
196
|
-
>
|
|
197
|
-
Console
|
|
198
|
-
<ChevronDownIcon
|
|
199
|
-
className={cn(
|
|
200
|
-
'h-4 w-4 transition-transform duration-200',
|
|
201
|
-
consoleOpen && 'rotate-180'
|
|
202
|
-
)}
|
|
203
|
-
/>
|
|
204
|
-
</Button>
|
|
205
|
-
</CollapsibleTrigger>
|
|
206
|
-
<CollapsibleContent
|
|
207
|
-
className={cn(
|
|
208
|
-
'px-4 pb-4',
|
|
209
|
-
'data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 outline-none data-[state=closed]:animate-out data-[state=open]:animate-in'
|
|
210
|
-
)}
|
|
211
|
-
>
|
|
212
|
-
<div className="max-h-48 space-y-1 overflow-y-auto">
|
|
213
|
-
{logs.length === 0 ? (
|
|
214
|
-
<p className="text-muted-foreground">No console output</p>
|
|
215
|
-
) : (
|
|
216
|
-
logs.map((log, index) => (
|
|
217
|
-
<div
|
|
218
|
-
className={cn(
|
|
219
|
-
'text-xs',
|
|
220
|
-
log.level === 'error' && 'text-destructive',
|
|
221
|
-
log.level === 'warn' && 'text-yellow-600',
|
|
222
|
-
log.level === 'log' && 'text-foreground'
|
|
223
|
-
)}
|
|
224
|
-
key={`${log.timestamp.getTime()}-${index}`}
|
|
225
|
-
>
|
|
226
|
-
<span className="text-muted-foreground">
|
|
227
|
-
{log.timestamp.toLocaleTimeString()}
|
|
228
|
-
</span>{' '}
|
|
229
|
-
{log.message}
|
|
230
|
-
</div>
|
|
231
|
-
))
|
|
232
|
-
)}
|
|
233
|
-
{children}
|
|
234
|
-
</div>
|
|
235
|
-
</CollapsibleContent>
|
|
236
|
-
</Collapsible>
|
|
237
|
-
);
|
|
238
|
-
};
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { cva, type VariantProps } from 'class-variance-authority';
|
|
3
|
-
|
|
4
|
-
import { cn } from '../../lib/utils';
|
|
5
|
-
|
|
6
|
-
const alertVariants = cva(
|
|
7
|
-
'relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current',
|
|
8
|
-
{
|
|
9
|
-
variants: {
|
|
10
|
-
variant: {
|
|
11
|
-
default: 'bg-card text-card-foreground',
|
|
12
|
-
destructive:
|
|
13
|
-
'text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90',
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
defaultVariants: {
|
|
17
|
-
variant: 'default',
|
|
18
|
-
},
|
|
19
|
-
}
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
function Alert({
|
|
23
|
-
className,
|
|
24
|
-
variant,
|
|
25
|
-
...props
|
|
26
|
-
}: React.ComponentProps<'div'> & VariantProps<typeof alertVariants>) {
|
|
27
|
-
return (
|
|
28
|
-
<div
|
|
29
|
-
data-slot="alert"
|
|
30
|
-
role="alert"
|
|
31
|
-
className={cn(alertVariants({ variant }), className)}
|
|
32
|
-
{...props}
|
|
33
|
-
/>
|
|
34
|
-
);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function AlertTitle({ className, ...props }: React.ComponentProps<'div'>) {
|
|
38
|
-
return (
|
|
39
|
-
<div
|
|
40
|
-
data-slot="alert-title"
|
|
41
|
-
className={cn('col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight', className)}
|
|
42
|
-
{...props}
|
|
43
|
-
/>
|
|
44
|
-
);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function AlertDescription({ className, ...props }: React.ComponentProps<'div'>) {
|
|
48
|
-
return (
|
|
49
|
-
<div
|
|
50
|
-
data-slot="alert-description"
|
|
51
|
-
className={cn(
|
|
52
|
-
'text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed',
|
|
53
|
-
className
|
|
54
|
-
)}
|
|
55
|
-
{...props}
|
|
56
|
-
/>
|
|
57
|
-
);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
export { Alert, AlertTitle, AlertDescription };
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { Slot } from '@radix-ui/react-slot';
|
|
3
|
-
import { cva, type VariantProps } from 'class-variance-authority';
|
|
4
|
-
|
|
5
|
-
import { cn } from '../../lib/utils';
|
|
6
|
-
|
|
7
|
-
const badgeVariants = cva(
|
|
8
|
-
'inline-flex items-center justify-center rounded-full 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',
|
|
9
|
-
{
|
|
10
|
-
variants: {
|
|
11
|
-
variant: {
|
|
12
|
-
default:
|
|
13
|
-
'border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90',
|
|
14
|
-
secondary:
|
|
15
|
-
'border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90',
|
|
16
|
-
destructive:
|
|
17
|
-
'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',
|
|
18
|
-
outline: 'text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground',
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
defaultVariants: {
|
|
22
|
-
variant: 'default',
|
|
23
|
-
},
|
|
24
|
-
}
|
|
25
|
-
);
|
|
26
|
-
|
|
27
|
-
function Badge({
|
|
28
|
-
className,
|
|
29
|
-
variant,
|
|
30
|
-
asChild = false,
|
|
31
|
-
...props
|
|
32
|
-
}: React.ComponentProps<'span'> & VariantProps<typeof badgeVariants> & { asChild?: boolean }) {
|
|
33
|
-
const Comp = asChild ? Slot : 'span';
|
|
34
|
-
|
|
35
|
-
return (
|
|
36
|
-
<Comp data-slot="badge" className={cn(badgeVariants({ variant }), className)} {...props} />
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
export { Badge, badgeVariants };
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { cn } from '../../lib/utils';
|
|
3
|
-
|
|
4
|
-
function Card({ className, ...props }: React.ComponentProps<'div'>) {
|
|
5
|
-
return (
|
|
6
|
-
<div
|
|
7
|
-
className={cn('rounded-lg border bg-card text-card-foreground shadow-sm', className)}
|
|
8
|
-
{...props}
|
|
9
|
-
/>
|
|
10
|
-
);
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
function CardAction({ className, ...props }: React.ComponentProps<'div'>) {
|
|
14
|
-
return <div className={cn('flex flex-col space-y-1.5 p-6', className)} {...props} />;
|
|
15
|
-
}
|
|
16
|
-
function CardHeader({ className, ...props }: React.ComponentProps<'div'>) {
|
|
17
|
-
return <div className={cn('flex flex-col space-y-1.5 p-6', className)} {...props} />;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
function CardTitle({ className, ...props }: React.ComponentProps<'h3'>) {
|
|
21
|
-
return (
|
|
22
|
-
<h3
|
|
23
|
-
className={cn('text-2xl font-semibold leading-none tracking-tight', className)}
|
|
24
|
-
{...props}
|
|
25
|
-
/>
|
|
26
|
-
);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
function CardDescription({ className, ...props }: React.ComponentProps<'p'>) {
|
|
30
|
-
return <p className={cn('text-sm text-muted-foreground', className)} {...props} />;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
function CardContent({ className, ...props }: React.ComponentProps<'div'>) {
|
|
34
|
-
return <div className={cn('p-6 pt-0', className)} {...props} />;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function CardFooter({ className, ...props }: React.ComponentProps<'div'>) {
|
|
38
|
-
return <div className={cn('flex items-center p-6 pt-0', className)} {...props} />;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
export { Card, CardHeader, CardFooter, CardTitle, CardAction, CardDescription, CardContent };
|