@xyne/workflow-ui 0.3.0 → 0.4.1
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/analytics/AnalyticsDashboard.d.ts.map +1 -1
- package/dist/components/analytics/AnalyticsDashboard.js +30 -7
- package/dist/components/analytics/AnalyticsDashboard.js.map +1 -1
- package/dist/components/analytics/FilteredRunsPanel.d.ts +8 -0
- package/dist/components/analytics/FilteredRunsPanel.d.ts.map +1 -0
- package/dist/components/analytics/FilteredRunsPanel.js +64 -0
- package/dist/components/analytics/FilteredRunsPanel.js.map +1 -0
- package/dist/components/analytics/RecentFailuresPanel.d.ts +9 -0
- package/dist/components/analytics/RecentFailuresPanel.d.ts.map +1 -0
- package/dist/components/analytics/RecentFailuresPanel.js +27 -0
- package/dist/components/analytics/RecentFailuresPanel.js.map +1 -0
- package/dist/components/analytics/StatCard.d.ts +3 -1
- package/dist/components/analytics/StatCard.d.ts.map +1 -1
- package/dist/components/analytics/StatCard.js +2 -2
- package/dist/components/analytics/StatCard.js.map +1 -1
- package/dist/components/analytics/TopErrorsPanel.d.ts +4 -5
- package/dist/components/analytics/TopErrorsPanel.d.ts.map +1 -1
- package/dist/components/analytics/TopErrorsPanel.js +18 -45
- package/dist/components/analytics/TopErrorsPanel.js.map +1 -1
- package/dist/components/analytics/WorkflowsTable.d.ts.map +1 -1
- package/dist/components/analytics/WorkflowsTable.js +25 -8
- package/dist/components/analytics/WorkflowsTable.js.map +1 -1
- package/dist/components/builder/v3/AiBuilderPanel.d.ts +12 -0
- package/dist/components/builder/v3/AiBuilderPanel.d.ts.map +1 -0
- package/dist/components/builder/v3/AiBuilderPanel.js +119 -0
- package/dist/components/builder/v3/AiBuilderPanel.js.map +1 -0
- package/dist/components/builder/v3/BranchContainer.d.ts +3 -1
- package/dist/components/builder/v3/BranchContainer.d.ts.map +1 -1
- package/dist/components/builder/v3/BranchContainer.js +42 -44
- package/dist/components/builder/v3/BranchContainer.js.map +1 -1
- package/dist/components/builder/v3/BuilderToolbar.d.ts +3 -1
- package/dist/components/builder/v3/BuilderToolbar.d.ts.map +1 -1
- package/dist/components/builder/v3/BuilderToolbar.js +5 -3
- package/dist/components/builder/v3/BuilderToolbar.js.map +1 -1
- package/dist/components/builder/v3/DeleteStepDialog.d.ts +14 -0
- package/dist/components/builder/v3/DeleteStepDialog.d.ts.map +1 -0
- package/dist/components/builder/v3/DeleteStepDialog.js +10 -0
- package/dist/components/builder/v3/DeleteStepDialog.js.map +1 -0
- package/dist/components/builder/v3/EnhancedSchemaFormRenderer.d.ts.map +1 -1
- package/dist/components/builder/v3/EnhancedSchemaFormRenderer.js +27 -4
- package/dist/components/builder/v3/EnhancedSchemaFormRenderer.js.map +1 -1
- package/dist/components/builder/v3/IssueBar.d.ts +16 -0
- package/dist/components/builder/v3/IssueBar.d.ts.map +1 -0
- package/dist/components/builder/v3/IssueBar.js +10 -0
- package/dist/components/builder/v3/IssueBar.js.map +1 -0
- package/dist/components/builder/v3/KeyValueEditor.d.ts.map +1 -1
- package/dist/components/builder/v3/KeyValueEditor.js +1 -1
- package/dist/components/builder/v3/KeyValueEditor.js.map +1 -1
- package/dist/components/builder/v3/SaveValidationDialog.d.ts +17 -0
- package/dist/components/builder/v3/SaveValidationDialog.d.ts.map +1 -0
- package/dist/components/builder/v3/SaveValidationDialog.js +16 -0
- package/dist/components/builder/v3/SaveValidationDialog.js.map +1 -0
- package/dist/components/builder/v3/SidePanel.d.ts +6 -1
- package/dist/components/builder/v3/SidePanel.d.ts.map +1 -1
- package/dist/components/builder/v3/SidePanel.js +2 -2
- package/dist/components/builder/v3/SidePanel.js.map +1 -1
- package/dist/components/builder/v3/StepConfigPanel.d.ts +4 -1
- package/dist/components/builder/v3/StepConfigPanel.d.ts.map +1 -1
- package/dist/components/builder/v3/StepConfigPanel.js +6 -3
- package/dist/components/builder/v3/StepConfigPanel.js.map +1 -1
- package/dist/components/builder/v3/StepNode.d.ts +5 -1
- package/dist/components/builder/v3/StepNode.d.ts.map +1 -1
- package/dist/components/builder/v3/StepNode.js +4 -3
- package/dist/components/builder/v3/StepNode.js.map +1 -1
- package/dist/components/builder/v3/TriggerConfigPanel.d.ts +4 -1
- package/dist/components/builder/v3/TriggerConfigPanel.d.ts.map +1 -1
- package/dist/components/builder/v3/TriggerConfigPanel.js +5 -2
- package/dist/components/builder/v3/TriggerConfigPanel.js.map +1 -1
- package/dist/components/builder/v3/TriggerNode.d.ts +3 -1
- package/dist/components/builder/v3/TriggerNode.d.ts.map +1 -1
- package/dist/components/builder/v3/TriggerNode.js +3 -3
- package/dist/components/builder/v3/TriggerNode.js.map +1 -1
- package/dist/components/builder/v3/VariablePickerPopover.d.ts +3 -1
- package/dist/components/builder/v3/VariablePickerPopover.d.ts.map +1 -1
- package/dist/components/builder/v3/VariablePickerPopover.js +2 -1
- package/dist/components/builder/v3/VariablePickerPopover.js.map +1 -1
- package/dist/components/builder/v3/VariableRefInput.d.ts +3 -1
- package/dist/components/builder/v3/VariableRefInput.d.ts.map +1 -1
- package/dist/components/builder/v3/VariableRefInput.js +2 -2
- package/dist/components/builder/v3/VariableRefInput.js.map +1 -1
- package/dist/components/builder/v3/WorkflowBuilderV3.d.ts +4 -1
- package/dist/components/builder/v3/WorkflowBuilderV3.d.ts.map +1 -1
- package/dist/components/builder/v3/WorkflowBuilderV3.js +86 -6
- package/dist/components/builder/v3/WorkflowBuilderV3.js.map +1 -1
- package/dist/components/builder/v3/WorkflowCanvas.d.ts +6 -1
- package/dist/components/builder/v3/WorkflowCanvas.d.ts.map +1 -1
- package/dist/components/builder/v3/WorkflowCanvas.js +2 -2
- package/dist/components/builder/v3/WorkflowCanvas.js.map +1 -1
- package/dist/components/builder/v3/WorkflowTree.d.ts +4 -1
- package/dist/components/builder/v3/WorkflowTree.d.ts.map +1 -1
- package/dist/components/builder/v3/WorkflowTree.js +7 -6
- package/dist/components/builder/v3/WorkflowTree.js.map +1 -1
- package/dist/components/dashboard/WorkflowDashboard.d.ts +4 -1
- package/dist/components/dashboard/WorkflowDashboard.d.ts.map +1 -1
- package/dist/components/dashboard/WorkflowDashboard.js +2 -2
- package/dist/components/dashboard/WorkflowDashboard.js.map +1 -1
- package/dist/components/execution/ExecutionTree.js +1 -1
- package/dist/components/execution/ExecutionTree.js.map +1 -1
- package/dist/components/execution/StepAgentPanels.d.ts +9 -0
- package/dist/components/execution/StepAgentPanels.d.ts.map +1 -0
- package/dist/components/execution/StepAgentPanels.js +133 -0
- package/dist/components/execution/StepAgentPanels.js.map +1 -0
- package/dist/components/execution/StepDetailPanel.d.ts.map +1 -1
- package/dist/components/execution/StepDetailPanel.js +3 -3
- package/dist/components/execution/StepDetailPanel.js.map +1 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +1 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/runs/RunsTable.d.ts.map +1 -1
- package/dist/components/runs/RunsTable.js +23 -7
- package/dist/components/runs/RunsTable.js.map +1 -1
- package/dist/components/shared/JsonTreeViewer.d.ts +9 -0
- package/dist/components/shared/JsonTreeViewer.d.ts.map +1 -0
- package/dist/components/shared/JsonTreeViewer.js +46 -0
- package/dist/components/shared/JsonTreeViewer.js.map +1 -0
- package/dist/hooks/use-ai-builder.d.ts +13 -0
- package/dist/hooks/use-ai-builder.d.ts.map +1 -0
- package/dist/hooks/use-ai-builder.js +35 -0
- package/dist/hooks/use-ai-builder.js.map +1 -0
- package/dist/hooks/use-analytics.d.ts +0 -2
- package/dist/hooks/use-analytics.d.ts.map +1 -1
- package/dist/hooks/use-analytics.js +21 -118
- package/dist/hooks/use-analytics.js.map +1 -1
- package/dist/hooks/use-variable-picker.js +18 -1
- package/dist/hooks/use-variable-picker.js.map +1 -1
- package/dist/hooks/use-workflow-builder.d.ts +2 -0
- package/dist/hooks/use-workflow-builder.d.ts.map +1 -1
- package/dist/hooks/use-workflow-builder.js +8 -0
- package/dist/hooks/use-workflow-builder.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/styles.css +1 -1
- package/dist/utils/issue-mapping.d.ts +26 -0
- package/dist/utils/issue-mapping.d.ts.map +1 -0
- package/dist/utils/issue-mapping.js +40 -0
- package/dist/utils/issue-mapping.js.map +1 -0
- package/package.json +3 -2
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { WorkflowConfig } from '@xyne/workflow-sdk/builder';
|
|
2
|
+
import type { AiBuilderClient } from '@xyne/workflow-sdk/ai-builder';
|
|
3
|
+
export interface AiBuilderPanelProps {
|
|
4
|
+
isOpen: boolean;
|
|
5
|
+
currentConfig: WorkflowConfig;
|
|
6
|
+
client: AiBuilderClient;
|
|
7
|
+
onApplyConfig: (config: WorkflowConfig) => void;
|
|
8
|
+
onSave?: (config: WorkflowConfig, summary: string | null) => Promise<void>;
|
|
9
|
+
onClose: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function AiBuilderPanel({ isOpen, currentConfig, client, onApplyConfig, onSave, onClose, }: AiBuilderPanelProps): import("react").JSX.Element;
|
|
12
|
+
//# sourceMappingURL=AiBuilderPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AiBuilderPanel.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/AiBuilderPanel.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAIrE,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,OAAO,CAAC;IAChB,aAAa,EAAE,cAAc,CAAC;IAC9B,MAAM,EAAE,eAAe,CAAC;IACxB,aAAa,EAAE,CAAC,MAAM,EAAE,cAAc,KAAK,IAAI,CAAC;IAChD,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3E,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,EAC7B,MAAM,EACN,aAAa,EACb,MAAM,EACN,aAAa,EACb,MAAM,EACN,OAAO,GACR,EAAE,mBAAmB,+BAwUrB"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useEffect, useRef, useState } from 'react';
|
|
3
|
+
import { useAiBuilder } from '../../../hooks/use-ai-builder.js';
|
|
4
|
+
import { cn } from '../../shared/cn.js';
|
|
5
|
+
export function AiBuilderPanel({ isOpen, currentConfig, client, onApplyConfig, onSave, onClose, }) {
|
|
6
|
+
const { messages, pendingPatch, isLoading, error, send, clearPatch, reset } = useAiBuilder(client);
|
|
7
|
+
const [draft, setDraft] = useState('');
|
|
8
|
+
const [isSaving, setIsSaving] = useState(false);
|
|
9
|
+
const [isUploading, setIsUploading] = useState(false);
|
|
10
|
+
const [attachedFile, setAttachedFile] = useState(null);
|
|
11
|
+
const messagesEndRef = useRef(null);
|
|
12
|
+
const textareaRef = useRef(null);
|
|
13
|
+
const fileInputRef = useRef(null);
|
|
14
|
+
// Auto-apply and save as soon as the AI returns a patch
|
|
15
|
+
useEffect(() => {
|
|
16
|
+
if (!pendingPatch)
|
|
17
|
+
return;
|
|
18
|
+
const patch = pendingPatch;
|
|
19
|
+
clearPatch(); // clear first so effect doesn't re-fire
|
|
20
|
+
onApplyConfig(patch);
|
|
21
|
+
if (onSave) {
|
|
22
|
+
setIsSaving(true);
|
|
23
|
+
void onSave(patch, null).catch((err) => {
|
|
24
|
+
console.warn('[AiBuilderPanel] save failed (canvas still updated):', err);
|
|
25
|
+
}).finally(() => setIsSaving(false));
|
|
26
|
+
}
|
|
27
|
+
}, [pendingPatch, onApplyConfig, onSave, clearPatch]);
|
|
28
|
+
// Auto-scroll to latest message
|
|
29
|
+
useEffect(() => {
|
|
30
|
+
messagesEndRef.current?.scrollIntoView({ behavior: 'smooth' });
|
|
31
|
+
}, [messages]);
|
|
32
|
+
// Focus textarea when panel opens
|
|
33
|
+
useEffect(() => {
|
|
34
|
+
if (isOpen) {
|
|
35
|
+
setTimeout(() => textareaRef.current?.focus(), 180);
|
|
36
|
+
}
|
|
37
|
+
}, [isOpen]);
|
|
38
|
+
const handleSend = useCallback(async () => {
|
|
39
|
+
const userText = draft.trim();
|
|
40
|
+
if (!userText && !attachedFile)
|
|
41
|
+
return;
|
|
42
|
+
if (isLoading)
|
|
43
|
+
return;
|
|
44
|
+
let messageText = userText;
|
|
45
|
+
if (attachedFile) {
|
|
46
|
+
const intro = userText || 'Generate a workflow from this document.';
|
|
47
|
+
messageText = `${intro}\n\n<document name="${attachedFile.name}">\n${attachedFile.text}\n</document>`;
|
|
48
|
+
}
|
|
49
|
+
setDraft('');
|
|
50
|
+
setAttachedFile(null);
|
|
51
|
+
await send(messageText, currentConfig);
|
|
52
|
+
}, [draft, attachedFile, isLoading, send, currentConfig]);
|
|
53
|
+
const handleFileSelect = useCallback(async (e) => {
|
|
54
|
+
const file = e.target.files?.[0];
|
|
55
|
+
if (!file)
|
|
56
|
+
return;
|
|
57
|
+
e.target.value = '';
|
|
58
|
+
setIsUploading(true);
|
|
59
|
+
try {
|
|
60
|
+
let text;
|
|
61
|
+
if (file.name.endsWith('.md') || file.name.endsWith('.json') || file.name.endsWith('.txt') || file.type === 'text/markdown' || file.type === 'text/plain' || file.type === 'application/json') {
|
|
62
|
+
text = await file.text();
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
const form = new FormData();
|
|
66
|
+
form.append('file', file);
|
|
67
|
+
const res = await fetch(`${client.baseUrl}/api/parse-file`, {
|
|
68
|
+
method: 'POST',
|
|
69
|
+
body: form,
|
|
70
|
+
});
|
|
71
|
+
if (!res.ok)
|
|
72
|
+
throw new Error((await res.json()).error);
|
|
73
|
+
text = (await res.json()).text;
|
|
74
|
+
}
|
|
75
|
+
setAttachedFile({ name: file.name, text });
|
|
76
|
+
setTimeout(() => textareaRef.current?.focus(), 50);
|
|
77
|
+
}
|
|
78
|
+
catch (err) {
|
|
79
|
+
setAttachedFile({ name: file.name, text: `[Parse error: ${err instanceof Error ? err.message : String(err)}]` });
|
|
80
|
+
}
|
|
81
|
+
finally {
|
|
82
|
+
setIsUploading(false);
|
|
83
|
+
}
|
|
84
|
+
}, [client.baseUrl]);
|
|
85
|
+
const handleKeyDown = useCallback((e) => {
|
|
86
|
+
if (e.key === 'Enter' && !e.shiftKey) {
|
|
87
|
+
e.preventDefault();
|
|
88
|
+
void handleSend();
|
|
89
|
+
}
|
|
90
|
+
}, [handleSend]);
|
|
91
|
+
return (_jsx("div", { className: cn('relative flex h-full flex-col border-l border-slate-200/80 bg-white transition-[flex,opacity] duration-200 overflow-hidden', isOpen ? 'opacity-100' : 'opacity-0 border-l-0'), style: { flex: isOpen ? '0 0 380px' : '0 0 0px' }, children: isOpen && (_jsxs(_Fragment, { children: [_jsxs("div", { className: "flex items-center justify-between border-b border-slate-100 px-4 py-3", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "flex h-6 w-6 items-center justify-center rounded-md bg-indigo-100 text-indigo-600", children: _jsxs("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M12 2a10 10 0 0 1 10 10c0 5.52-4.48 10-10 10S2 17.52 2 12 6.48 2 12 2z" }), _jsx("path", { d: "M8 12h8M12 8v8" })] }) }), _jsx("span", { className: "text-sm font-semibold text-slate-700", children: "Ask AI" })] }), _jsxs("div", { className: "flex items-center gap-1", children: [messages.length > 0 && (_jsx("button", { onClick: reset, title: "Clear conversation", className: "flex h-6 w-6 items-center justify-center rounded-md text-slate-400 hover:bg-slate-100 hover:text-slate-600 transition-colors", children: _jsx("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: _jsx("path", { d: "M3 6h18M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2" }) }) })), _jsx("button", { onClick: onClose, title: "Close", className: "flex h-6 w-6 items-center justify-center rounded-md text-slate-400 hover:bg-slate-100 hover:text-slate-600 transition-colors", children: _jsxs("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: [_jsx("path", { d: "M18 6 6 18" }), _jsx("path", { d: "m6 6 12 12" })] }) })] })] }), _jsxs("div", { className: "flex-1 overflow-y-auto px-4 py-3 space-y-3", children: [messages.length === 0 && (_jsxs("div", { className: "flex flex-col items-center justify-center h-full gap-3 text-center py-8", children: [_jsx("span", { className: "flex h-10 w-10 items-center justify-center rounded-full bg-indigo-50 text-indigo-400", children: _jsx("svg", { width: "20", height: "20", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("path", { d: "M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" }) }) }), _jsx("p", { className: "text-sm text-slate-500 max-w-[240px]", children: "Describe what you want to build and I'll help you create or modify the workflow." }), _jsx("div", { className: "flex flex-col gap-1.5 w-full", children: [
|
|
92
|
+
'Add an HTTP request step',
|
|
93
|
+
'Make this run on a schedule',
|
|
94
|
+
'Add error handling with a conditional',
|
|
95
|
+
].map((suggestion) => (_jsx("button", { onClick: () => setDraft(suggestion), className: "text-left text-xs text-slate-600 bg-slate-50 hover:bg-indigo-50 hover:text-indigo-700 rounded-lg px-3 py-2 border border-slate-200 hover:border-indigo-200 transition-colors", children: suggestion }, suggestion))) })] })), messages.map((msg, i) => {
|
|
96
|
+
// Extract attached document names and the visible prompt text
|
|
97
|
+
const docNames = [];
|
|
98
|
+
const visibleText = msg.content
|
|
99
|
+
.replace(/<document name="([^"]+)">[\s\S]*?<\/document>/g, (_, name) => {
|
|
100
|
+
docNames.push(name);
|
|
101
|
+
return '';
|
|
102
|
+
})
|
|
103
|
+
.trim();
|
|
104
|
+
return (_jsx("div", { className: cn('flex', msg.role === 'user' ? 'justify-end' : 'justify-start'), children: _jsxs("div", { className: cn('max-w-[85%] rounded-2xl px-3 py-2 text-sm leading-relaxed space-y-1.5', msg.role === 'user'
|
|
105
|
+
? 'bg-indigo-600 text-white rounded-br-sm'
|
|
106
|
+
: 'bg-slate-100 text-slate-700 rounded-bl-sm'), children: [docNames.map((name) => (_jsxs("div", { className: "flex items-center gap-1.5 rounded-lg bg-white/20 px-2 py-1", children: [_jsxs("svg", { width: "11", height: "11", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "shrink-0", children: [_jsx("path", { d: "M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z" }), _jsx("polyline", { points: "14 2 14 8 20 8" })] }), _jsx("span", { className: "text-xs font-medium truncate", children: name })] }, name))), visibleText && _jsx("p", { className: "whitespace-pre-wrap", children: visibleText })] }) }, i));
|
|
107
|
+
}), isLoading && (_jsx("div", { className: "flex justify-start", children: _jsx("div", { className: "bg-slate-100 rounded-2xl rounded-bl-sm px-3 py-2", children: _jsxs("div", { className: "flex items-center gap-1", children: [_jsx("span", { className: "h-1.5 w-1.5 rounded-full bg-slate-400 animate-bounce [animation-delay:0ms]" }), _jsx("span", { className: "h-1.5 w-1.5 rounded-full bg-slate-400 animate-bounce [animation-delay:150ms]" }), _jsx("span", { className: "h-1.5 w-1.5 rounded-full bg-slate-400 animate-bounce [animation-delay:300ms]" })] }) }) })), error && (_jsx("div", { className: "rounded-lg bg-red-50 border border-red-100 px-3 py-2 text-xs text-red-600", children: error })), isSaving && (_jsxs("div", { className: "rounded-xl border border-indigo-200 bg-indigo-50 px-3 py-2 text-xs text-indigo-600 italic flex items-center gap-1.5", children: [_jsx("svg", { className: "animate-spin shrink-0", width: "11", height: "11", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", children: _jsx("path", { d: "M21 12a9 9 0 1 1-6.219-8.56" }) }), "Applying and saving\u2026"] })), _jsx("div", { ref: messagesEndRef })] }), _jsxs("div", { className: "border-t border-slate-100 p-3 space-y-2", children: [attachedFile && (_jsxs("div", { className: "flex items-center gap-2 rounded-lg border border-indigo-200 bg-indigo-50 px-2.5 py-1.5", children: [_jsxs("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "shrink-0 text-indigo-500", children: [_jsx("path", { d: "M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z" }), _jsx("polyline", { points: "14 2 14 8 20 8" })] }), _jsx("span", { className: "flex-1 truncate text-xs font-medium text-indigo-700", children: attachedFile.name }), _jsx("button", { onClick: () => setAttachedFile(null), className: "shrink-0 text-indigo-400 hover:text-indigo-600 transition-colors", children: _jsxs("svg", { width: "12", height: "12", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", children: [_jsx("path", { d: "M18 6 6 18" }), _jsx("path", { d: "m6 6 12 12" })] }) })] })), _jsxs("div", { className: "flex items-end gap-2 rounded-xl border border-slate-200 bg-slate-50 px-3 py-2.5 focus-within:border-indigo-300 focus-within:bg-white transition-colors", children: [_jsx("input", { ref: fileInputRef, type: "file", accept: ".md,.json,.txt,.pdf,text/markdown,text/plain,application/json,application/pdf", className: "hidden", onChange: (e) => void handleFileSelect(e) }), _jsx("button", { title: "Attach .md or .pdf", disabled: isLoading || isUploading, onClick: () => fileInputRef.current?.click(), className: cn('flex h-7 w-7 flex-shrink-0 self-end items-center justify-center rounded-lg transition-all', isLoading || isUploading
|
|
108
|
+
? 'text-slate-300 cursor-not-allowed'
|
|
109
|
+
: attachedFile
|
|
110
|
+
? 'text-indigo-500 hover:bg-indigo-50'
|
|
111
|
+
: 'text-slate-400 hover:bg-slate-200 hover:text-slate-600 active:scale-95'), children: isUploading ? (_jsx("svg", { className: "animate-spin", width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", children: _jsx("path", { d: "M21 12a9 9 0 1 1-6.219-8.56" }) })) : (_jsx("svg", { width: "14", height: "14", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("path", { d: "M21.44 11.05l-9.19 9.19a6 6 0 0 1-8.49-8.49l9.19-9.19a4 4 0 0 1 5.66 5.66l-9.2 9.19a2 2 0 0 1-2.83-2.83l8.49-8.48" }) })) }), _jsx("textarea", { ref: textareaRef, value: draft, onChange: (e) => {
|
|
112
|
+
setDraft(e.target.value);
|
|
113
|
+
e.target.style.height = 'auto';
|
|
114
|
+
e.target.style.height = `${Math.min(e.target.scrollHeight, 96)}px`;
|
|
115
|
+
}, onKeyDown: handleKeyDown, placeholder: attachedFile ? 'Add a prompt or send as-is…' : 'Ask anything about your workflow…', rows: 1, className: "flex-1 resize-none bg-transparent text-sm text-slate-700 placeholder-slate-400 outline-none", style: { minHeight: '22px', maxHeight: '96px' } }), _jsx("button", { onClick: () => void handleSend(), disabled: (!draft.trim() && !attachedFile) || isLoading, className: cn('flex h-7 w-7 flex-shrink-0 self-end items-center justify-center rounded-lg transition-all', (draft.trim() || attachedFile) && !isLoading
|
|
116
|
+
? 'bg-indigo-600 text-white hover:bg-indigo-700 active:scale-95'
|
|
117
|
+
: 'bg-slate-200 text-slate-400 cursor-not-allowed'), children: _jsx("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("path", { d: "M22 2 11 13M22 2 15 22l-4-9-9-4 20-7z" }) }) })] }), _jsx("p", { className: "text-center text-[10px] text-slate-400", children: "Enter to send \u00B7 Shift+Enter for newline" })] })] })) }));
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=AiBuilderPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AiBuilderPanel.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/AiBuilderPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,8 @@ interface BranchContainerProps {
|
|
|
4
4
|
stepId: string;
|
|
5
5
|
branches: Record<string, DetectedBranch>;
|
|
6
6
|
category?: string | undefined;
|
|
7
|
+
/** Box header label (the step's name, e.g. "Parallel" / "Conditional" / "Switch"). */
|
|
8
|
+
label?: string | undefined;
|
|
7
9
|
/** For dynamic branch containers (PARALLEL) — the config key holding the record */
|
|
8
10
|
dynamicContainer?: string | undefined;
|
|
9
11
|
readOnly: boolean;
|
|
@@ -12,6 +14,6 @@ interface BranchContainerProps {
|
|
|
12
14
|
/** Render function for branch content — provided by WorkflowTree */
|
|
13
15
|
renderBranch: (branchKey: string, steps: WorkflowStepConfig[]) => React.ReactNode;
|
|
14
16
|
}
|
|
15
|
-
export declare function BranchContainer({ branches, category, dynamicContainer, readOnly, onAddBranch, onRenameBranch, renderBranch, }: BranchContainerProps): import("react").JSX.Element;
|
|
17
|
+
export declare function BranchContainer({ branches, category, label, dynamicContainer, readOnly, onAddBranch, onRenameBranch, renderBranch, }: BranchContainerProps): import("react").JSX.Element;
|
|
16
18
|
export {};
|
|
17
19
|
//# sourceMappingURL=BranchContainer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BranchContainer.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/BranchContainer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AAIzE,UAAU,oBAAoB;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IACzC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,mFAAmF;IACnF,gBAAgB,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACtC,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5D,oEAAoE;IACpE,YAAY,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,kBAAkB,EAAE,KAAK,KAAK,CAAC,SAAS,CAAC;CACnF;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,QAAQ,EACR,gBAAgB,EAChB,QAAQ,EACR,WAAW,EACX,cAAc,EACd,YAAY,GACb,EAAE,oBAAoB,+
|
|
1
|
+
{"version":3,"file":"BranchContainer.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/BranchContainer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AAIzE,UAAU,oBAAoB;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IACzC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,sFAAsF;IACtF,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,mFAAmF;IACnF,gBAAgB,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACtC,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5D,oEAAoE;IACpE,YAAY,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,kBAAkB,EAAE,KAAK,KAAK,CAAC,SAAS,CAAC;CACnF;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,QAAQ,EACR,KAAK,EACL,gBAAgB,EAChB,QAAQ,EACR,WAAW,EACX,cAAc,EACd,YAAY,GACb,EAAE,oBAAoB,+BAqMtB"}
|
|
@@ -2,7 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
2
2
|
import { useCallback, useState } from 'react';
|
|
3
3
|
import { cn } from '../../shared/cn.js';
|
|
4
4
|
import { getCategoryTheme } from '../theme.js';
|
|
5
|
-
export function BranchContainer({ branches, category, dynamicContainer, readOnly, onAddBranch, onRenameBranch, renderBranch, }) {
|
|
5
|
+
export function BranchContainer({ branches, category, label, dynamicContainer, readOnly, onAddBranch, onRenameBranch, renderBranch, }) {
|
|
6
6
|
const theme = getCategoryTheme(category);
|
|
7
7
|
const entries = Object.entries(branches);
|
|
8
8
|
const [showInput, setShowInput] = useState(false);
|
|
@@ -17,48 +17,46 @@ export function BranchContainer({ branches, category, dynamicContainer, readOnly
|
|
|
17
17
|
setShowInput(false);
|
|
18
18
|
}
|
|
19
19
|
}, [branchName, onAddBranch]);
|
|
20
|
-
return (_jsxs("div", { className: "flex flex-col items-center", children: [
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
maxWidth: '100%',
|
|
62
|
-
} }), _jsx("div", { className: "h-4 w-px bg-slate-300" })] }));
|
|
20
|
+
return (_jsxs("div", { className: "flex flex-col items-center", children: [_jsxs("div", { className: cn('relative rounded-xl border-2 border-dashed px-6', 'bg-gradient-to-b from-slate-50/80 to-white'), style: { borderColor: `${theme.edgeColor}40` }, children: [_jsxs("div", { className: cn('absolute -top-3 left-4 flex items-center gap-1.5 rounded-full px-2.5 py-0.5', 'text-[10px] font-semibold uppercase tracking-wider', theme.iconBg, theme.iconText), children: [_jsxs("svg", { width: "10", height: "10", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("line", { x1: "6", x2: "6", y1: "3", y2: "15" }), _jsx("circle", { cx: "18", cy: "6", r: "3" }), _jsx("circle", { cx: "6", cy: "18", r: "3" }), _jsx("path", { d: "M18 9a9 9 0 0 1-9 9" })] }), label ?? 'Branches'] }), _jsx("div", { className: "mx-auto h-4 w-px bg-slate-300" }), _jsx("div", { className: "h-px rounded-full", style: {
|
|
21
|
+
backgroundColor: theme.edgeColor,
|
|
22
|
+
opacity: 0.4,
|
|
23
|
+
width: '100%',
|
|
24
|
+
minWidth: `${entries.length * 200}px`,
|
|
25
|
+
} }), _jsxs("div", { className: "flex items-stretch gap-4", children: [entries.map(([branchKey, branch]) => (_jsxs("div", { className: "flex flex-col items-center", style: { minWidth: '200px' }, children: [editingKey === branchKey ? (_jsx("input", { type: "text", value: editValue, onChange: (e) => setEditValue(e.target.value), onKeyDown: (e) => {
|
|
26
|
+
e.stopPropagation();
|
|
27
|
+
if (e.key === 'Enter') {
|
|
28
|
+
const name = editValue.trim();
|
|
29
|
+
if (name && name !== branchKey && onRenameBranch) {
|
|
30
|
+
onRenameBranch(branchKey, name);
|
|
31
|
+
}
|
|
32
|
+
setEditingKey(null);
|
|
33
|
+
}
|
|
34
|
+
if (e.key === 'Escape')
|
|
35
|
+
setEditingKey(null);
|
|
36
|
+
}, onBlur: () => {
|
|
37
|
+
const name = editValue.trim();
|
|
38
|
+
if (name && name !== branchKey && onRenameBranch) {
|
|
39
|
+
onRenameBranch(branchKey, name);
|
|
40
|
+
}
|
|
41
|
+
setEditingKey(null);
|
|
42
|
+
}, onClick: (e) => e.stopPropagation(), autoFocus: true, className: cn('mb-2 mt-1 w-24 rounded-full px-3 py-0.5 text-[10px] font-semibold uppercase tracking-wider text-center outline-none', 'border border-indigo-300 ring-1 ring-indigo-100', theme.lightBg, theme.iconText) })) : (_jsx("div", { className: cn('mb-2 mt-1 rounded-full px-3 py-0.5 text-[10px] font-semibold uppercase tracking-wider', theme.lightBg, theme.iconText, dynamicContainer && !readOnly && 'cursor-pointer hover:ring-1 hover:ring-indigo-200 transition-all'), onDoubleClick: () => {
|
|
43
|
+
if (dynamicContainer && !readOnly) {
|
|
44
|
+
setEditingKey(branchKey);
|
|
45
|
+
setEditValue(branchKey);
|
|
46
|
+
}
|
|
47
|
+
}, title: dynamicContainer && !readOnly ? 'Double-click to rename' : undefined, children: branch.label })), _jsx("div", { className: "h-4 w-px bg-slate-300" }), _jsx("div", { className: "flex flex-col items-center", children: renderBranch(branchKey, branch.steps) }), _jsx("div", { className: "min-h-[16px] w-px flex-1 bg-slate-300" })] }, branchKey))), dynamicContainer && !readOnly && !showInput && (_jsx("div", { className: "flex flex-col items-center justify-start pt-1", children: _jsxs("button", { onClick: (e) => { e.stopPropagation(); setShowInput(true); }, className: cn('flex h-8 items-center gap-1.5 rounded-full border border-dashed px-3', 'border-slate-300 text-slate-400 text-[11px] font-medium', 'hover:border-indigo-400 hover:text-indigo-500 transition-all'), children: [_jsxs("svg", { width: "10", height: "10", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", children: [_jsx("path", { d: "M12 5v14" }), _jsx("path", { d: "M5 12h14" })] }), "Branch"] }) })), showInput && (_jsx("div", { className: "flex flex-col items-center justify-start pt-1", children: _jsxs("div", { className: "flex items-center gap-1.5", children: [_jsx("input", { type: "text", value: branchName, onChange: (e) => setBranchName(e.target.value), onKeyDown: (e) => {
|
|
48
|
+
e.stopPropagation();
|
|
49
|
+
if (e.key === 'Enter')
|
|
50
|
+
handleAdd();
|
|
51
|
+
if (e.key === 'Escape') {
|
|
52
|
+
setShowInput(false);
|
|
53
|
+
setBranchName('');
|
|
54
|
+
}
|
|
55
|
+
}, onClick: (e) => e.stopPropagation(), placeholder: "Branch name...", autoFocus: true, className: "w-28 rounded border border-slate-200 bg-slate-50 px-2 py-1 text-[11px] text-slate-700 outline-none focus:border-indigo-300 focus:ring-1 focus:ring-indigo-100" }), _jsx("button", { onClick: (e) => { e.stopPropagation(); handleAdd(); }, className: "flex h-6 w-6 items-center justify-center rounded bg-indigo-500 text-white hover:bg-indigo-600 transition-colors", children: _jsx("svg", { width: "10", height: "10", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", children: _jsx("path", { d: "M20 6 9 17l-5-5" }) }) })] }) }))] }), _jsx("div", { className: "h-px rounded-full", style: {
|
|
56
|
+
backgroundColor: theme.edgeColor,
|
|
57
|
+
opacity: 0.4,
|
|
58
|
+
width: '100%',
|
|
59
|
+
minWidth: `${entries.length * 200}px`,
|
|
60
|
+
} }), _jsx("div", { className: "mx-auto h-4 w-px bg-slate-300" })] }), _jsx("div", { className: "h-4 w-px bg-slate-300" })] }));
|
|
63
61
|
}
|
|
64
62
|
//# sourceMappingURL=BranchContainer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BranchContainer.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/BranchContainer.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAG9C,OAAO,EAAE,EAAE,EAAE,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"BranchContainer.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/BranchContainer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -6,6 +6,8 @@ export interface BuilderToolbarProps {
|
|
|
6
6
|
onZoomIn: () => void;
|
|
7
7
|
onZoomOut: () => void;
|
|
8
8
|
onFitView: () => void;
|
|
9
|
+
showAiPanel?: boolean;
|
|
10
|
+
onToggleAiPanel?: () => void;
|
|
9
11
|
}
|
|
10
|
-
export declare function BuilderToolbar({ canUndo, canRedo, onUndo, onRedo, onZoomIn, onZoomOut, onFitView, }: BuilderToolbarProps): import("react").JSX.Element;
|
|
12
|
+
export declare function BuilderToolbar({ canUndo, canRedo, onUndo, onRedo, onZoomIn, onZoomOut, onFitView, showAiPanel, onToggleAiPanel, }: BuilderToolbarProps): import("react").JSX.Element;
|
|
11
13
|
//# sourceMappingURL=BuilderToolbar.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BuilderToolbar.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/BuilderToolbar.tsx"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,SAAS,EAAE,MAAM,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"BuilderToolbar.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/BuilderToolbar.tsx"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,IAAI,CAAC;CAC9B;AAkCD,wBAAgB,cAAc,CAAC,EAC7B,OAAO,EACP,OAAO,EACP,MAAM,EACN,MAAM,EACN,QAAQ,EACR,SAAS,EACT,SAAS,EACT,WAAW,EACX,eAAe,GAChB,EAAE,mBAAmB,+BA8DrB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
2
|
import { cn } from '../../shared/cn.js';
|
|
3
3
|
function ToolbarButton({ title, disabled, onClick, children, }) {
|
|
4
4
|
return (_jsx("button", { title: title, disabled: disabled, onClick: onClick, className: cn('flex h-8 w-8 items-center justify-center rounded-lg transition-all', disabled
|
|
@@ -8,7 +8,9 @@ function ToolbarButton({ title, disabled, onClick, children, }) {
|
|
|
8
8
|
function Divider() {
|
|
9
9
|
return _jsx("div", { className: "mx-0.5 h-5 w-px bg-slate-200" });
|
|
10
10
|
}
|
|
11
|
-
export function BuilderToolbar({ canUndo, canRedo, onUndo, onRedo, onZoomIn, onZoomOut, onFitView, }) {
|
|
12
|
-
return (_jsxs("div", { className: cn('absolute bottom-4 left-1/2 z-20 -translate-x-1/2', 'flex items-center gap-0.5 rounded-xl border border-slate-200/80 bg-white/95 px-1.5 py-1 shadow-lg backdrop-blur-sm', 'animate-[wui-fade-in_200ms_ease-out]'), children: [_jsx(ToolbarButton, { title: "Undo (Ctrl+Z)", disabled: !canUndo, onClick: onUndo, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M3 7v6h6" }), _jsx("path", { d: "M21 17a9 9 0 0 0-9-9 9 9 0 0 0-6.69 3L3 13" })] }) }), _jsx(ToolbarButton, { title: "Redo (Ctrl+Shift+Z)", disabled: !canRedo, onClick: onRedo, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M21 7v6h-6" }), _jsx("path", { d: "M3 17a9 9 0 0 1 9-9 9 9 0 0 1 6.69 3L21 13" })] }) }), _jsx(Divider, {}), _jsx(ToolbarButton, { title: "Zoom out", onClick: onZoomOut, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: [_jsx("circle", { cx: "11", cy: "11", r: "8" }), _jsx("path", { d: "m21 21-4.3-4.3" }), _jsx("path", { d: "M8 11h6" })] }) }), _jsx(ToolbarButton, { title: "Fit view", onClick: onFitView, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M8 3H5a2 2 0 0 0-2 2v3" }), _jsx("path", { d: "M21 8V5a2 2 0 0 0-2-2h-3" }), _jsx("path", { d: "M3 16v3a2 2 0 0 0 2 2h3" }), _jsx("path", { d: "M16 21h3a2 2 0 0 0 2-2v-3" })] }) }), _jsx(ToolbarButton, { title: "Zoom in", onClick: onZoomIn, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: [_jsx("circle", { cx: "11", cy: "11", r: "8" }), _jsx("path", { d: "m21 21-4.3-4.3" }), _jsx("path", { d: "M11 8v6" }), _jsx("path", { d: "M8 11h6" })] }) })
|
|
11
|
+
export function BuilderToolbar({ canUndo, canRedo, onUndo, onRedo, onZoomIn, onZoomOut, onFitView, showAiPanel, onToggleAiPanel, }) {
|
|
12
|
+
return (_jsxs("div", { className: cn('absolute bottom-4 left-1/2 z-20 -translate-x-1/2', 'flex items-center gap-0.5 rounded-xl border border-slate-200/80 bg-white/95 px-1.5 py-1 shadow-lg backdrop-blur-sm', 'animate-[wui-fade-in_200ms_ease-out]'), children: [_jsx(ToolbarButton, { title: "Undo (Ctrl+Z)", disabled: !canUndo, onClick: onUndo, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M3 7v6h6" }), _jsx("path", { d: "M21 17a9 9 0 0 0-9-9 9 9 0 0 0-6.69 3L3 13" })] }) }), _jsx(ToolbarButton, { title: "Redo (Ctrl+Shift+Z)", disabled: !canRedo, onClick: onRedo, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M21 7v6h-6" }), _jsx("path", { d: "M3 17a9 9 0 0 1 9-9 9 9 0 0 1 6.69 3L21 13" })] }) }), _jsx(Divider, {}), _jsx(ToolbarButton, { title: "Zoom out", onClick: onZoomOut, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: [_jsx("circle", { cx: "11", cy: "11", r: "8" }), _jsx("path", { d: "m21 21-4.3-4.3" }), _jsx("path", { d: "M8 11h6" })] }) }), _jsx(ToolbarButton, { title: "Fit view", onClick: onFitView, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M8 3H5a2 2 0 0 0-2 2v3" }), _jsx("path", { d: "M21 8V5a2 2 0 0 0-2-2h-3" }), _jsx("path", { d: "M3 16v3a2 2 0 0 0 2 2h3" }), _jsx("path", { d: "M16 21h3a2 2 0 0 0 2-2v-3" })] }) }), _jsx(ToolbarButton, { title: "Zoom in", onClick: onZoomIn, children: _jsxs("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", children: [_jsx("circle", { cx: "11", cy: "11", r: "8" }), _jsx("path", { d: "m21 21-4.3-4.3" }), _jsx("path", { d: "M11 8v6" }), _jsx("path", { d: "M8 11h6" })] }) }), onToggleAiPanel && (_jsxs(_Fragment, { children: [_jsx(Divider, {}), _jsxs("button", { title: showAiPanel ? 'Close AI assistant' : 'Ask AI', onClick: onToggleAiPanel, className: cn('flex h-8 items-center gap-1.5 rounded-lg px-2.5 text-xs font-medium transition-all active:scale-95', showAiPanel
|
|
13
|
+
? 'bg-indigo-600 text-white hover:bg-indigo-700'
|
|
14
|
+
: 'text-indigo-600 hover:bg-indigo-50'), children: [_jsx("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("path", { d: "M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" }) }), "Ask AI"] })] }))] }));
|
|
13
15
|
}
|
|
14
16
|
//# sourceMappingURL=BuilderToolbar.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BuilderToolbar.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/BuilderToolbar.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"BuilderToolbar.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/BuilderToolbar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface DeleteStepDialogProps {
|
|
2
|
+
/** Label of the step being deleted. */
|
|
3
|
+
stepLabel: string;
|
|
4
|
+
/** Labels of steps that reference the one being deleted. */
|
|
5
|
+
referencingLabels: string[];
|
|
6
|
+
onCancel: () => void;
|
|
7
|
+
onConfirm: () => void;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Warns before deleting a step that other steps reference via `{{…}}`. After
|
|
11
|
+
* deletion those steps' references break — they'll be flagged by validation.
|
|
12
|
+
*/
|
|
13
|
+
export declare function DeleteStepDialog({ stepLabel, referencingLabels, onCancel, onConfirm, }: DeleteStepDialogProps): import("react").JSX.Element;
|
|
14
|
+
//# sourceMappingURL=DeleteStepDialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DeleteStepDialog.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/DeleteStepDialog.tsx"],"names":[],"mappings":"AAEA,MAAM,WAAW,qBAAqB;IACpC,uCAAuC;IACvC,SAAS,EAAE,MAAM,CAAC;IAClB,4DAA4D;IAC5D,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,EAC/B,SAAS,EACT,iBAAiB,EACjB,QAAQ,EACR,SAAS,GACV,EAAE,qBAAqB,+BAwDvB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from '../../shared/cn.js';
|
|
3
|
+
/**
|
|
4
|
+
* Warns before deleting a step that other steps reference via `{{…}}`. After
|
|
5
|
+
* deletion those steps' references break — they'll be flagged by validation.
|
|
6
|
+
*/
|
|
7
|
+
export function DeleteStepDialog({ stepLabel, referencingLabels, onCancel, onConfirm, }) {
|
|
8
|
+
return (_jsxs("div", { className: "fixed inset-0 z-50 flex items-center justify-center", "data-testid": "delete-step-dialog", children: [_jsx("div", { className: "absolute inset-0 bg-black/30", onClick: onCancel }), _jsxs("div", { className: cn('relative z-10 w-full max-w-md rounded-xl border border-slate-200 bg-white shadow-xl', 'animate-[wui-fade-in_150ms_ease-out]'), children: [_jsxs("div", { className: "flex items-center gap-2 border-b border-slate-200/80 px-5 py-3.5", children: [_jsx("span", { className: "flex h-6 w-6 items-center justify-center rounded-full bg-amber-100 text-amber-600", children: _jsxs("svg", { width: "13", height: "13", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3Z" }), _jsx("path", { d: "M12 9v4" }), _jsx("path", { d: "M12 17h.01" })] }) }), _jsxs("h3", { className: "text-sm font-semibold text-slate-800", children: ["Delete \u201C", stepLabel, "\u201D?"] })] }), _jsxs("div", { className: "px-5 py-4 text-[13px] text-slate-600", children: [_jsxs("p", { className: "mb-2", children: [referencingLabels.length, " ", referencingLabels.length === 1 ? 'step references' : 'steps reference', " this step's output. Deleting it will break ", referencingLabels.length === 1 ? 'that reference' : 'those references', ":"] }), _jsx("ul", { className: "space-y-1 rounded-lg border border-slate-200 bg-slate-50 px-3 py-2", children: referencingLabels.map((label, i) => (_jsxs("li", { className: "flex items-center gap-1.5 text-slate-700", children: [_jsx("span", { className: "h-1.5 w-1.5 rounded-full bg-amber-400" }), label] }, i))) })] }), _jsxs("div", { className: "flex items-center justify-end gap-2 border-t border-slate-200/80 px-5 py-3", children: [_jsx("button", { type: "button", onClick: onCancel, className: "rounded-md px-3.5 py-1.5 text-[13px] font-semibold text-slate-500 hover:bg-slate-100", children: "Cancel" }), _jsx("button", { type: "button", "data-testid": "delete-anyway", onClick: onConfirm, className: "rounded-md bg-red-500 px-3.5 py-1.5 text-[13px] font-semibold text-white shadow-sm hover:bg-red-600", children: "Delete anyway" })] })] })] }));
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=DeleteStepDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DeleteStepDialog.js","sourceRoot":"","sources":["../../../../src/components/builder/v3/DeleteStepDialog.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,oBAAoB,CAAC;AAWxC;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAAC,EAC/B,SAAS,EACT,iBAAiB,EACjB,QAAQ,EACR,SAAS,GACa;IACtB,OAAO,CACL,eAAK,SAAS,EAAC,qDAAqD,iBAAa,oBAAoB,aACnG,cAAK,SAAS,EAAC,8BAA8B,EAAC,OAAO,EAAE,QAAQ,GAAI,EAEnE,eAAK,SAAS,EAAE,EAAE,CAChB,qFAAqF,EACrF,sCAAsC,CACvC,aAEC,eAAK,SAAS,EAAC,kEAAkE,aAC/E,eAAM,SAAS,EAAC,mFAAmF,YACjG,eAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,KAAK,EAAC,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,aAC9I,eAAM,CAAC,EAAC,2EAA2E,GAAG,EAAA,eAAM,CAAC,EAAC,SAAS,GAAG,EAAA,eAAM,CAAC,EAAC,YAAY,GAAG,IAC7H,GACD,EACP,cAAI,SAAS,EAAC,sCAAsC,8BAAU,SAAS,eAAQ,IAC3E,EAGN,eAAK,SAAS,EAAC,sCAAsC,aACnD,aAAG,SAAS,EAAC,MAAM,aAChB,iBAAiB,CAAC,MAAM,OAAG,iBAAiB,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,kDAC1E,iBAAiB,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,kBAAkB,SAC5F,EACJ,aAAI,SAAS,EAAC,oEAAoE,YAC/E,iBAAiB,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,CACnC,cAAY,SAAS,EAAC,0CAA0C,aAC9D,eAAM,SAAS,EAAC,uCAAuC,GAAG,EACzD,KAAK,KAFC,CAAC,CAGL,CACN,CAAC,GACC,IACD,EAGN,eAAK,SAAS,EAAC,4EAA4E,aACzF,iBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,QAAQ,EACjB,SAAS,EAAC,sFAAsF,uBAGzF,EACT,iBACE,IAAI,EAAC,QAAQ,iBACD,eAAe,EAC3B,OAAO,EAAE,SAAS,EAClB,SAAS,EAAC,qGAAqG,8BAGxG,IACL,IACF,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EnhancedSchemaFormRenderer.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/EnhancedSchemaFormRenderer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAYzE,MAAM,WAAW,+BAA+B;IAC9C,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IACjD,MAAM,EAAE,cAAc,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;CAChC;
|
|
1
|
+
{"version":3,"file":"EnhancedSchemaFormRenderer.d.ts","sourceRoot":"","sources":["../../../../src/components/builder/v3/EnhancedSchemaFormRenderer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAYzE,MAAM,WAAW,+BAA+B;IAC9C,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IACjD,MAAM,EAAE,cAAc,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;CAChC;AAqBD,wBAAgB,0BAA0B,CAAC,EACzC,MAAM,EACN,MAAM,EACN,MAAM,EACN,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,QAAQ,GACT,EAAE,+BAA+B,+BAiBjC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useMemo } from 'react';
|
|
2
|
+
import { useMemo, useState } from 'react';
|
|
3
3
|
import { itemSchemaToFields, detectItemDiscriminatedUnion } from '../../../hooks/use-schema-form.js';
|
|
4
4
|
import { VariableRefInput } from './VariableRefInput.js';
|
|
5
5
|
import { KeyValueEditor } from './KeyValueEditor.js';
|
|
@@ -10,6 +10,12 @@ import { StringArrayInput } from './StringArrayInput.js';
|
|
|
10
10
|
import { MultiSelectCheckboxes } from './MultiSelectCheckboxes.js';
|
|
11
11
|
import { InputSchemaBuilder } from './InputSchemaBuilder.js';
|
|
12
12
|
import { cn } from '../../shared/cn.js';
|
|
13
|
+
/** Field types where a typed editor exists but the whole field can also bind to a `{{ref}}`. */
|
|
14
|
+
const VAR_BINDABLE_TYPES = new Set(['boolean', 'number', 'integer', 'array', 'object']);
|
|
15
|
+
/** True if the value is exactly one `{{...}}` reference (no surrounding text). */
|
|
16
|
+
function isPureRefValue(v) {
|
|
17
|
+
return typeof v === 'string' && /^\{\{[^}]+\}\}$/.test(v.trim());
|
|
18
|
+
}
|
|
13
19
|
function getNestedValue(obj, path) {
|
|
14
20
|
if (path === '')
|
|
15
21
|
return obj;
|
|
@@ -26,6 +32,12 @@ export function EnhancedSchemaFormRenderer({ fields, values, errors, onChange, c
|
|
|
26
32
|
return (_jsx("div", { className: "space-y-4", children: fields.map((field) => (_jsx(EnhancedFieldRenderer, { field: field, value: getNestedValue(values, field.path), error: errors[field.path], onChange: (val) => onChange(field.path, val), config: config, atStepId: atStepId, readOnly: readOnly }, field.path))) }));
|
|
27
33
|
}
|
|
28
34
|
function EnhancedFieldRenderer({ field, value, error, onChange, config, atStepId, readOnly, }) {
|
|
35
|
+
// "Use a variable" binding for fields that have a typed editor (the default
|
|
36
|
+
// string field already embeds the picker). Bound when toggled on or the
|
|
37
|
+
// current value is already a pure ref.
|
|
38
|
+
const supportsVarBinding = VAR_BINDABLE_TYPES.has(field.type) && field.format !== 'json-schema' && field.format !== 'output-fields';
|
|
39
|
+
const [useVar, setUseVar] = useState(false);
|
|
40
|
+
const boundToVar = supportsVarBinding && (useVar || isPureRefValue(value));
|
|
29
41
|
const inputClasses = cn('w-full rounded-lg border px-3 py-2 text-sm', 'bg-white text-[var(--wui-fg)]', 'outline-none transition-all', error
|
|
30
42
|
? 'border-red-300 focus:border-red-400 focus:ring-2 focus:ring-red-100'
|
|
31
43
|
: 'border-[var(--wui-border)] focus:border-[var(--wui-primary)] focus:ring-2 focus:ring-[var(--wui-primary)]/10', readOnly && 'opacity-60 cursor-not-allowed bg-[var(--wui-bg-subtle)]');
|
|
@@ -33,6 +45,10 @@ function EnhancedFieldRenderer({ field, value, error, onChange, config, atStepId
|
|
|
33
45
|
if (field.enumValues) {
|
|
34
46
|
return (_jsxs("select", { value: String(value ?? ''), onChange: (e) => onChange(e.target.value), disabled: readOnly, className: inputClasses, children: [_jsx("option", { value: "", children: "Select..." }), field.enumValues.map((v) => (_jsx("option", { value: v, children: v }, v)))] }));
|
|
35
47
|
}
|
|
48
|
+
// Whole-field bound to a variable ref (type-filtered picker).
|
|
49
|
+
if (boundToVar) {
|
|
50
|
+
return (_jsx(VariableRefInput, { value: value, onChange: onChange, config: config, atStepId: atStepId, placeholder: "{{ variable }}", disabled: readOnly, filterType: field.type }));
|
|
51
|
+
}
|
|
36
52
|
switch (field.type) {
|
|
37
53
|
case 'boolean': {
|
|
38
54
|
// Tri-state dropdown: True / False / (Unset for optional fields).
|
|
@@ -107,10 +123,17 @@ function EnhancedFieldRenderer({ field, value, error, onChange, config, atStepId
|
|
|
107
123
|
return (_jsx(CodeEditor, { value: String(value ?? ''), onChange: onChange, config: config, atStepId: atStepId, readOnly: readOnly }));
|
|
108
124
|
}
|
|
109
125
|
// All other string fields get the variable ref input with {{ }} picker
|
|
110
|
-
return (_jsx(VariableRefInput, { value: value, onChange: onChange, config: config, atStepId: atStepId, placeholder: field.placeholder ?? field.description, disabled: readOnly }));
|
|
126
|
+
return (_jsx(VariableRefInput, { value: value, onChange: onChange, config: config, atStepId: atStepId, placeholder: field.placeholder ?? field.description, disabled: readOnly, filterType: field.type }));
|
|
111
127
|
}
|
|
112
128
|
};
|
|
113
|
-
return (_jsxs("div", { className: "space-y-1.5", children: [_jsxs("label", { className: "flex items-center gap-1 text-xs font-medium text-[var(--wui-fg)]", children: [field.label, field.required && _jsx("span", { className: "text-red-400", children: "*" }), field.acceptsVariableRef && (_jsx("span", { className: "ml-auto rounded bg-indigo-50 px-1 py-0.5 text-[9px] font-semibold text-indigo-500", children: '{{var}}' }))] }), renderInput(),
|
|
129
|
+
return (_jsxs("div", { className: "space-y-1.5", children: [_jsxs("label", { className: "flex items-center gap-1 text-xs font-medium text-[var(--wui-fg)]", children: [field.label, field.required && _jsx("span", { className: "text-red-400", children: "*" }), field.acceptsVariableRef && (_jsx("span", { className: "ml-auto rounded bg-indigo-50 px-1 py-0.5 text-[9px] font-semibold text-indigo-500", children: '{{var}}' }))] }), renderInput(), !readOnly && supportsVarBinding && (_jsx("button", { type: "button", onClick: () => {
|
|
130
|
+
if (boundToVar) {
|
|
131
|
+
setUseVar(false);
|
|
132
|
+
onChange(undefined);
|
|
133
|
+
}
|
|
134
|
+
else
|
|
135
|
+
setUseVar(true);
|
|
136
|
+
}, className: "text-[10px] font-medium text-indigo-500 hover:underline", children: boundToVar ? 'Use a literal value' : 'Use a variable' })), field.description && (_jsx("p", { className: "text-[11px] leading-relaxed text-[var(--wui-fg-muted)]", children: field.description })), error && (_jsxs("p", { className: "flex items-center gap-1 text-[11px] text-red-500", children: [_jsxs("svg", { width: "10", height: "10", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", children: [_jsx("circle", { cx: "12", cy: "12", r: "10" }), _jsx("path", { d: "M12 8v4" }), _jsx("path", { d: "M12 16h.01" })] }), error] }))] }));
|
|
114
137
|
}
|
|
115
138
|
// ─── Array of objects editor ───
|
|
116
139
|
const DISC_PILL_COLORS = {
|
|
@@ -223,7 +246,7 @@ function ArrayItemField({ field, value, config, atStepId, readOnly, onChange, })
|
|
|
223
246
|
catch { /* invalid JSON */ }
|
|
224
247
|
}, disabled: readOnly, rows: 3, className: cn(inputClasses, 'font-mono text-[11px]'), placeholder: "[]" }));
|
|
225
248
|
default:
|
|
226
|
-
return (_jsx(VariableRefInput, { value: value, onChange: onChange, config: config, atStepId: atStepId, placeholder: field.placeholder ?? field.description, disabled: readOnly, compact: true }));
|
|
249
|
+
return (_jsx(VariableRefInput, { value: value, onChange: onChange, config: config, atStepId: atStepId, placeholder: field.placeholder ?? field.description, disabled: readOnly, compact: true, filterType: field.type }));
|
|
227
250
|
}
|
|
228
251
|
};
|
|
229
252
|
return (_jsxs("div", { className: "space-y-1", children: [_jsxs("label", { className: "flex items-center gap-1 text-[11px] font-medium text-slate-600", children: [field.label, field.required && _jsx("span", { className: "text-red-400 text-[10px]", children: "*" }), field.description && (_jsx("span", { className: "ml-auto text-[10px] font-normal text-slate-400 truncate max-w-[50%]", title: field.description, children: field.description }))] }), renderInput()] }));
|