@inkeep/agents-manage-ui 0.12.1 → 0.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/standalone/agents-manage-ui/.next/BUILD_ID +1 -1
- package/.next/standalone/agents-manage-ui/.next/app-build-manifest.json +122 -126
- package/.next/standalone/agents-manage-ui/.next/app-path-routes-manifest.json +6 -6
- package/.next/standalone/agents-manage-ui/.next/build-manifest.json +2 -2
- package/.next/standalone/agents-manage-ui/.next/prerender-manifest.json +13 -13
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/api-keys/page.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/api-keys/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/api-keys/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/new/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/artifacts/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/new/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/components/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/page.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/page.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/new/providers/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/credentials/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/[graphId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/[graphId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/[graphId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/new/page.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/graphs/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/edit/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/edit/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/edit/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/new/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/mcp-servers/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/settings/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/settings/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/settings/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/ai-calls/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/ai-calls/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/ai-calls/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/conversations/[conversationId]/page.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/conversations/[conversationId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/conversations/[conversationId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/page.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/traces/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/page.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/_not-found/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/_not-found.rsc +9 -9
- package/.next/standalone/agents-manage-ui/.next/server/app/api/signoz/conversations/[conversationId]/route_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/api/signoz/route_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app-paths-manifest.json +6 -6
- package/.next/standalone/agents-manage-ui/.next/server/chunks/2190.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/2415.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/{292.js → 245.js} +11 -11
- package/.next/standalone/agents-manage-ui/.next/server/chunks/2539.js +13 -13
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3547.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/{5546.js → 3672.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/{8096.js → 3884.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4843.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5495.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6212.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6229.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6525.js +4087 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6747.js +4 -4
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7346.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7538.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8100.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8610.js +25 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8615.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9340.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/pages/404.html +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/pages/500.html +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/server-reference-manifest.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/1558-8cb46768b5585f53.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/6497-2a72e838c6240f76.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/6501-2c90923d1b2f0f3e.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/7167-8e3d7b9e316f636b.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/7305-4bde6b1356d61f7a.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/8130-c153c48b1fab6cb4.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/{6443-dd27c846ef650d0a.js → 8486-01fbe9371d862c28.js} +6 -6
- package/.next/standalone/agents-manage-ui/.next/static/chunks/926-2d2311c975e35a35.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/api-keys/page-c241f711010e7e13.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/{page-61379a8d1c1a9ca1.js → page-c3c91cd61be884a4.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/new/{page-61379a8d1c1a9ca1.js → page-c3c91cd61be884a4.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/page-ebf80aff5a2957f1.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/page-6e9e120e0f0235de.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/new/page-6e9e120e0f0235de.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/page-930b7126b9182e8d.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/{page-7cfa34591d1a6acd.js → page-72c57c0fb9389280.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page-9deb7adcdeed1a80.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page-ea02a056bccd6124.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/page-a842eee6a4322d45.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/[graphId]/page-21f1392ae65ea31a.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/new/page-b7ee3944e6a5c03d.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/page-eb9c74bbc66bae57.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/edit/{page-8ce40458e68f1441.js → page-4498950740edb744.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/new/{page-2543a9b4438b0b03.js → page-05827d40bb0aaf12.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/page-ababf7c5aa5e0bc0.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/settings/{page-5a7b693a09f13234.js → page-d5fe05a40d56d36d.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/page-663da25347087a0f.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/page-1c25a0513febf08b.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/layout-462211bdc5e56272.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/css/ff74e9dcb72fa41b.css +1 -0
- package/.next/standalone/agents-manage-ui/package.json +4 -1
- package/.next/standalone/package.json +1 -0
- package/.next/standalone/packages/agents-core/package.json +1 -1
- package/package.json +7 -4
- package/src/components/form/expandable-field.tsx +17 -11
- package/src/components/form/generic-input.tsx +2 -2
- package/src/components/form/prompt-editor.tsx +245 -0
- package/src/components/graph/graph.tsx +7 -5
- package/src/components/graph/nodes/agent-node.tsx +4 -2
- package/src/components/graph/nodes/mcp-node.tsx +5 -3
- package/src/components/graph/sidepane/edges/edge-editor.tsx +2 -2
- package/src/components/graph/sidepane/metadata/metadata-editor.tsx +3 -4
- package/src/components/graph/sidepane/nodes/agent-node-editor.tsx +2 -4
- package/src/components/graph/sidepane/nodes/expandable-text-area.tsx +54 -14
- package/src/components/graph/sidepane/nodes/mcp-node-editor.tsx +6 -4
- package/src/components/projects/form/form-configuration.ts +1 -1
- package/src/components/projects/form/project-form.tsx +14 -8
- package/src/components/projects/form/project-models-section.tsx +26 -2
- package/src/components/projects/form/project-stopwhen-section.tsx +18 -2
- package/src/components/projects/form/validation.ts +13 -4
- package/src/components/projects/project-item.tsx +2 -1
- package/src/features/graph/commands/commands.ts +24 -24
- package/src/features/graph/state/use-graph-store.ts +199 -172
- package/src/features/graph/ui/use-graph-shortcuts.ts +2 -2
- package/src/hooks/use-graph-errors.ts +7 -9
- package/src/hooks/use-node-editor.ts +4 -4
- package/src/lib/__tests__/context-suggestions.test.ts +205 -0
- package/src/lib/context-suggestions.ts +102 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/1156.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3859.js +0 -25
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5232.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6114.js +0 -4087
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6997.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8298.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9812.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/1558-cf7aef893a85469e.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/2616-afea50e929636181.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/5635-a3e053f2a2633b0f.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/6497-5a3efd5d17896e0b.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/7167-d00c25860bc43555.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/7305-80fb496a6a7b01cf.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/api-keys/page-3e911bcedbdcc8b0.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/page-a6cfdce0698bfa2c.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/page-b16426d953306ee7.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/new/page-b16426d953306ee7.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/page-53ad78b81054c5f6.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page-46c8e4772748bf3c.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page-db65b50c3319a62c.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/page-08fc17f254e5278e.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/[graphId]/page-00765523b4cc6114.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/new/page-4791623af5ab27ea.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/graphs/page-b645d7373e4b7a62.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/page-15fba6cf333f2f2a.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/page-c5a019309939d912.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/page-750a94d65d9266d6.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/layout-c42ea39210c86d1d.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/css/02016a706b2fdd40.css +0 -1
- /package/.next/standalone/agents-manage-ui/.next/static/{5LuVpO2ZOs-I6neEc3jpn → YQiRd4Be9CAfAPdCkur2K}/_buildManifest.js +0 -0
- /package/.next/standalone/agents-manage-ui/.next/static/{5LuVpO2ZOs-I6neEc3jpn → YQiRd4Be9CAfAPdCkur2K}/_ssgManifest.js +0 -0
|
@@ -1,19 +1,28 @@
|
|
|
1
|
-
import { StopWhenSchema } from '@inkeep/agents-core/client-exports';
|
|
2
1
|
import { z } from 'zod';
|
|
3
2
|
|
|
4
3
|
const modelSettingsSchema = z.object({
|
|
5
4
|
model: z.string().optional(), // Allow empty model - system will fall back to defaults
|
|
6
|
-
providerOptions: z.record(z.string(), z.any()).optional(),
|
|
5
|
+
providerOptions: z.record(z.string(), z.any()).optional().nullable(),
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
const baseModelSettingsSchema = z.object({
|
|
9
|
+
model: z.string().min(1, 'Base model is required'),
|
|
10
|
+
providerOptions: z.record(z.string(), z.any()).optional().nullable(),
|
|
7
11
|
});
|
|
8
12
|
|
|
9
13
|
const projectModelsSchema = z.object({
|
|
10
|
-
base:
|
|
14
|
+
base: baseModelSettingsSchema,
|
|
11
15
|
structuredOutput: modelSettingsSchema.optional(),
|
|
12
16
|
summarizer: modelSettingsSchema.optional(),
|
|
13
17
|
});
|
|
14
18
|
|
|
15
19
|
// Use the shared StopWhen schema with optional and nullable modifiers
|
|
16
|
-
const projectStopWhenSchema =
|
|
20
|
+
const projectStopWhenSchema = z
|
|
21
|
+
.object({
|
|
22
|
+
transferCountIs: z.number().min(1).max(100).optional().nullable(),
|
|
23
|
+
stepCountIs: z.number().min(1).max(1000).optional().nullable(),
|
|
24
|
+
})
|
|
25
|
+
.optional();
|
|
17
26
|
|
|
18
27
|
export const projectSchema = z.object({
|
|
19
28
|
id: z
|
|
@@ -11,6 +11,7 @@ import {
|
|
|
11
11
|
ItemCardTitle,
|
|
12
12
|
} from '@/components/ui/item-card';
|
|
13
13
|
import type { Project } from '@/lib/types/project';
|
|
14
|
+
import type { ProjectFormData } from './form/validation';
|
|
14
15
|
import { ProjectItemMenu } from './project-item-menu';
|
|
15
16
|
|
|
16
17
|
export interface ProjectItemProps extends Project {
|
|
@@ -38,7 +39,7 @@ export function ProjectItem({
|
|
|
38
39
|
</ItemCardLink>
|
|
39
40
|
<ProjectItemMenu
|
|
40
41
|
projectName={name}
|
|
41
|
-
projectData={{ id: projectId, name, description, models, stopWhen }}
|
|
42
|
+
projectData={{ id: projectId, name, description, models, stopWhen } as ProjectFormData}
|
|
42
43
|
tenantId={tenantId}
|
|
43
44
|
/>
|
|
44
45
|
</ItemCardHeader>
|
|
@@ -2,7 +2,7 @@ import type { Connection, Edge, Node } from '@xyflow/react';
|
|
|
2
2
|
import { addEdge } from '@xyflow/react';
|
|
3
3
|
import { EdgeType } from '@/components/graph/configuration/edge-types';
|
|
4
4
|
import type { GraphMetadata } from '@/components/graph/configuration/graph-types';
|
|
5
|
-
import {
|
|
5
|
+
import { graphStore } from '@/features/graph/state/use-graph-store';
|
|
6
6
|
import { eventBus } from '@/lib/events';
|
|
7
7
|
import type { Command } from './command-manager';
|
|
8
8
|
|
|
@@ -13,25 +13,25 @@ export class AddNodeCommand implements Command {
|
|
|
13
13
|
this.node = node;
|
|
14
14
|
}
|
|
15
15
|
execute() {
|
|
16
|
-
const {
|
|
17
|
-
setNodes((prev) => prev.concat(this.node));
|
|
16
|
+
const { actions } = graphStore.getState();
|
|
17
|
+
actions.setNodes((prev) => prev.concat(this.node));
|
|
18
18
|
}
|
|
19
19
|
undo() {
|
|
20
|
-
const {
|
|
21
|
-
setNodes((prev) => prev.filter((n) => n.id !== this.node.id));
|
|
20
|
+
const { actions } = graphStore.getState();
|
|
21
|
+
actions.setNodes((prev) => prev.filter((n) => n.id !== this.node.id));
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
export class DeleteSelectionCommand implements Command {
|
|
26
26
|
readonly name = 'DeleteSelection';
|
|
27
27
|
execute() {
|
|
28
|
-
const {
|
|
29
|
-
deleteSelected();
|
|
28
|
+
const { actions } = graphStore.getState();
|
|
29
|
+
actions.deleteSelected();
|
|
30
30
|
}
|
|
31
31
|
undo() {
|
|
32
32
|
// relies on store history; in a richer system we'd capture diffs
|
|
33
|
-
const {
|
|
34
|
-
undo();
|
|
33
|
+
const { actions } = graphStore.getState();
|
|
34
|
+
actions.undo();
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
|
|
@@ -43,8 +43,8 @@ export class ConnectEdgeCommand implements Command {
|
|
|
43
43
|
this.connection = connection;
|
|
44
44
|
}
|
|
45
45
|
execute() {
|
|
46
|
-
const {
|
|
47
|
-
setEdges((eds) => {
|
|
46
|
+
const { actions } = graphStore.getState();
|
|
47
|
+
actions.setEdges((eds) => {
|
|
48
48
|
const newEdges = addEdge(this.connection as any, eds);
|
|
49
49
|
const last = newEdges[newEdges.length - 1];
|
|
50
50
|
this.createdEdgeId = last?.id ?? null;
|
|
@@ -53,9 +53,9 @@ export class ConnectEdgeCommand implements Command {
|
|
|
53
53
|
}
|
|
54
54
|
undo() {
|
|
55
55
|
if (!this.createdEdgeId) return;
|
|
56
|
-
const {
|
|
56
|
+
const { actions } = graphStore.getState();
|
|
57
57
|
const id = this.createdEdgeId;
|
|
58
|
-
setEdges((eds) => eds.filter((e) => e.id !== id));
|
|
58
|
+
actions.setEdges((eds) => eds.filter((e) => e.id !== id));
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
61
|
|
|
@@ -69,21 +69,21 @@ export class UpdateMetadataCommand implements Command {
|
|
|
69
69
|
this.value = value;
|
|
70
70
|
}
|
|
71
71
|
execute() {
|
|
72
|
-
const { metadata,
|
|
72
|
+
const { metadata, actions } = graphStore.getState();
|
|
73
73
|
this.prev = metadata[this.field];
|
|
74
|
-
setMetadata(this.field, this.value);
|
|
74
|
+
actions.setMetadata(this.field, this.value);
|
|
75
75
|
}
|
|
76
76
|
undo() {
|
|
77
|
-
const {
|
|
78
|
-
setMetadata(this.field, this.prev as any);
|
|
77
|
+
const { actions } = graphStore.getState();
|
|
78
|
+
actions.setMetadata(this.field, this.prev as any);
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
81
|
|
|
82
82
|
export class ClearSelectionCommand implements Command {
|
|
83
83
|
readonly name = 'ClearSelection';
|
|
84
84
|
execute() {
|
|
85
|
-
const {
|
|
86
|
-
clearSelection();
|
|
85
|
+
const { actions } = graphStore.getState();
|
|
86
|
+
actions.clearSelection();
|
|
87
87
|
}
|
|
88
88
|
undo() {
|
|
89
89
|
// no-op for now
|
|
@@ -99,12 +99,12 @@ export class AddPreparedEdgeCommand implements Command {
|
|
|
99
99
|
this.deselectOtherEdgesIfA2A = Boolean(options?.deselectOtherEdgesIfA2A);
|
|
100
100
|
}
|
|
101
101
|
execute() {
|
|
102
|
-
const {
|
|
102
|
+
const { actions } = graphStore.getState();
|
|
103
103
|
if (this.edge.type === EdgeType.A2A) {
|
|
104
104
|
// deselect nodes when creating an A2A edge
|
|
105
|
-
setNodes((nds) => nds.map((n) => ({ ...n, selected: false })));
|
|
105
|
+
actions.setNodes((nds) => nds.map((n) => ({ ...n, selected: false })));
|
|
106
106
|
}
|
|
107
|
-
setEdges((eds) => {
|
|
107
|
+
actions.setEdges((eds) => {
|
|
108
108
|
if (eds.some((e) => e.id === this.edge.id)) return eds;
|
|
109
109
|
const base =
|
|
110
110
|
this.deselectOtherEdgesIfA2A && this.edge.type === EdgeType.A2A
|
|
@@ -116,8 +116,8 @@ export class AddPreparedEdgeCommand implements Command {
|
|
|
116
116
|
});
|
|
117
117
|
}
|
|
118
118
|
undo() {
|
|
119
|
-
const {
|
|
119
|
+
const { actions } = graphStore.getState();
|
|
120
120
|
const id = this.edge.id;
|
|
121
|
-
setEdges((eds) => eds.filter((e) => e.id !== id));
|
|
121
|
+
actions.setEdges((eds) => eds.filter((e) => e.id !== id));
|
|
122
122
|
}
|
|
123
123
|
}
|
|
@@ -9,6 +9,7 @@ import type { ArtifactComponent } from '@/lib/api/artifact-components';
|
|
|
9
9
|
import type { DataComponent } from '@/lib/api/data-components';
|
|
10
10
|
import type { MCPTool } from '@/lib/types/tools';
|
|
11
11
|
import type { GraphErrorSummary } from '@/lib/utils/graph-error-parser';
|
|
12
|
+
import { useShallow } from 'zustand/react/shallow';
|
|
12
13
|
|
|
13
14
|
type HistoryEntry = { nodes: Node[]; edges: Edge[] };
|
|
14
15
|
|
|
@@ -27,7 +28,7 @@ type GraphStateData = {
|
|
|
27
28
|
showErrors: boolean;
|
|
28
29
|
};
|
|
29
30
|
|
|
30
|
-
type
|
|
31
|
+
type GraphActions = {
|
|
31
32
|
setInitial(
|
|
32
33
|
nodes: Node[],
|
|
33
34
|
edges: Edge[],
|
|
@@ -62,7 +63,11 @@ type GraphState = GraphStateData & {
|
|
|
62
63
|
getEdgeErrors(edgeId: string): GraphErrorSummary['allErrors'];
|
|
63
64
|
};
|
|
64
65
|
|
|
65
|
-
|
|
66
|
+
type GraphState = GraphStateData & {
|
|
67
|
+
actions: GraphActions;
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
export const graphStore = create<GraphState>()(
|
|
66
71
|
devtools((set, get) => ({
|
|
67
72
|
nodes: [],
|
|
68
73
|
edges: [],
|
|
@@ -90,186 +95,208 @@ export const useGraphStore = create<GraphState>()(
|
|
|
90
95
|
future: [],
|
|
91
96
|
errors: null,
|
|
92
97
|
showErrors: false,
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
metadata,
|
|
97
|
-
dataComponentLookup = {},
|
|
98
|
-
artifactComponentLookup = {},
|
|
99
|
-
toolLookup = {},
|
|
100
|
-
agentToolConfigLookup = {}
|
|
101
|
-
) {
|
|
102
|
-
set({
|
|
98
|
+
// Separate "namespace" for actions
|
|
99
|
+
actions: {
|
|
100
|
+
setInitial(
|
|
103
101
|
nodes,
|
|
104
102
|
edges,
|
|
105
103
|
metadata,
|
|
106
|
-
dataComponentLookup,
|
|
107
|
-
artifactComponentLookup,
|
|
108
|
-
toolLookup,
|
|
109
|
-
agentToolConfigLookup
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
104
|
+
dataComponentLookup = {},
|
|
105
|
+
artifactComponentLookup = {},
|
|
106
|
+
toolLookup = {},
|
|
107
|
+
agentToolConfigLookup = {}
|
|
108
|
+
) {
|
|
109
|
+
set({
|
|
110
|
+
nodes,
|
|
111
|
+
edges,
|
|
112
|
+
metadata,
|
|
113
|
+
dataComponentLookup,
|
|
114
|
+
artifactComponentLookup,
|
|
115
|
+
toolLookup,
|
|
116
|
+
agentToolConfigLookup,
|
|
117
|
+
dirty: false,
|
|
118
|
+
history: [],
|
|
119
|
+
future: [],
|
|
120
|
+
errors: null,
|
|
121
|
+
showErrors: false,
|
|
122
|
+
});
|
|
123
|
+
},
|
|
124
|
+
setDataComponentLookup(dataComponentLookup) {
|
|
125
|
+
set({ dataComponentLookup });
|
|
126
|
+
},
|
|
127
|
+
setArtifactComponentLookup(artifactComponentLookup) {
|
|
128
|
+
set({ artifactComponentLookup });
|
|
129
|
+
},
|
|
130
|
+
setToolLookup(toolLookup) {
|
|
131
|
+
set({ toolLookup });
|
|
132
|
+
},
|
|
133
|
+
setAgentToolConfigLookup(agentToolConfigLookup) {
|
|
134
|
+
set({ agentToolConfigLookup });
|
|
135
|
+
},
|
|
136
|
+
setNodes(updater) {
|
|
137
|
+
set((state) => ({ nodes: updater(state.nodes) }));
|
|
138
|
+
},
|
|
139
|
+
setEdges(updater) {
|
|
140
|
+
set((state) => ({ edges: updater(state.edges) }));
|
|
141
|
+
},
|
|
142
|
+
push(nodes, edges) {
|
|
143
|
+
set((state) => ({
|
|
144
|
+
history: [...state.history, { nodes, edges }],
|
|
145
|
+
future: [],
|
|
146
|
+
}));
|
|
147
|
+
},
|
|
148
|
+
onNodesChange(changes) {
|
|
149
|
+
// Check if any change type would modify the graph (not just selection changes)
|
|
150
|
+
const hasModifyingChange = changes.some(
|
|
151
|
+
(change) =>
|
|
152
|
+
change.type === 'remove' ||
|
|
153
|
+
change.type === 'add' ||
|
|
154
|
+
change.type === 'replace' ||
|
|
155
|
+
change.type === 'position'
|
|
156
|
+
);
|
|
150
157
|
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
158
|
+
set((state) => ({
|
|
159
|
+
history: [...state.history, { nodes: state.nodes, edges: state.edges }],
|
|
160
|
+
nodes: applyNodeChanges(changes, state.nodes),
|
|
161
|
+
dirty: hasModifyingChange ? true : state.dirty,
|
|
162
|
+
}));
|
|
163
|
+
},
|
|
164
|
+
onEdgesChange(changes) {
|
|
165
|
+
// Check if any change type would modify the graph (not just selection changes)
|
|
166
|
+
const hasModifyingChange = changes.some(
|
|
167
|
+
(change) => change.type === 'remove' || change.type === 'add' || change.type === 'replace'
|
|
168
|
+
);
|
|
162
169
|
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
170
|
+
set((state) => {
|
|
171
|
+
// Check for edge removals that disconnect agent from MCP node
|
|
172
|
+
const removeChanges = changes.filter((change) => change.type === 'remove');
|
|
173
|
+
let updatedNodes = state.nodes;
|
|
167
174
|
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
175
|
+
for (const removeChange of removeChanges) {
|
|
176
|
+
const edgeToRemove = state.edges.find((e) => e.id === removeChange.id);
|
|
177
|
+
if (edgeToRemove && edgeToRemove.targetHandle === mcpNodeHandleId) {
|
|
178
|
+
// Find the target MCP node and clear its agentId
|
|
179
|
+
const mcpNode = state.nodes.find((n) => n.id === edgeToRemove.target);
|
|
180
|
+
if (mcpNode && mcpNode.type === NodeType.MCP) {
|
|
181
|
+
updatedNodes = updatedNodes.map((n) =>
|
|
182
|
+
n.id === mcpNode.id
|
|
183
|
+
? { ...n, data: { ...n.data, agentId: null, relationshipId: null } }
|
|
184
|
+
: n
|
|
185
|
+
);
|
|
186
|
+
}
|
|
179
187
|
}
|
|
180
188
|
}
|
|
181
|
-
}
|
|
182
189
|
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
history: [...state.history, { nodes: state.nodes, edges: state.edges }],
|
|
218
|
-
dirty: state.dirty,
|
|
219
|
-
}));
|
|
220
|
-
},
|
|
221
|
-
markSaved() {
|
|
222
|
-
set({ dirty: false });
|
|
223
|
-
},
|
|
224
|
-
markUnsaved() {
|
|
225
|
-
set({ dirty: true });
|
|
226
|
-
},
|
|
227
|
-
clearSelection() {
|
|
228
|
-
set((state) => ({
|
|
229
|
-
nodes: state.nodes.map((n) => ({ ...n, selected: false })),
|
|
230
|
-
edges: state.edges.map((e) => ({ ...e, selected: false })),
|
|
231
|
-
dirty: state.dirty,
|
|
232
|
-
}));
|
|
233
|
-
},
|
|
234
|
-
deleteSelected() {
|
|
235
|
-
set((state) => {
|
|
236
|
-
const nodesToDelete = new Set(
|
|
237
|
-
state.nodes.filter((n) => n.selected && (n.deletable ?? true)).map((n) => n.id)
|
|
238
|
-
);
|
|
239
|
-
const edgesRemaining = state.edges.filter(
|
|
240
|
-
(e) => !e.selected && !nodesToDelete.has(e.source) && !nodesToDelete.has(e.target)
|
|
241
|
-
);
|
|
242
|
-
const nodesRemaining = state.nodes.filter((n) => !nodesToDelete.has(n.id));
|
|
243
|
-
return {
|
|
190
|
+
return {
|
|
191
|
+
history: [...state.history, { nodes: state.nodes, edges: state.edges }],
|
|
192
|
+
nodes: updatedNodes,
|
|
193
|
+
edges: applyEdgeChanges(changes, state.edges),
|
|
194
|
+
dirty: hasModifyingChange ? true : state.dirty,
|
|
195
|
+
};
|
|
196
|
+
});
|
|
197
|
+
},
|
|
198
|
+
onConnect(connection) {
|
|
199
|
+
set((state) => ({ edges: addEdge(connection as any, state.edges) }));
|
|
200
|
+
},
|
|
201
|
+
setMetadata(field, value) {
|
|
202
|
+
set((state) => ({ metadata: { ...state.metadata, [field]: value } }));
|
|
203
|
+
},
|
|
204
|
+
undo() {
|
|
205
|
+
const { history } = get();
|
|
206
|
+
if (history.length === 0) return;
|
|
207
|
+
const prev = history[history.length - 1];
|
|
208
|
+
set((state) => ({
|
|
209
|
+
nodes: prev.nodes,
|
|
210
|
+
edges: prev.edges,
|
|
211
|
+
history: state.history.slice(0, -1),
|
|
212
|
+
future: [{ nodes: state.nodes, edges: state.edges }, ...state.future],
|
|
213
|
+
dirty: state.dirty,
|
|
214
|
+
}));
|
|
215
|
+
},
|
|
216
|
+
redo() {
|
|
217
|
+
const { future } = get();
|
|
218
|
+
if (future.length === 0) return;
|
|
219
|
+
const next = future[0];
|
|
220
|
+
set((state) => ({
|
|
221
|
+
nodes: next.nodes,
|
|
222
|
+
edges: next.edges,
|
|
223
|
+
future: state.future.slice(1),
|
|
244
224
|
history: [...state.history, { nodes: state.nodes, edges: state.edges }],
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
225
|
+
dirty: state.dirty,
|
|
226
|
+
}));
|
|
227
|
+
},
|
|
228
|
+
markSaved() {
|
|
229
|
+
set({ dirty: false });
|
|
230
|
+
},
|
|
231
|
+
markUnsaved() {
|
|
232
|
+
set({ dirty: true });
|
|
233
|
+
},
|
|
234
|
+
clearSelection() {
|
|
235
|
+
set((state) => ({
|
|
236
|
+
nodes: state.nodes.map((n) => ({ ...n, selected: false })),
|
|
237
|
+
edges: state.edges.map((e) => ({ ...e, selected: false })),
|
|
238
|
+
dirty: state.dirty,
|
|
239
|
+
}));
|
|
240
|
+
},
|
|
241
|
+
deleteSelected() {
|
|
242
|
+
set((state) => {
|
|
243
|
+
const nodesToDelete = new Set(
|
|
244
|
+
state.nodes.filter((n) => n.selected && (n.deletable ?? true)).map((n) => n.id)
|
|
245
|
+
);
|
|
246
|
+
const edgesRemaining = state.edges.filter(
|
|
247
|
+
(e) => !e.selected && !nodesToDelete.has(e.source) && !nodesToDelete.has(e.target)
|
|
248
|
+
);
|
|
249
|
+
const nodesRemaining = state.nodes.filter((n) => !nodesToDelete.has(n.id));
|
|
250
|
+
return {
|
|
251
|
+
history: [...state.history, { nodes: state.nodes, edges: state.edges }],
|
|
252
|
+
nodes: nodesRemaining,
|
|
253
|
+
edges: edgesRemaining,
|
|
254
|
+
dirty: true,
|
|
255
|
+
};
|
|
256
|
+
});
|
|
257
|
+
},
|
|
258
|
+
setErrors(errors) {
|
|
259
|
+
set({ errors, showErrors: errors !== null });
|
|
260
|
+
},
|
|
261
|
+
clearErrors() {
|
|
262
|
+
set({ errors: null, showErrors: false });
|
|
263
|
+
},
|
|
264
|
+
setShowErrors(show) {
|
|
265
|
+
set({ showErrors: show });
|
|
266
|
+
},
|
|
267
|
+
hasErrors() {
|
|
268
|
+
const { errors } = get();
|
|
269
|
+
return errors !== null && errors.totalErrors > 0;
|
|
270
|
+
},
|
|
271
|
+
getNodeErrors(nodeId) {
|
|
272
|
+
const { errors } = get();
|
|
273
|
+
if (!errors || !errors.nodeErrors[nodeId]) return [];
|
|
274
|
+
return errors.nodeErrors[nodeId];
|
|
275
|
+
},
|
|
276
|
+
getEdgeErrors(edgeId) {
|
|
277
|
+
const { errors } = get();
|
|
278
|
+
if (!errors || !errors.edgeErrors[edgeId]) return [];
|
|
279
|
+
return errors.edgeErrors[edgeId];
|
|
280
|
+
},
|
|
273
281
|
},
|
|
274
282
|
}))
|
|
275
283
|
);
|
|
284
|
+
|
|
285
|
+
/**
|
|
286
|
+
* Actions are functions that update values in your store.
|
|
287
|
+
* These are static and do not change between renders.
|
|
288
|
+
*
|
|
289
|
+
* @see https://tkdodo.eu/blog/working-with-zustand#separate-actions-from-state
|
|
290
|
+
*/
|
|
291
|
+
export const useGraphActions = () => graphStore((state) => state.actions);
|
|
292
|
+
|
|
293
|
+
/**
|
|
294
|
+
* Select values from the graph store (excluding actions).
|
|
295
|
+
*
|
|
296
|
+
* We explicitly use `GraphStateData` instead of `GraphState`,
|
|
297
|
+
* which includes actions, to encourage using `useGraphActions`
|
|
298
|
+
* when accessing or calling actions.
|
|
299
|
+
*/
|
|
300
|
+
export function useGraphStore<T>(selector: (state: GraphStateData) => T): T {
|
|
301
|
+
return graphStore(useShallow(selector));
|
|
302
|
+
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { useCallback, useEffect } from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { useGraphActions } from '@/features/graph/state/use-graph-store';
|
|
3
3
|
|
|
4
4
|
export function useGraphShortcuts() {
|
|
5
|
-
const { undo, redo, deleteSelected } =
|
|
5
|
+
const { undo, redo, deleteSelected } = useGraphActions();
|
|
6
6
|
|
|
7
7
|
const onKeyDown = useCallback(
|
|
8
8
|
(e: KeyboardEvent) => {
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
5
|
import { useCallback } from 'react';
|
|
6
|
-
import { useGraphStore } from '@/features/graph/state/use-graph-store';
|
|
6
|
+
import { useGraphStore, useGraphActions } from '@/features/graph/state/use-graph-store';
|
|
7
7
|
|
|
8
8
|
export interface ErrorHelpers {
|
|
9
9
|
hasFieldError: (fieldName: string) => boolean;
|
|
@@ -12,14 +12,12 @@ export interface ErrorHelpers {
|
|
|
12
12
|
}
|
|
13
13
|
|
|
14
14
|
export function useGraphErrors() {
|
|
15
|
-
const errors = useGraphStore((state) =>
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
const getEdgeErrors
|
|
20
|
-
|
|
21
|
-
const clearErrors = useGraphStore((state) => state.clearErrors);
|
|
22
|
-
const setShowErrors = useGraphStore((state) => state.setShowErrors);
|
|
15
|
+
const { errors, showErrors } = useGraphStore((state) => ({
|
|
16
|
+
errors: state.errors,
|
|
17
|
+
showErrors: state.showErrors,
|
|
18
|
+
}));
|
|
19
|
+
const { hasErrors, getNodeErrors, getEdgeErrors, setErrors, clearErrors, setShowErrors } =
|
|
20
|
+
useGraphActions();
|
|
23
21
|
|
|
24
22
|
const getNodeErrorCount = (nodeId: string): number => {
|
|
25
23
|
return getNodeErrors(nodeId).length;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useReactFlow } from '@xyflow/react';
|
|
2
2
|
import { useCallback, useRef } from 'react';
|
|
3
|
-
import {
|
|
3
|
+
import { useGraphActions } from '@/features/graph/state/use-graph-store';
|
|
4
4
|
import type { ErrorHelpers } from './use-graph-errors';
|
|
5
5
|
|
|
6
6
|
interface UseNodeEditorOptions {
|
|
@@ -10,7 +10,7 @@ interface UseNodeEditorOptions {
|
|
|
10
10
|
|
|
11
11
|
export function useNodeEditor({ selectedNodeId, errorHelpers }: UseNodeEditorOptions) {
|
|
12
12
|
const { updateNodeData } = useReactFlow();
|
|
13
|
-
const markUnsaved =
|
|
13
|
+
const { markUnsaved } = useGraphActions();
|
|
14
14
|
|
|
15
15
|
// Focus management for error fields
|
|
16
16
|
const fieldRefs = useRef<Record<string, HTMLElement>>({});
|
|
@@ -107,8 +107,8 @@ export function useNodeEditor({ selectedNodeId, errorHelpers }: UseNodeEditorOpt
|
|
|
107
107
|
const finalKey = nestedPath[nestedPath.length - 1];
|
|
108
108
|
if (value === undefined || value === null || value === '') {
|
|
109
109
|
delete current[finalKey];
|
|
110
|
-
//
|
|
111
|
-
if (Object.keys(updatedParent).length === 0
|
|
110
|
+
// Check if the parent object becomes empty after deletion
|
|
111
|
+
if (Object.keys(updatedParent).length === 0) {
|
|
112
112
|
updateField(parentField, null);
|
|
113
113
|
return;
|
|
114
114
|
}
|