@inkeep/agents-manage-ui 0.29.3 → 0.29.5
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 +237 -237
- package/.next/standalone/agents-manage-ui/.next/app-path-routes-manifest.json +8 -8
- package/.next/standalone/agents-manage-ui/.next/build-manifest.json +5 -5
- package/.next/standalone/agents-manage-ui/.next/prerender-manifest.json +3 -3
- package/.next/standalone/agents-manage-ui/.next/react-loadable-manifest.json +11 -11
- 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]/agents/[agentId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/[agentId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/[agentId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/new/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/agents/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 +1 -1
- 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]/external-agents/[externalAgentId]/edit/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/edit/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/edit/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/new/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/new/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/page.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/page.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/[tenantId]/projects/[projectId]/external-agents/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 +1 -1
- 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 +2 -2
- 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 +2 -2
- 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 +2 -2
- 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/data-components/[dataComponentId]/generate-render/route.js +190 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/api/data-components/[dataComponentId]/generate-render/route.js.nft.json +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/api/data-components/[dataComponentId]/generate-render/route_client-reference-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/api/signoz/conversations/[conversationId]/route.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/app/api/signoz/conversations/[conversationId]/route.js.nft.json +1 -1
- 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 +3 -3
- 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 +8 -8
- package/.next/standalone/agents-manage-ui/.next/server/chunks/1062.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/1063.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/1989.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/chunks/2068.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/279.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3146.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/{3196.js → 3813.js} +7 -7
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4087.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4608.js +2 -2
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4629.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4703.js +4080 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/4745.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/493.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5029.js +7 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5206.js +3 -3
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5231.js +7 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/5626.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6641.js +4 -4
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6915.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7494.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7512.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7711.js +4 -4
- package/.next/standalone/agents-manage-ui/.next/server/chunks/7990.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8153.js +28 -28
- package/.next/standalone/agents-manage-ui/.next/server/chunks/{6786.js → 825.js} +4 -4
- package/.next/standalone/agents-manage-ui/.next/server/chunks/8544.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9103.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9887.js +6 -6
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9896.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/server/middleware-build-manifest.js +1 -1
- package/.next/standalone/agents-manage-ui/.next/server/middleware-manifest.json +5 -5
- package/.next/standalone/agents-manage-ui/.next/server/middleware-react-loadable-manifest.js +1 -1
- 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/13328-55dd6583a4a83208.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/16556-41a7202dab79a3ab.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/33808783-c28b4f057cb65a45.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/{4698.3051cd4ec04e2aa4.js → 4698.ca8fb193dde36128.js} +7 -7
- package/.next/standalone/agents-manage-ui/.next/static/chunks/{71707-ca20f365f10e3d9b.js → 71707-9fe239f258988d67.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/73281-8420f80fb480f4c5.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/75951-878dc4e0e8dcc1fb.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/8025-3a188e500c7b07ea.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/85756-0c79e852059de191.js +7 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/89003-56d12f45210d207c.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/{55102-3a3cf3019003b803.js → 89047-d952c8786d1b5231.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/89748.1b986e8a1a51c2a7.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/89814.9cc4e5c2b2c03616.js +90 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/91168-6013e6192bf30422.js +197 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/95716-5919a91812112efc.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/97657-8083f14bae23466c.js +21 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/agents/[agentId]/{page-81d891f2ebad99f6.js → page-41a5e02713e1c0c9.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/agents/new/page-f7f1ca119db8cd42.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/agents/page-566e1ddb90f1f54d.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/api-keys/page-56f0d692b7a97629.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/page-9a1a224f4ade7638.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/new/page-b965b71a34029574.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/page-02f0b483917ae979.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/[dataComponentId]/{page-387db12bf402479e.js → page-5d4655b0b3e05dc9.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/new/page-86880b4f13459bce.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/page-07aac3c3e1c8155c.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/page-9f475409950a8bef.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page-b839c80da5ad1c82.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page-a42da1e089859a62.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/{page-67769ed96aece3d2.js → page-0bb318969c30760d.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/edit/page-12f31c2f39114bbe.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/page-4af233894f263f3e.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/new/{page-02453d0611e080bf.js → page-c75b55bf52f8e99d.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/{page-12ba94f27f479503.js → page-8698f76d02f33048.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/edit/{page-871855c42cc1570a.js → page-323dc5915df41040.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/page-ff1fb42365e1b1a2.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/new/{page-a716f264d06da9f6.js → page-8f8c32b7b62670fb.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/{page-57952d7b41a8ea5f.js → page-8f3a272b1e9acdc1.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/settings/{page-df08752575e4dde5.js → page-23c5699149ab3850.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/ai-calls/{page-b497260652ee7ef8.js → page-5f3df837bb40db23.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/conversations/[conversationId]/{page-90edd7e87e5bd2ec.js → page-25d57ef6ea7bf234.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/page-dc558b380db7dfb2.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/page-54e01d054ff5f99d.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/layout-8c1364dad27ebe81.js +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/chunks/{webpack-4f03d3dee03e888e.js → webpack-0b6bb882bcc796f6.js} +1 -1
- package/.next/standalone/agents-manage-ui/.next/static/css/f6d76bf9a7f33006.css +1 -0
- package/.next/standalone/agents-manage-ui/.next/static/css/fdac6bbf6bfe4fdb.css +1 -0
- package/.next/standalone/agents-manage-ui/package.json +10 -4
- package/.next/standalone/packages/agents-core/package.json +1 -1
- package/package.json +13 -7
- package/src/app/api/data-components/[dataComponentId]/generate-render/route.ts +250 -34
- package/src/components/agent/playground/chat-widget.tsx +2 -2
- package/src/components/ui/external-link.tsx +1 -1
- package/src/components/ui/item-card.tsx +1 -1
- package/src/lib/ai/model-factory.ts +204 -0
- package/.next/standalone/agents-manage-ui/.next/server/chunks/2092.js +0 -4080
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3228.js +0 -7
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3283.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/3723.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6215.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/6295.js +0 -7
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9282.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/server/chunks/9392.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/13328-3501afe632ea84f5.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/27549-0999635c700455a7.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/35989-ab35d1b983e41b8b.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/43687-9960b73019faa081.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/5545-fbadc7cd8ce68d12.js +0 -21
- package/.next/standalone/agents-manage-ui/.next/static/chunks/72652-6e31c6f0bd7a749e.js +0 -7
- package/.next/standalone/agents-manage-ui/.next/static/chunks/73281-643b9a02ca117c7b.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/869872cd-be0002f55324190f.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/89748.6aacc5949597be57.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/89814.c752574c3da1d1c4.js +0 -90
- package/.next/standalone/agents-manage-ui/.next/static/chunks/91168-8bb3e226fa7976c4.js +0 -197
- package/.next/standalone/agents-manage-ui/.next/static/chunks/92986-4b612a2548ee8fcc.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/98322-7f89d1c46d5719f1.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/agents/new/page-e7b745b3bdefe901.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/agents/page-306e17f29475e5a3.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/api-keys/page-fe5ef51bd669cfa2.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/[artifactComponentId]/page-2638393b668c8b66.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/new/page-246e1999e69b78d2.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/artifacts/page-d2019a39a82db50d.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/new/page-fc515342b1da4f4d.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/components/page-1e0a9e5f846dbbd2.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/[credentialId]/page-92963ed7188c0474.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/bearer/page-503467a74891265f.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/credentials/new/providers/[providerId]/page-419227fb7429c8f0.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/edit/page-1214db18147c5236.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/external-agents/[externalAgentId]/page-d2a380ee0bc84d15.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/mcp-servers/[mcpServerId]/page-6d24716f7d1b40f1.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/[projectId]/traces/page-b7391b719ca30eda.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/[tenantId]/projects/page-c385d57ce8d0d9a3.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/chunks/app/layout-53b5678fc38cba4e.js +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/css/b83d1d0ee3fbce7c.css +0 -1
- package/.next/standalone/agents-manage-ui/.next/static/css/df64af30921ff372.css +0 -1
- /package/.next/standalone/agents-manage-ui/.next/static/{KS4kZjlZlfQwUlc7wRBHr → -Dv27qIFhmRP1zRrlUJG8}/_buildManifest.js +0 -0
- /package/.next/standalone/agents-manage-ui/.next/static/{KS4kZjlZlfQwUlc7wRBHr → -Dv27qIFhmRP1zRrlUJG8}/_ssgManifest.js +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@inkeep/agents-manage-ui",
|
|
3
|
-
"version": "0.29.
|
|
3
|
+
"version": "0.29.5",
|
|
4
4
|
"license": "SEE LICENSE IN LICENSE.md",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"types": "index.d.ts",
|
|
@@ -27,13 +27,18 @@
|
|
|
27
27
|
"registry": "https://registry.npmjs.org/"
|
|
28
28
|
},
|
|
29
29
|
"dependencies": {
|
|
30
|
+
"@ai-sdk/anthropic": "2.0.2",
|
|
31
|
+
"@ai-sdk/gateway": "^1.0.23",
|
|
32
|
+
"@ai-sdk/google": "^2.0.14",
|
|
33
|
+
"@ai-sdk/openai": "2.0.11",
|
|
30
34
|
"@ai-sdk/react": "2.0.11",
|
|
31
35
|
"@hookform/resolvers": "^5.2.1",
|
|
32
|
-
"@inkeep/agents-ui": "^0.14.
|
|
36
|
+
"@inkeep/agents-ui": "^0.14.25",
|
|
33
37
|
"@lezer/highlight": "^1.2.1",
|
|
34
38
|
"@nangohq/frontend": "^0.69.5",
|
|
35
39
|
"@nangohq/node": "^0.69.5",
|
|
36
40
|
"@nangohq/types": "^0.69.5",
|
|
41
|
+
"@openrouter/ai-sdk-provider": "^1.2.0",
|
|
37
42
|
"@radix-ui/react-alert-dialog": "^1.1.15",
|
|
38
43
|
"@radix-ui/react-checkbox": "^1.3.2",
|
|
39
44
|
"@radix-ui/react-collapsible": "^1.1.12",
|
|
@@ -48,9 +53,11 @@
|
|
|
48
53
|
"@radix-ui/react-switch": "^1.2.6",
|
|
49
54
|
"@radix-ui/react-tabs": "^1.1.13",
|
|
50
55
|
"@radix-ui/react-tooltip": "^1.2.7",
|
|
56
|
+
"@shikijs/monaco": "^3.13.0",
|
|
51
57
|
"@sinclair/typebox": "^0.34.40",
|
|
52
58
|
"@types/dagre": "^0.7.53",
|
|
53
59
|
"@xyflow/react": "^12.8.2",
|
|
60
|
+
"ai": "^5.0.11",
|
|
54
61
|
"axios": "^1.11.0",
|
|
55
62
|
"axios-retry": "^4.5.0",
|
|
56
63
|
"class-variance-authority": "^0.7.1",
|
|
@@ -75,17 +82,16 @@
|
|
|
75
82
|
"react-runner": "^1.0.5",
|
|
76
83
|
"recharts": "2.15.4",
|
|
77
84
|
"remark-supersub": "^1.0.0",
|
|
78
|
-
"sonner": "^2.0.6",
|
|
79
85
|
"shiki": "^3.13.0",
|
|
80
|
-
"
|
|
86
|
+
"sonner": "^2.0.6",
|
|
81
87
|
"streamdown": "^1.4.0",
|
|
82
88
|
"tailwind-merge": "^3.3.1",
|
|
83
89
|
"use-stick-to-bottom": "^1.1.1",
|
|
84
90
|
"zod": "^4.1.11",
|
|
85
91
|
"zustand": "^5.0.7",
|
|
86
|
-
"@inkeep/agents-
|
|
87
|
-
"@inkeep/agents-
|
|
88
|
-
"@inkeep/agents-run-api": "^0.29.
|
|
92
|
+
"@inkeep/agents-manage-api": "^0.29.5",
|
|
93
|
+
"@inkeep/agents-core": "^0.29.5",
|
|
94
|
+
"@inkeep/agents-run-api": "^0.29.5"
|
|
89
95
|
},
|
|
90
96
|
"devDependencies": {
|
|
91
97
|
"@tailwindcss/postcss": "^4",
|
|
@@ -1,9 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API Route: Generate Component Render
|
|
3
|
+
*
|
|
4
|
+
* Generates a React/Tailwind component using AI based on a data component's schema.
|
|
5
|
+
* This route:
|
|
6
|
+
* 1. Fetches the data component from manage-api
|
|
7
|
+
* 2. Fetches the project to get base model configuration
|
|
8
|
+
* 3. Uses AI SDK streamObject to generate component code and sample data
|
|
9
|
+
* 4. Streams NDJSON response back to client
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { streamObject } from 'ai';
|
|
1
13
|
import type { NextRequest } from 'next/server';
|
|
14
|
+
import { z } from 'zod';
|
|
15
|
+
import { ModelFactory } from '@/lib/ai/model-factory';
|
|
16
|
+
import { fetchDataComponent } from '@/lib/api/data-components';
|
|
17
|
+
import { fetchProject } from '@/lib/api/projects';
|
|
18
|
+
|
|
19
|
+
interface RouteContext {
|
|
20
|
+
params: Promise<{
|
|
21
|
+
dataComponentId: string;
|
|
22
|
+
}>;
|
|
23
|
+
}
|
|
2
24
|
|
|
3
|
-
export async function POST(
|
|
4
|
-
request: NextRequest,
|
|
5
|
-
context: RouteContext<'/api/data-components/[dataComponentId]/generate-render'>
|
|
6
|
-
) {
|
|
25
|
+
export async function POST(request: NextRequest, context: RouteContext) {
|
|
7
26
|
try {
|
|
8
27
|
const { dataComponentId } = await context.params;
|
|
9
28
|
const body = await request.json();
|
|
@@ -13,45 +32,242 @@ export async function POST(
|
|
|
13
32
|
return new Response('Missing tenantId or projectId', { status: 400 });
|
|
14
33
|
}
|
|
15
34
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
'Content-Type': 'application/json',
|
|
23
|
-
...(process.env.PUBLIC_INKEEP_AGENTS_RUN_API_BYPASS_SECRET && {
|
|
24
|
-
Authorization: `Bearer ${process.env.PUBLIC_INKEEP_AGENTS_RUN_API_BYPASS_SECRET}`,
|
|
25
|
-
'x-inkeep-tenant-id': tenantId,
|
|
26
|
-
'x-inkeep-project-id': projectId,
|
|
27
|
-
}),
|
|
28
|
-
},
|
|
29
|
-
body: JSON.stringify({
|
|
30
|
-
instructions: instructions || undefined,
|
|
31
|
-
existingCode: existingCode || undefined,
|
|
32
|
-
}),
|
|
35
|
+
console.log('Generating component render', {
|
|
36
|
+
tenantId,
|
|
37
|
+
projectId,
|
|
38
|
+
dataComponentId,
|
|
39
|
+
hasInstructions: !!instructions,
|
|
40
|
+
hasExistingCode: !!existingCode,
|
|
33
41
|
});
|
|
34
42
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
43
|
+
// Fetch data component from manage-api
|
|
44
|
+
const dataComponent = await fetchDataComponent(tenantId, projectId, dataComponentId);
|
|
45
|
+
|
|
46
|
+
if (!dataComponent) {
|
|
47
|
+
return new Response('Data component not found', { status: 404 });
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Fetch project to get model configuration
|
|
51
|
+
const projectResponse = await fetchProject(tenantId, projectId);
|
|
52
|
+
|
|
53
|
+
if (!projectResponse.data) {
|
|
54
|
+
return new Response('Project not found', { status: 404 });
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const project = projectResponse.data;
|
|
58
|
+
|
|
59
|
+
if (!project.models?.base) {
|
|
60
|
+
return new Response('Project base model configuration is required', { status: 400 });
|
|
44
61
|
}
|
|
45
62
|
|
|
46
|
-
//
|
|
47
|
-
|
|
63
|
+
// Build prompt for AI generation
|
|
64
|
+
const prompt = buildGenerationPrompt(dataComponent, instructions, existingCode);
|
|
65
|
+
|
|
66
|
+
// Prepare model configuration
|
|
67
|
+
const modelConfig = ModelFactory.prepareGenerationConfig(project.models?.base as any);
|
|
68
|
+
|
|
69
|
+
// Define schema for generated output
|
|
70
|
+
const renderSchema = z.object({
|
|
71
|
+
component: z.string().describe('The React component code'),
|
|
72
|
+
mockData: z.any().describe('Sample data matching the props schema'),
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
// Generate using AI SDK streamObject
|
|
76
|
+
const result = streamObject({
|
|
77
|
+
...modelConfig,
|
|
78
|
+
prompt,
|
|
79
|
+
schema: renderSchema,
|
|
80
|
+
temperature: 0.7,
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
// Get existing data if we're modifying (to preserve sample data)
|
|
84
|
+
const existingData =
|
|
85
|
+
existingCode &&
|
|
86
|
+
dataComponent.render &&
|
|
87
|
+
typeof dataComponent.render === 'object' &&
|
|
88
|
+
'mockData' in dataComponent.render
|
|
89
|
+
? (dataComponent.render as any).mockData
|
|
90
|
+
: null;
|
|
91
|
+
|
|
92
|
+
// Create a ReadableStream for NDJSON streaming
|
|
93
|
+
const stream = new ReadableStream({
|
|
94
|
+
async start(controller) {
|
|
95
|
+
try {
|
|
96
|
+
for await (const partialObject of result.partialObjectStream) {
|
|
97
|
+
// If modifying with instructions, preserve existing data
|
|
98
|
+
const outputObject =
|
|
99
|
+
instructions && existingData
|
|
100
|
+
? { ...(partialObject as any), mockData: existingData }
|
|
101
|
+
: partialObject;
|
|
102
|
+
|
|
103
|
+
// Write NDJSON (newline-delimited JSON)
|
|
104
|
+
const line = `${JSON.stringify(outputObject)}\n`;
|
|
105
|
+
controller.enqueue(new TextEncoder().encode(line));
|
|
106
|
+
}
|
|
107
|
+
controller.close();
|
|
108
|
+
} catch (error) {
|
|
109
|
+
console.error('Error streaming preview generation:', error);
|
|
110
|
+
// Send error as final line
|
|
111
|
+
const errorLine = `${JSON.stringify({ component: '// Error generating component', mockData: {} })}\n`;
|
|
112
|
+
controller.enqueue(new TextEncoder().encode(errorLine));
|
|
113
|
+
controller.close();
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
return new Response(stream, {
|
|
48
119
|
headers: {
|
|
49
120
|
'Content-Type': 'application/x-ndjson',
|
|
50
121
|
'Transfer-Encoding': 'chunked',
|
|
122
|
+
'Cache-Control': 'no-cache',
|
|
51
123
|
},
|
|
52
124
|
});
|
|
53
125
|
} catch (error) {
|
|
54
|
-
console.error('Error generating
|
|
55
|
-
return new Response('Internal server error', {
|
|
126
|
+
console.error('Error generating component render:', error);
|
|
127
|
+
return new Response(error instanceof Error ? error.message : 'Internal server error', {
|
|
128
|
+
status: 500,
|
|
129
|
+
});
|
|
56
130
|
}
|
|
57
131
|
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Build the prompt for AI generation
|
|
135
|
+
*/
|
|
136
|
+
function buildGenerationPrompt(
|
|
137
|
+
dataComponent: {
|
|
138
|
+
name: string;
|
|
139
|
+
description: string;
|
|
140
|
+
props: Record<string, unknown> | null;
|
|
141
|
+
},
|
|
142
|
+
instructions?: string,
|
|
143
|
+
existingCode?: string
|
|
144
|
+
): string {
|
|
145
|
+
const propsSchema = dataComponent.props || {};
|
|
146
|
+
const propsJson = JSON.stringify(propsSchema, null, 2);
|
|
147
|
+
const componentName = sanitizeComponentName(dataComponent.name);
|
|
148
|
+
|
|
149
|
+
// If we have custom instructions and existing code, modify the prompt
|
|
150
|
+
if (instructions && existingCode) {
|
|
151
|
+
return `You are an expert React and Tailwind CSS developer. You need to modify an existing React component based on specific instructions.
|
|
152
|
+
|
|
153
|
+
COMPONENT DETAILS:
|
|
154
|
+
- Original Name: ${dataComponent.name}
|
|
155
|
+
- Component Function Name: ${componentName}
|
|
156
|
+
- Description: ${dataComponent.description}
|
|
157
|
+
- Props Schema (JSON Schema): ${propsJson}
|
|
158
|
+
|
|
159
|
+
EXISTING COMPONENT CODE:
|
|
160
|
+
\`\`\`jsx
|
|
161
|
+
${existingCode}
|
|
162
|
+
\`\`\`
|
|
163
|
+
|
|
164
|
+
MODIFICATION INSTRUCTIONS:
|
|
165
|
+
${instructions}
|
|
166
|
+
|
|
167
|
+
REQUIREMENTS:
|
|
168
|
+
1. Modify the existing component code according to the instructions
|
|
169
|
+
2. Keep using Tailwind CSS SEMANTIC COLOR CLASSES (bg-background, text-foreground, etc.)
|
|
170
|
+
3. Maintain the balanced spacing and design principles from the original
|
|
171
|
+
4. Keep using lucide-react icons where appropriate
|
|
172
|
+
5. DO NOT include export statements - just the imports and function
|
|
173
|
+
6. DO NOT include TypeScript type annotations
|
|
174
|
+
7. Component name should remain: ${componentName}
|
|
175
|
+
8. DO NOT regenerate sample data - keep the same data structure
|
|
176
|
+
|
|
177
|
+
OUTPUT FORMAT:
|
|
178
|
+
You need to generate only one thing:
|
|
179
|
+
1. "component": The modified React component code as a string
|
|
180
|
+
|
|
181
|
+
Return ONLY the component field, the mockData field will be reused from the existing render.
|
|
182
|
+
|
|
183
|
+
EXAMPLE OUTPUT:
|
|
184
|
+
{
|
|
185
|
+
"component": "import { Mail, User } from 'lucide-react';\\n\\nfunction ${componentName}(props) {\\n // Modified component code here\\n}"
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
Focus on making the requested changes while maintaining the component's quality and design principles.`;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
return `You are an expert React and Tailwind CSS developer. Generate a beautiful, modern React component for displaying data and sample data to preview it.
|
|
192
|
+
|
|
193
|
+
COMPONENT DETAILS:
|
|
194
|
+
- Original Name: ${dataComponent.name}
|
|
195
|
+
- Component Function Name: ${componentName}
|
|
196
|
+
- Description: ${dataComponent.description}
|
|
197
|
+
- Props Schema (JSON Schema): ${propsJson}
|
|
198
|
+
|
|
199
|
+
REQUIREMENTS:
|
|
200
|
+
1. Create a React functional component (JSX, not TypeScript)
|
|
201
|
+
2. Use Tailwind CSS SEMANTIC COLOR CLASSES (these automatically adapt to light/dark mode):
|
|
202
|
+
- Background: bg-background, bg-card, bg-muted, bg-muted/40, bg-accent, bg-primary
|
|
203
|
+
- Text: text-foreground, text-muted-foreground, text-card-foreground, text-primary-foreground
|
|
204
|
+
- Borders: border-border, border-input, border-muted
|
|
205
|
+
- DO NOT use direct colors like bg-white, bg-gray-800, text-gray-900, etc.
|
|
206
|
+
- DO NOT use dark: prefix - semantic classes handle dark mode automatically
|
|
207
|
+
3. Make it balanced - comfortable but efficient:
|
|
208
|
+
- Use moderate padding: p-4, px-4 py-3 (balanced, not cramped or excessive)
|
|
209
|
+
- Use appropriate text sizes: text-sm for body, text-base for headings, text-xs for captions
|
|
210
|
+
- Use balanced spacing: gap-2.5, gap-3, space-y-2, mt-2, mb-3
|
|
211
|
+
- Aim for a clean, professional look with good readability
|
|
212
|
+
4. Design for embedding - this component blends into existing content:
|
|
213
|
+
- DO NOT add redundant titles or headers unless they're part of the actual data schema
|
|
214
|
+
- Focus on displaying the data directly and elegantly
|
|
215
|
+
- Assume the component is part of a larger conversation or content flow
|
|
216
|
+
- If the schema has a "title" or "name" property, display it as data, not as a wrapper heading
|
|
217
|
+
5. Use LUCIDE-REACT ICONS to enhance UI aesthetics:
|
|
218
|
+
- Import icons from lucide-react: import { User, Mail, Clock } from 'lucide-react'
|
|
219
|
+
- Use icons with size-4 or size-5 classes for balanced visibility
|
|
220
|
+
- Place icons inline with text or as visual indicators
|
|
221
|
+
- Example: <User className="size-4" /> or <Mail className="size-4 text-muted-foreground" />
|
|
222
|
+
- Common useful icons: User, Mail, Calendar, Clock, Check, X, Star, Heart, Settings, Search, etc.
|
|
223
|
+
6. The component should accept props that match the JSON Schema properties
|
|
224
|
+
7. Make it visually appealing and professional - clean with good whitespace
|
|
225
|
+
8. Use semantic HTML elements
|
|
226
|
+
9. Make it responsive and accessible
|
|
227
|
+
10. You can import icons from 'lucide-react' at the top
|
|
228
|
+
11. DO NOT include export statements - just the imports and function
|
|
229
|
+
12. DO NOT include TypeScript type annotations
|
|
230
|
+
13. Component name should be exactly: ${componentName}
|
|
231
|
+
|
|
232
|
+
AVAILABLE SEMANTIC COLOR CLASSES:
|
|
233
|
+
- Backgrounds: bg-background, bg-foreground, bg-card, bg-popover, bg-primary, bg-secondary, bg-muted, bg-accent, bg-destructive
|
|
234
|
+
- Text: text-foreground, text-background, text-card-foreground, text-popover-foreground, text-primary-foreground, text-secondary-foreground, text-muted-foreground, text-accent-foreground, text-destructive
|
|
235
|
+
- Borders: border-border, border-input, border-ring
|
|
236
|
+
- You can use opacity modifiers: bg-muted/40, bg-accent/10, etc.
|
|
237
|
+
|
|
238
|
+
OUTPUT FORMAT:
|
|
239
|
+
You need to generate two things:
|
|
240
|
+
1. "component": The complete React component code as a string
|
|
241
|
+
2. "mockData": Realistic sample data that matches the props schema (as a JSON object)
|
|
242
|
+
|
|
243
|
+
EXAMPLE OUTPUT (for a user profile schema with name, email, role):
|
|
244
|
+
{
|
|
245
|
+
"component": "import { Mail, User } from 'lucide-react';\\n\\nfunction ${componentName}(props) {\\n return (\\n <div className=\\"p-4 rounded-lg border border-border bg-card\\">\\n <div className=\\"flex items-center gap-2.5 mb-2\\">\\n <User className=\\"size-4 text-muted-foreground\\" />\\n <span className=\\"text-base font-medium text-foreground\\">{props.name}</span>\\n </div>\\n <div className=\\"flex items-center gap-2 text-sm text-muted-foreground\\">\\n <Mail className=\\"size-4\\" />\\n <span>{props.email}</span>\\n </div>\\n <div className=\\"text-xs text-muted-foreground mt-2\\">Role: {props.role}</div>\\n </div>\\n );\\n}",
|
|
246
|
+
"mockData": {
|
|
247
|
+
"name": "Sarah Chen",
|
|
248
|
+
"email": "sarah.chen@example.com",
|
|
249
|
+
"role": "Product Manager"
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
REMEMBER:
|
|
254
|
+
- ONLY use semantic color classes (bg-card, text-foreground, etc.)
|
|
255
|
+
- NO direct colors (bg-white, text-gray-900, etc.)
|
|
256
|
+
- NO dark: prefix needed - semantic classes adapt automatically
|
|
257
|
+
- Use balanced spacing (p-4, gap-2.5/gap-3, text-sm for body, text-base for headings)
|
|
258
|
+
- Use lucide-react icons where appropriate for better UI
|
|
259
|
+
- NO redundant titles - just display the actual data from props
|
|
260
|
+
- Design for embedding - this blends into existing content, not a standalone card
|
|
261
|
+
- Make the sample data realistic and useful for previewing the component`;
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
/**
|
|
265
|
+
* Sanitize component name to be a valid React component name
|
|
266
|
+
*/
|
|
267
|
+
function sanitizeComponentName(name: string): string {
|
|
268
|
+
return name
|
|
269
|
+
.split(/\s+/)
|
|
270
|
+
.map((word) => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
|
|
271
|
+
.join('')
|
|
272
|
+
.replace(/[^a-zA-Z0-9]/g, '');
|
|
273
|
+
}
|
|
@@ -179,7 +179,7 @@ export function ChatWidget({
|
|
|
179
179
|
<div className="flex-1 min-w-0 h-full">
|
|
180
180
|
<InkeepEmbeddedChat
|
|
181
181
|
baseSettings={{
|
|
182
|
-
onEvent: (event: InkeepCallbackEvent) => {
|
|
182
|
+
onEvent: async (event: InkeepCallbackEvent) => {
|
|
183
183
|
if (event.eventName === 'assistant_message_received') {
|
|
184
184
|
// Mark that we've received the assistant message
|
|
185
185
|
hasReceivedAssistantMessageRef.current = true;
|
|
@@ -256,7 +256,7 @@ export function ChatWidget({
|
|
|
256
256
|
headers: {
|
|
257
257
|
'x-inkeep-tenant-id': tenantId,
|
|
258
258
|
'x-inkeep-project-id': projectId,
|
|
259
|
-
'x-inkeep-agent-id': agentId,
|
|
259
|
+
'x-inkeep-agent-id': agentId || '',
|
|
260
260
|
'x-emit-operations': 'true',
|
|
261
261
|
Authorization: `Bearer ${PUBLIC_INKEEP_AGENTS_RUN_API_BYPASS_SECRET}`,
|
|
262
262
|
...customHeaders,
|
|
@@ -91,7 +91,7 @@ export function ItemCardFooter({ footerText }: { footerText: string }) {
|
|
|
91
91
|
<div className="relative flex items-center justify-between">
|
|
92
92
|
<div className="flex items-center text-xs text-muted-foreground">{footerText}</div>
|
|
93
93
|
<div className="opacity-0 group-hover:opacity-60 transform translate-x-1 group-hover:translate-x-0 transition-all duration-300">
|
|
94
|
-
<ArrowRight className="w-4 h-4 text-muted-foreground
|
|
94
|
+
<ArrowRight className="w-4 h-4 text-muted-foreground opacity-60" />
|
|
95
95
|
</div>
|
|
96
96
|
</div>
|
|
97
97
|
);
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ModelFactory for creating AI SDK language models from configuration
|
|
3
|
+
* Copied from agents-run-api for use in manage-ui API routes
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { anthropic, createAnthropic } from '@ai-sdk/anthropic';
|
|
7
|
+
import { createGateway, gateway } from '@ai-sdk/gateway';
|
|
8
|
+
import { createGoogleGenerativeAI, google } from '@ai-sdk/google';
|
|
9
|
+
import { createOpenAI, openai } from '@ai-sdk/openai';
|
|
10
|
+
import { createOpenRouter, openrouter } from '@openrouter/ai-sdk-provider';
|
|
11
|
+
import type { LanguageModel } from 'ai';
|
|
12
|
+
|
|
13
|
+
export interface ModelSettings {
|
|
14
|
+
model?: string;
|
|
15
|
+
providerOptions?: Record<string, unknown>;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Factory for creating AI SDK language models from configuration
|
|
20
|
+
* Supports multiple providers and AI Gateway integration
|
|
21
|
+
*/
|
|
22
|
+
export class ModelFactory {
|
|
23
|
+
/**
|
|
24
|
+
* Create a provider instance with custom configuration
|
|
25
|
+
*/
|
|
26
|
+
private static createProvider(provider: string, config: Record<string, unknown>): any {
|
|
27
|
+
switch (provider) {
|
|
28
|
+
case 'anthropic':
|
|
29
|
+
return createAnthropic(config);
|
|
30
|
+
case 'openai':
|
|
31
|
+
return createOpenAI(config);
|
|
32
|
+
case 'google':
|
|
33
|
+
return createGoogleGenerativeAI(config);
|
|
34
|
+
case 'openrouter':
|
|
35
|
+
return createOpenRouter(config);
|
|
36
|
+
case 'gateway':
|
|
37
|
+
return createGateway(config);
|
|
38
|
+
default:
|
|
39
|
+
throw new Error(`Unsupported provider: ${provider}`);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Extract provider configuration from providerOptions
|
|
45
|
+
* Only includes settings that go to the provider constructor (baseURL, apiKey, etc.)
|
|
46
|
+
*/
|
|
47
|
+
private static extractProviderConfig(
|
|
48
|
+
providerOptions?: Record<string, unknown>
|
|
49
|
+
): Record<string, unknown> {
|
|
50
|
+
if (!providerOptions) {
|
|
51
|
+
return {};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const providerConfig: Record<string, unknown> = {};
|
|
55
|
+
|
|
56
|
+
if (providerOptions.baseUrl || providerOptions.baseURL) {
|
|
57
|
+
providerConfig.baseURL = providerOptions.baseUrl || providerOptions.baseURL;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (providerOptions.gateway) {
|
|
61
|
+
Object.assign(providerConfig, providerOptions.gateway);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return providerConfig;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Create a language model instance from configuration
|
|
69
|
+
* Throws error if no config provided - models must be configured at project level
|
|
70
|
+
*/
|
|
71
|
+
static createModel(config: ModelSettings): any {
|
|
72
|
+
if (!config?.model?.trim()) {
|
|
73
|
+
throw new Error(
|
|
74
|
+
'Model configuration is required. Please configure models at the project level.'
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const modelSettings = config;
|
|
79
|
+
if (!modelSettings.model) {
|
|
80
|
+
throw new Error('Model configuration is required');
|
|
81
|
+
}
|
|
82
|
+
const modelString = modelSettings.model.trim();
|
|
83
|
+
const { provider, modelName } = ModelFactory.parseModelString(modelString);
|
|
84
|
+
|
|
85
|
+
console.log('Creating language model', {
|
|
86
|
+
provider,
|
|
87
|
+
model: modelName,
|
|
88
|
+
hasProviderOptions: !!modelSettings.providerOptions,
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
const providerConfig = ModelFactory.extractProviderConfig(modelSettings.providerOptions);
|
|
92
|
+
|
|
93
|
+
if (Object.keys(providerConfig).length > 0) {
|
|
94
|
+
console.log(`Applying custom ${provider} provider configuration`, providerConfig);
|
|
95
|
+
const customProvider = ModelFactory.createProvider(provider, providerConfig);
|
|
96
|
+
return customProvider.languageModel(modelName);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
switch (provider) {
|
|
100
|
+
case 'anthropic':
|
|
101
|
+
return anthropic(modelName);
|
|
102
|
+
case 'openai':
|
|
103
|
+
return openai(modelName);
|
|
104
|
+
case 'google':
|
|
105
|
+
return google(modelName);
|
|
106
|
+
case 'openrouter':
|
|
107
|
+
return openrouter(modelName);
|
|
108
|
+
case 'gateway':
|
|
109
|
+
return gateway(modelName);
|
|
110
|
+
default:
|
|
111
|
+
throw new Error(
|
|
112
|
+
`Unsupported provider: ${provider}. ` +
|
|
113
|
+
`Supported providers are: ${ModelFactory.BUILT_IN_PROVIDERS.join(', ')}. ` +
|
|
114
|
+
`To access other models, use OpenRouter (openrouter/model-id) or Vercel AI Gateway (gateway/model-id).`
|
|
115
|
+
);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* Built-in providers that have special handling
|
|
121
|
+
*/
|
|
122
|
+
private static readonly BUILT_IN_PROVIDERS = [
|
|
123
|
+
'anthropic',
|
|
124
|
+
'openai',
|
|
125
|
+
'google',
|
|
126
|
+
'openrouter',
|
|
127
|
+
'gateway',
|
|
128
|
+
] as const;
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Parse model string to extract provider and model name
|
|
132
|
+
* Examples: "anthropic/claude-sonnet-4" -> { provider: "anthropic", modelName: "claude-sonnet-4" }
|
|
133
|
+
* "openrouter/anthropic/claude-sonnet-4" -> { provider: "openrouter", modelName: "anthropic/claude-sonnet-4" }
|
|
134
|
+
*/
|
|
135
|
+
static parseModelString(modelString: string): { provider: string; modelName: string } {
|
|
136
|
+
if (modelString.includes('/')) {
|
|
137
|
+
const [provider, ...modelParts] = modelString.split('/');
|
|
138
|
+
const normalizedProvider = provider.toLowerCase();
|
|
139
|
+
|
|
140
|
+
if (!ModelFactory.BUILT_IN_PROVIDERS.includes(normalizedProvider as any)) {
|
|
141
|
+
throw new Error(
|
|
142
|
+
`Unsupported provider: ${normalizedProvider}. ` +
|
|
143
|
+
`Supported providers are: ${ModelFactory.BUILT_IN_PROVIDERS.join(', ')}. ` +
|
|
144
|
+
`To access other models, use OpenRouter (openrouter/model-id) or Vercel AI Gateway (gateway/model-id).`
|
|
145
|
+
);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
return {
|
|
149
|
+
provider: normalizedProvider,
|
|
150
|
+
modelName: modelParts.join('/'),
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
throw new Error(`No provider specified in model string: ${modelString}`);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* Get generation parameters from provider options
|
|
159
|
+
* These are parameters that get passed to generateText/streamText calls
|
|
160
|
+
*/
|
|
161
|
+
static getGenerationParams(providerOptions?: Record<string, unknown>): Record<string, unknown> {
|
|
162
|
+
if (!providerOptions) {
|
|
163
|
+
return {};
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
const excludedKeys = ['apiKey', 'baseURL', 'baseUrl', 'maxDuration'];
|
|
167
|
+
|
|
168
|
+
const params: Record<string, unknown> = {};
|
|
169
|
+
for (const [key, value] of Object.entries(providerOptions)) {
|
|
170
|
+
if (!excludedKeys.includes(key) && value !== undefined) {
|
|
171
|
+
params[key] = value;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
return params;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* Prepare complete generation configuration from model settings
|
|
180
|
+
* Returns model instance and generation parameters ready to spread into generateText/streamText
|
|
181
|
+
* Includes maxDuration if specified in provider options (in seconds, following Vercel standard)
|
|
182
|
+
*/
|
|
183
|
+
static prepareGenerationConfig(modelSettings?: ModelSettings): {
|
|
184
|
+
model: LanguageModel;
|
|
185
|
+
maxDuration?: number;
|
|
186
|
+
} & Record<string, unknown> {
|
|
187
|
+
const modelString = modelSettings?.model?.trim();
|
|
188
|
+
|
|
189
|
+
const model = ModelFactory.createModel({
|
|
190
|
+
model: modelString,
|
|
191
|
+
providerOptions: modelSettings?.providerOptions,
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
const generationParams = ModelFactory.getGenerationParams(modelSettings?.providerOptions);
|
|
195
|
+
|
|
196
|
+
const maxDuration = modelSettings?.providerOptions?.maxDuration as number | undefined;
|
|
197
|
+
|
|
198
|
+
return {
|
|
199
|
+
model,
|
|
200
|
+
...generationParams,
|
|
201
|
+
...(maxDuration !== undefined && { maxDuration }),
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
}
|