agent-orcha 0.0.4 → 0.0.7
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/README.md +216 -1323
- package/dist/lib/agents/agent-executor.d.ts +15 -4
- package/dist/lib/agents/agent-executor.d.ts.map +1 -1
- package/dist/lib/agents/agent-executor.js +337 -87
- package/dist/lib/agents/agent-executor.js.map +1 -1
- package/dist/lib/agents/agent-loader.d.ts +4 -1
- package/dist/lib/agents/agent-loader.d.ts.map +1 -1
- package/dist/lib/agents/agent-loader.js +20 -4
- package/dist/lib/agents/agent-loader.js.map +1 -1
- package/dist/lib/agents/index.d.ts +5 -5
- package/dist/lib/agents/index.js +4 -4
- package/dist/lib/agents/react-loop.d.ts +30 -0
- package/dist/lib/agents/react-loop.d.ts.map +1 -0
- package/dist/lib/agents/react-loop.js +193 -0
- package/dist/lib/agents/react-loop.js.map +1 -0
- package/dist/lib/agents/structured-output-wrapper.d.ts +3 -3
- package/dist/lib/agents/structured-output-wrapper.d.ts.map +1 -1
- package/dist/lib/agents/structured-output-wrapper.js +2 -2
- package/dist/lib/agents/structured-output-wrapper.js.map +1 -1
- package/dist/lib/agents/types.d.ts +306 -19
- package/dist/lib/agents/types.d.ts.map +1 -1
- package/dist/lib/agents/types.js +34 -4
- package/dist/lib/agents/types.js.map +1 -1
- package/dist/lib/functions/function-loader.d.ts +3 -1
- package/dist/lib/functions/function-loader.d.ts.map +1 -1
- package/dist/lib/functions/function-loader.js +23 -5
- package/dist/lib/functions/function-loader.js.map +1 -1
- package/dist/lib/functions/index.d.ts +2 -2
- package/dist/lib/functions/index.js +1 -1
- package/dist/lib/functions/simple-function-wrapper.d.ts +2 -11
- package/dist/lib/functions/simple-function-wrapper.d.ts.map +1 -1
- package/dist/lib/functions/simple-function-wrapper.js +3 -3
- package/dist/lib/functions/simple-function-wrapper.js.map +1 -1
- package/dist/lib/index.d.ts +29 -17
- package/dist/lib/index.d.ts.map +1 -1
- package/dist/lib/index.js +21 -9
- package/dist/lib/index.js.map +1 -1
- package/dist/lib/integrations/collabnook.d.ts +56 -0
- package/dist/lib/integrations/collabnook.d.ts.map +1 -0
- package/dist/lib/integrations/collabnook.js +307 -0
- package/dist/lib/integrations/collabnook.js.map +1 -0
- package/dist/lib/integrations/email.d.ts +38 -0
- package/dist/lib/integrations/email.d.ts.map +1 -0
- package/dist/lib/integrations/email.js +249 -0
- package/dist/lib/integrations/email.js.map +1 -0
- package/dist/lib/integrations/integration-manager.d.ts +19 -0
- package/dist/lib/integrations/integration-manager.d.ts.map +1 -0
- package/dist/lib/integrations/integration-manager.js +159 -0
- package/dist/lib/integrations/integration-manager.js.map +1 -0
- package/dist/lib/integrations/types.d.ts +232 -0
- package/dist/lib/integrations/types.d.ts.map +1 -0
- package/dist/lib/integrations/types.js +37 -0
- package/dist/lib/integrations/types.js.map +1 -0
- package/dist/lib/knowledge/direct-mapper.d.ts +21 -0
- package/dist/lib/knowledge/direct-mapper.d.ts.map +1 -0
- package/dist/lib/knowledge/direct-mapper.js +134 -0
- package/dist/lib/knowledge/direct-mapper.js.map +1 -0
- package/dist/lib/knowledge/index.d.ts +9 -8
- package/dist/lib/knowledge/index.d.ts.map +1 -1
- package/dist/lib/knowledge/index.js +9 -7
- package/dist/lib/knowledge/index.js.map +1 -1
- package/dist/lib/knowledge/knowledge-store-metadata.d.ts +40 -0
- package/dist/lib/knowledge/knowledge-store-metadata.d.ts.map +1 -0
- package/dist/lib/knowledge/knowledge-store-metadata.js +93 -0
- package/dist/lib/knowledge/knowledge-store-metadata.js.map +1 -0
- package/dist/lib/knowledge/knowledge-store.d.ts +49 -0
- package/dist/lib/knowledge/knowledge-store.d.ts.map +1 -0
- package/dist/lib/knowledge/knowledge-store.js +670 -0
- package/dist/lib/knowledge/knowledge-store.js.map +1 -0
- package/dist/lib/knowledge/loaders/database-loader.d.ts +5 -5
- package/dist/lib/knowledge/loaders/database-loader.d.ts.map +1 -1
- package/dist/lib/knowledge/loaders/database-loader.js +21 -10
- package/dist/lib/knowledge/loaders/database-loader.js.map +1 -1
- package/dist/lib/knowledge/loaders/file-loaders.d.ts +45 -0
- package/dist/lib/knowledge/loaders/file-loaders.d.ts.map +1 -0
- package/dist/lib/knowledge/loaders/file-loaders.js +160 -0
- package/dist/lib/knowledge/loaders/file-loaders.js.map +1 -0
- package/dist/lib/knowledge/loaders/index.d.ts +3 -3
- package/dist/lib/knowledge/loaders/index.d.ts.map +1 -1
- package/dist/lib/knowledge/loaders/index.js +3 -3
- package/dist/lib/knowledge/loaders/index.js.map +1 -1
- package/dist/lib/knowledge/loaders/web-loader.d.ts +14 -5
- package/dist/lib/knowledge/loaders/web-loader.d.ts.map +1 -1
- package/dist/lib/knowledge/loaders/web-loader.js +64 -29
- package/dist/lib/knowledge/loaders/web-loader.js.map +1 -1
- package/dist/lib/knowledge/sqlite-store.d.ts +107 -0
- package/dist/lib/knowledge/sqlite-store.d.ts.map +1 -0
- package/dist/lib/knowledge/sqlite-store.js +327 -0
- package/dist/lib/knowledge/sqlite-store.js.map +1 -0
- package/dist/lib/knowledge/types.d.ts +124 -1448
- package/dist/lib/knowledge/types.d.ts.map +1 -1
- package/dist/lib/knowledge/types.js +54 -60
- package/dist/lib/knowledge/types.js.map +1 -1
- package/dist/lib/knowledge/utils/connection-pool.d.ts +3 -2
- package/dist/lib/knowledge/utils/connection-pool.d.ts.map +1 -1
- package/dist/lib/knowledge/utils/connection-pool.js +20 -10
- package/dist/lib/knowledge/utils/connection-pool.js.map +1 -1
- package/dist/lib/knowledge/utils/index.d.ts +2 -2
- package/dist/lib/knowledge/utils/index.js +2 -2
- package/dist/lib/llm/index.d.ts +5 -5
- package/dist/lib/llm/index.d.ts.map +1 -1
- package/dist/lib/llm/index.js +3 -3
- package/dist/lib/llm/index.js.map +1 -1
- package/dist/lib/llm/llm-call-logger.d.ts +39 -0
- package/dist/lib/llm/llm-call-logger.d.ts.map +1 -0
- package/dist/lib/llm/llm-call-logger.js +110 -0
- package/dist/lib/llm/llm-call-logger.js.map +1 -0
- package/dist/lib/llm/llm-config.d.ts +30 -16
- package/dist/lib/llm/llm-config.d.ts.map +1 -1
- package/dist/lib/llm/llm-config.js +22 -4
- package/dist/lib/llm/llm-config.js.map +1 -1
- package/dist/lib/llm/llm-factory.d.ts +3 -16
- package/dist/lib/llm/llm-factory.d.ts.map +1 -1
- package/dist/lib/llm/llm-factory.js +33 -48
- package/dist/lib/llm/llm-factory.js.map +1 -1
- package/dist/lib/llm/provider-detector.d.ts +1 -1
- package/dist/lib/llm/providers/anthropic-chat-model.d.ts +31 -0
- package/dist/lib/llm/providers/anthropic-chat-model.d.ts.map +1 -0
- package/dist/lib/llm/providers/anthropic-chat-model.js +262 -0
- package/dist/lib/llm/providers/anthropic-chat-model.js.map +1 -0
- package/dist/lib/llm/providers/gemini-chat-model.d.ts +30 -0
- package/dist/lib/llm/providers/gemini-chat-model.d.ts.map +1 -0
- package/dist/lib/llm/providers/gemini-chat-model.js +300 -0
- package/dist/lib/llm/providers/gemini-chat-model.js.map +1 -0
- package/dist/lib/llm/providers/gemini-embeddings.d.ts +14 -0
- package/dist/lib/llm/providers/gemini-embeddings.d.ts.map +1 -0
- package/dist/lib/llm/providers/gemini-embeddings.js +20 -0
- package/dist/lib/llm/providers/gemini-embeddings.js.map +1 -0
- package/dist/lib/llm/providers/openai-chat-model.d.ts +39 -0
- package/dist/lib/llm/providers/openai-chat-model.d.ts.map +1 -0
- package/dist/lib/llm/providers/openai-chat-model.js +397 -0
- package/dist/lib/llm/providers/openai-chat-model.js.map +1 -0
- package/dist/lib/llm/providers/openai-embeddings.d.ts +17 -0
- package/dist/lib/llm/providers/openai-embeddings.d.ts.map +1 -0
- package/dist/lib/llm/providers/openai-embeddings.js +35 -0
- package/dist/lib/llm/providers/openai-embeddings.js.map +1 -0
- package/dist/lib/llm/types.d.ts +2 -2
- package/dist/lib/llm/types.js +1 -1
- package/dist/lib/logger.d.ts +7 -0
- package/dist/lib/logger.d.ts.map +1 -1
- package/dist/lib/logger.js +42 -4
- package/dist/lib/logger.js.map +1 -1
- package/dist/lib/mcp/index.d.ts +3 -3
- package/dist/lib/mcp/index.js +2 -2
- package/dist/lib/mcp/mcp-client.d.ts +3 -2
- package/dist/lib/mcp/mcp-client.d.ts.map +1 -1
- package/dist/lib/mcp/mcp-client.js +10 -5
- package/dist/lib/mcp/mcp-client.js.map +1 -1
- package/dist/lib/mcp/types.d.ts +26 -25
- package/dist/lib/mcp/types.d.ts.map +1 -1
- package/dist/lib/mcp/types.js +12 -4
- package/dist/lib/mcp/types.js.map +1 -1
- package/dist/lib/memory/conversation-store.d.ts +2 -2
- package/dist/lib/memory/conversation-store.d.ts.map +1 -1
- package/dist/lib/memory/conversation-store.js +1 -1
- package/dist/lib/memory/index.d.ts +3 -2
- package/dist/lib/memory/index.d.ts.map +1 -1
- package/dist/lib/memory/index.js +3 -2
- package/dist/lib/memory/index.js.map +1 -1
- package/dist/lib/memory/memory-manager.d.ts +10 -0
- package/dist/lib/memory/memory-manager.d.ts.map +1 -0
- package/dist/lib/memory/memory-manager.js +43 -0
- package/dist/lib/memory/memory-manager.js.map +1 -0
- package/dist/lib/memory/types.d.ts +1 -1
- package/dist/lib/memory/types.d.ts.map +1 -1
- package/dist/lib/orchestrator.d.ts +72 -18
- package/dist/lib/orchestrator.d.ts.map +1 -1
- package/dist/lib/orchestrator.js +341 -56
- package/dist/lib/orchestrator.js.map +1 -1
- package/dist/lib/sandbox/cdp-client.d.ts +14 -0
- package/dist/lib/sandbox/cdp-client.d.ts.map +1 -0
- package/dist/lib/sandbox/cdp-client.js +113 -0
- package/dist/lib/sandbox/cdp-client.js.map +1 -0
- package/dist/lib/sandbox/html-to-markdown.d.ts +10 -0
- package/dist/lib/sandbox/html-to-markdown.d.ts.map +1 -0
- package/dist/lib/sandbox/html-to-markdown.js +121 -0
- package/dist/lib/sandbox/html-to-markdown.js.map +1 -0
- package/dist/lib/sandbox/index.d.ts +12 -0
- package/dist/lib/sandbox/index.d.ts.map +1 -0
- package/dist/lib/sandbox/index.js +10 -0
- package/dist/lib/sandbox/index.js.map +1 -0
- package/dist/lib/sandbox/page-readiness.d.ts +37 -0
- package/dist/lib/sandbox/page-readiness.d.ts.map +1 -0
- package/dist/lib/sandbox/page-readiness.js +235 -0
- package/dist/lib/sandbox/page-readiness.js.map +1 -0
- package/dist/lib/sandbox/sandbox-browser.d.ts +4 -0
- package/dist/lib/sandbox/sandbox-browser.d.ts.map +1 -0
- package/dist/lib/sandbox/sandbox-browser.js +303 -0
- package/dist/lib/sandbox/sandbox-browser.js.map +1 -0
- package/dist/lib/sandbox/sandbox-exec.d.ts +5 -0
- package/dist/lib/sandbox/sandbox-exec.d.ts.map +1 -0
- package/dist/lib/sandbox/sandbox-exec.js +35 -0
- package/dist/lib/sandbox/sandbox-exec.js.map +1 -0
- package/dist/lib/sandbox/sandbox-file.d.ts +4 -0
- package/dist/lib/sandbox/sandbox-file.d.ts.map +1 -0
- package/dist/lib/sandbox/sandbox-file.js +168 -0
- package/dist/lib/sandbox/sandbox-file.js.map +1 -0
- package/dist/lib/sandbox/sandbox-shell.d.ts +4 -0
- package/dist/lib/sandbox/sandbox-shell.d.ts.map +1 -0
- package/dist/lib/sandbox/sandbox-shell.js +93 -0
- package/dist/lib/sandbox/sandbox-shell.js.map +1 -0
- package/dist/lib/sandbox/sandbox-web.d.ts +5 -0
- package/dist/lib/sandbox/sandbox-web.d.ts.map +1 -0
- package/dist/lib/sandbox/sandbox-web.js +226 -0
- package/dist/lib/sandbox/sandbox-web.js.map +1 -0
- package/dist/lib/sandbox/types.d.ts +30 -0
- package/dist/lib/sandbox/types.d.ts.map +1 -0
- package/dist/lib/sandbox/types.js +8 -0
- package/dist/lib/sandbox/types.js.map +1 -0
- package/dist/lib/sandbox/vision-browser.d.ts +4 -0
- package/dist/lib/sandbox/vision-browser.d.ts.map +1 -0
- package/dist/lib/sandbox/vision-browser.js +289 -0
- package/dist/lib/sandbox/vision-browser.js.map +1 -0
- package/dist/lib/sandbox/vm-executor.d.ts +12 -0
- package/dist/lib/sandbox/vm-executor.d.ts.map +1 -0
- package/dist/lib/sandbox/vm-executor.js +101 -0
- package/dist/lib/sandbox/vm-executor.js.map +1 -0
- package/dist/lib/skills/index.d.ts +4 -0
- package/dist/lib/skills/index.d.ts.map +1 -0
- package/dist/lib/skills/index.js +3 -0
- package/dist/lib/skills/index.js.map +1 -0
- package/dist/lib/skills/skill-loader.d.ts +21 -0
- package/dist/lib/skills/skill-loader.d.ts.map +1 -0
- package/dist/lib/skills/skill-loader.js +116 -0
- package/dist/lib/skills/skill-loader.js.map +1 -0
- package/dist/lib/skills/types.d.ts +17 -0
- package/dist/lib/skills/types.d.ts.map +1 -0
- package/dist/lib/skills/types.js +6 -0
- package/dist/lib/skills/types.js.map +1 -0
- package/dist/lib/tasks/index.d.ts +4 -0
- package/dist/lib/tasks/index.d.ts.map +1 -0
- package/dist/lib/tasks/index.js +4 -0
- package/dist/lib/tasks/index.js.map +1 -0
- package/dist/lib/tasks/task-manager.d.ts +27 -0
- package/dist/lib/tasks/task-manager.d.ts.map +1 -0
- package/dist/lib/tasks/task-manager.js +200 -0
- package/dist/lib/tasks/task-manager.js.map +1 -0
- package/dist/lib/tasks/task-store.d.ts +20 -0
- package/dist/lib/tasks/task-store.d.ts.map +1 -0
- package/dist/lib/tasks/task-store.js +102 -0
- package/dist/lib/tasks/task-store.js.map +1 -0
- package/dist/lib/tasks/types.d.ts +56 -0
- package/dist/lib/tasks/types.d.ts.map +1 -0
- package/dist/lib/tasks/types.js +2 -0
- package/dist/lib/tasks/types.js.map +1 -0
- package/dist/lib/templates/resource-templates.d.ts +6 -0
- package/dist/lib/templates/resource-templates.d.ts.map +1 -0
- package/dist/lib/templates/resource-templates.js +146 -0
- package/dist/lib/templates/resource-templates.js.map +1 -0
- package/dist/lib/tools/agent-tool-wrapper.d.ts +5 -5
- package/dist/lib/tools/agent-tool-wrapper.js +3 -3
- package/dist/lib/tools/agent-tool-wrapper.js.map +1 -1
- package/dist/lib/tools/built-in/ask-user.tool.d.ts +1 -1
- package/dist/lib/tools/built-in/ask-user.tool.d.ts.map +1 -1
- package/dist/lib/tools/built-in/ask-user.tool.js +2 -2
- package/dist/lib/tools/built-in/ask-user.tool.js.map +1 -1
- package/dist/lib/tools/built-in/index.d.ts +9 -2
- package/dist/lib/tools/built-in/index.d.ts.map +1 -1
- package/dist/lib/tools/built-in/index.js +9 -2
- package/dist/lib/tools/built-in/index.js.map +1 -1
- package/dist/lib/tools/built-in/integration-tools.d.ts +4 -0
- package/dist/lib/tools/built-in/integration-tools.d.ts.map +1 -0
- package/dist/lib/tools/built-in/integration-tools.js +47 -0
- package/dist/lib/tools/built-in/integration-tools.js.map +1 -0
- package/dist/lib/tools/built-in/knowledge-entity-lookup.tool.d.ts +9 -0
- package/dist/lib/tools/built-in/knowledge-entity-lookup.tool.d.ts.map +1 -0
- package/dist/lib/tools/built-in/knowledge-entity-lookup.tool.js +108 -0
- package/dist/lib/tools/built-in/knowledge-entity-lookup.tool.js.map +1 -0
- package/dist/lib/tools/built-in/knowledge-graph-schema.tool.d.ts +9 -0
- package/dist/lib/tools/built-in/knowledge-graph-schema.tool.d.ts.map +1 -0
- package/dist/lib/tools/built-in/knowledge-graph-schema.tool.js +96 -0
- package/dist/lib/tools/built-in/knowledge-graph-schema.tool.js.map +1 -0
- package/dist/lib/tools/built-in/knowledge-search.tool.d.ts +2 -2
- package/dist/lib/tools/built-in/knowledge-search.tool.d.ts.map +1 -1
- package/dist/lib/tools/built-in/knowledge-search.tool.js +1 -1
- package/dist/lib/tools/built-in/knowledge-search.tool.js.map +1 -1
- package/dist/lib/tools/built-in/knowledge-sql.tool.d.ts +7 -0
- package/dist/lib/tools/built-in/knowledge-sql.tool.d.ts.map +1 -0
- package/dist/lib/tools/built-in/knowledge-sql.tool.js +128 -0
- package/dist/lib/tools/built-in/knowledge-sql.tool.js.map +1 -0
- package/dist/lib/tools/built-in/knowledge-tools-factory.d.ts +17 -0
- package/dist/lib/tools/built-in/knowledge-tools-factory.d.ts.map +1 -0
- package/dist/lib/tools/built-in/knowledge-tools-factory.js +54 -0
- package/dist/lib/tools/built-in/knowledge-tools-factory.js.map +1 -0
- package/dist/lib/tools/built-in/knowledge-traverse.tool.d.ts +9 -0
- package/dist/lib/tools/built-in/knowledge-traverse.tool.d.ts.map +1 -0
- package/dist/lib/tools/built-in/knowledge-traverse.tool.js +91 -0
- package/dist/lib/tools/built-in/knowledge-traverse.tool.js.map +1 -0
- package/dist/lib/tools/built-in/memory-save.tool.d.ts +4 -0
- package/dist/lib/tools/built-in/memory-save.tool.d.ts.map +1 -0
- package/dist/lib/tools/built-in/memory-save.tool.js +21 -0
- package/dist/lib/tools/built-in/memory-save.tool.js.map +1 -0
- package/dist/lib/tools/built-in/query-validators.d.ts +18 -0
- package/dist/lib/tools/built-in/query-validators.d.ts.map +1 -0
- package/dist/lib/tools/built-in/query-validators.js +91 -0
- package/dist/lib/tools/built-in/query-validators.js.map +1 -0
- package/dist/lib/tools/index.d.ts +4 -4
- package/dist/lib/tools/index.js +4 -4
- package/dist/lib/tools/tool-discovery.d.ts +11 -33
- package/dist/lib/tools/tool-discovery.d.ts.map +1 -1
- package/dist/lib/tools/tool-discovery.js +16 -43
- package/dist/lib/tools/tool-discovery.js.map +1 -1
- package/dist/lib/tools/tool-registry.d.ts +10 -18
- package/dist/lib/tools/tool-registry.d.ts.map +1 -1
- package/dist/lib/tools/tool-registry.js +37 -23
- package/dist/lib/tools/tool-registry.js.map +1 -1
- package/dist/lib/tools/workspace/workspace-tools.d.ts +61 -0
- package/dist/lib/tools/workspace/workspace-tools.d.ts.map +1 -0
- package/dist/lib/tools/workspace/workspace-tools.js +179 -0
- package/dist/lib/tools/workspace/workspace-tools.js.map +1 -0
- package/dist/lib/triggers/cron-trigger.d.ts +12 -0
- package/dist/lib/triggers/cron-trigger.d.ts.map +1 -0
- package/dist/lib/triggers/cron-trigger.js +45 -0
- package/dist/lib/triggers/cron-trigger.js.map +1 -0
- package/dist/lib/triggers/index.d.ts +6 -0
- package/dist/lib/triggers/index.d.ts.map +1 -0
- package/dist/lib/triggers/index.js +5 -0
- package/dist/lib/triggers/index.js.map +1 -0
- package/dist/lib/triggers/trigger-manager.d.ts +12 -0
- package/dist/lib/triggers/trigger-manager.d.ts.map +1 -0
- package/dist/lib/triggers/trigger-manager.js +77 -0
- package/dist/lib/triggers/trigger-manager.js.map +1 -0
- package/dist/lib/triggers/types.d.ts +57 -0
- package/dist/lib/triggers/types.d.ts.map +1 -0
- package/dist/lib/triggers/types.js +16 -0
- package/dist/lib/triggers/types.js.map +1 -0
- package/dist/lib/triggers/webhook-trigger.d.ts +12 -0
- package/dist/lib/triggers/webhook-trigger.d.ts.map +1 -0
- package/dist/lib/triggers/webhook-trigger.js +34 -0
- package/dist/lib/triggers/webhook-trigger.js.map +1 -0
- package/dist/lib/types/llm-types.d.ts +72 -0
- package/dist/lib/types/llm-types.d.ts.map +1 -0
- package/dist/lib/types/llm-types.js +72 -0
- package/dist/lib/types/llm-types.js.map +1 -0
- package/dist/lib/types/text-splitters.d.ts +27 -0
- package/dist/lib/types/text-splitters.d.ts.map +1 -0
- package/dist/lib/types/text-splitters.js +114 -0
- package/dist/lib/types/text-splitters.js.map +1 -0
- package/dist/lib/types/tool-factory.d.ts +9 -0
- package/dist/lib/types/tool-factory.d.ts.map +1 -0
- package/dist/lib/types/tool-factory.js +12 -0
- package/dist/lib/types/tool-factory.js.map +1 -0
- package/dist/lib/utils/env-substitution.d.ts +6 -0
- package/dist/lib/utils/env-substitution.d.ts.map +1 -0
- package/dist/lib/utils/env-substitution.js +15 -0
- package/dist/lib/utils/env-substitution.js.map +1 -0
- package/dist/lib/utils/file-utils.d.ts +11 -0
- package/dist/lib/utils/file-utils.d.ts.map +1 -0
- package/dist/lib/utils/file-utils.js +86 -0
- package/dist/lib/utils/file-utils.js.map +1 -0
- package/dist/lib/workflows/index.d.ts +6 -6
- package/dist/lib/workflows/index.d.ts.map +1 -1
- package/dist/lib/workflows/index.js +5 -5
- package/dist/lib/workflows/index.js.map +1 -1
- package/dist/lib/workflows/interrupt-manager.d.ts +1 -1
- package/dist/lib/workflows/interrupt-manager.js +1 -1
- package/dist/lib/workflows/react-workflow-executor.d.ts +26 -0
- package/dist/lib/workflows/react-workflow-executor.d.ts.map +1 -0
- package/dist/lib/workflows/react-workflow-executor.js +333 -0
- package/dist/lib/workflows/react-workflow-executor.js.map +1 -0
- package/dist/lib/workflows/types.d.ts +106 -107
- package/dist/lib/workflows/types.d.ts.map +1 -1
- package/dist/lib/workflows/types.js +5 -5
- package/dist/lib/workflows/types.js.map +1 -1
- package/dist/lib/workflows/workflow-executor.d.ts +3 -3
- package/dist/lib/workflows/workflow-executor.js +2 -2
- package/dist/lib/workflows/workflow-executor.js.map +1 -1
- package/dist/lib/workflows/workflow-loader.d.ts +4 -1
- package/dist/lib/workflows/workflow-loader.d.ts.map +1 -1
- package/dist/lib/workflows/workflow-loader.js +20 -4
- package/dist/lib/workflows/workflow-loader.js.map +1 -1
- package/dist/public/chat.html +114 -0
- package/dist/public/index.html +189 -0
- package/dist/public/src/components/AgentComposer.js +807 -0
- package/dist/public/src/components/AgentsView.js +1021 -344
- package/dist/public/src/components/AppRoot.js +150 -5
- package/dist/public/src/components/GraphView.js +420 -0
- package/dist/public/src/components/IdeView.js +625 -14
- package/dist/public/src/components/KnowledgeView.js +443 -66
- package/dist/public/src/components/MonitorView.js +526 -0
- package/dist/public/src/components/NavBar.js +3 -0
- package/dist/public/src/components/SkillsView.js +137 -0
- package/dist/public/src/components/StandaloneChat.js +889 -0
- package/dist/public/src/components/WorkflowsView.js +454 -129
- package/dist/public/src/services/ApiService.js +170 -25
- package/dist/public/src/services/SessionStore.js +83 -0
- package/dist/public/src/store.js +3 -4
- package/dist/public/src/utils/markdown.js +14 -0
- package/dist/src/cli/commands/init.js +2 -2
- package/dist/src/cli/commands/init.js.map +1 -1
- package/dist/src/cli/commands/start.d.ts +0 -1
- package/dist/src/cli/commands/start.d.ts.map +1 -1
- package/dist/src/cli/commands/start.js +23 -14
- package/dist/src/cli/commands/start.js.map +1 -1
- package/dist/src/cli/index.js +8 -5
- package/dist/src/cli/index.js.map +1 -1
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +23 -9
- package/dist/src/index.js.map +1 -1
- package/dist/src/middleware/auth.d.ts +3 -0
- package/dist/src/middleware/auth.d.ts.map +1 -0
- package/dist/src/middleware/auth.js +129 -0
- package/dist/src/middleware/auth.js.map +1 -0
- package/dist/src/middleware/rate-limit.d.ts +8 -0
- package/dist/src/middleware/rate-limit.d.ts.map +1 -0
- package/dist/src/middleware/rate-limit.js +21 -0
- package/dist/src/middleware/rate-limit.js.map +1 -0
- package/dist/src/routes/agents.route.d.ts.map +1 -1
- package/dist/src/routes/agents.route.js +167 -12
- package/dist/src/routes/agents.route.js.map +1 -1
- package/dist/src/routes/chat.route.d.ts +3 -0
- package/dist/src/routes/chat.route.d.ts.map +1 -0
- package/dist/src/routes/chat.route.js +155 -0
- package/dist/src/routes/chat.route.js.map +1 -0
- package/dist/src/routes/files.route.d.ts.map +1 -1
- package/dist/src/routes/files.route.js +163 -87
- package/dist/src/routes/files.route.js.map +1 -1
- package/dist/src/routes/functions.route.js +1 -1
- package/dist/src/routes/graph.route.d.ts +3 -0
- package/dist/src/routes/graph.route.d.ts.map +1 -0
- package/dist/src/routes/graph.route.js +173 -0
- package/dist/src/routes/graph.route.js.map +1 -0
- package/dist/src/routes/knowledge.route.d.ts.map +1 -1
- package/dist/src/routes/knowledge.route.js +172 -69
- package/dist/src/routes/knowledge.route.js.map +1 -1
- package/dist/src/routes/llm.route.d.ts.map +1 -1
- package/dist/src/routes/llm.route.js +85 -9
- package/dist/src/routes/llm.route.js.map +1 -1
- package/dist/src/routes/mcp.route.js +1 -1
- package/dist/src/routes/skills.route.d.ts +3 -0
- package/dist/src/routes/skills.route.d.ts.map +1 -0
- package/dist/src/routes/skills.route.js +23 -0
- package/dist/src/routes/skills.route.js.map +1 -0
- package/dist/src/routes/tasks.route.d.ts +3 -0
- package/dist/src/routes/tasks.route.d.ts.map +1 -0
- package/dist/src/routes/tasks.route.js +149 -0
- package/dist/src/routes/tasks.route.js.map +1 -0
- package/dist/src/routes/vnc.route.d.ts +3 -0
- package/dist/src/routes/vnc.route.d.ts.map +1 -0
- package/dist/src/routes/vnc.route.js +49 -0
- package/dist/src/routes/vnc.route.js.map +1 -0
- package/dist/src/routes/workflows.route.d.ts.map +1 -1
- package/dist/src/routes/workflows.route.js +9 -1
- package/dist/src/routes/workflows.route.js.map +1 -1
- package/dist/src/server.d.ts +1 -1
- package/dist/src/server.d.ts.map +1 -1
- package/dist/src/server.js +26 -9
- package/dist/src/server.js.map +1 -1
- package/dist/templates/.env.example +4 -19
- package/dist/templates/Demo.md +152 -0
- package/dist/templates/README.md +28 -11
- package/dist/templates/agents/architect.agent.yaml +57 -0
- package/dist/templates/agents/chatbot.agent.yaml +55 -0
- package/dist/templates/agents/corporate.agent.yaml +65 -0
- package/dist/templates/agents/investment-analyst.agent.yaml +80 -0
- package/dist/templates/agents/music-librarian.agent.yaml +70 -0
- package/dist/templates/agents/network-security.agent.yaml +82 -0
- package/dist/templates/agents/transport-security.agent.yaml +70 -0
- package/dist/templates/agents/web-engineer.agent.yaml +99 -0
- package/dist/templates/agents/web-pilot.agent.yaml +58 -0
- package/dist/templates/knowledge/music-store/LICENSE.md +11 -0
- package/dist/templates/knowledge/music-store/musicstore.sqlite +0 -0
- package/dist/templates/knowledge/music-store/tables.png +0 -0
- package/dist/templates/knowledge/music-store.knowledge.yaml +138 -0
- package/dist/templates/knowledge/org-chart/personnel.csv +21 -0
- package/dist/templates/knowledge/org-chart.knowledge.yaml +53 -0
- package/dist/templates/knowledge/pet-store/pet-store.db +0 -0
- package/dist/templates/knowledge/pet-store.knowledge.yaml +81 -0
- package/dist/templates/knowledge/security-incidents/incidents.json +55935 -0
- package/dist/templates/knowledge/security-incidents.knowledge.yaml +46 -0
- package/dist/templates/knowledge/transcripts.knowledge.yaml +29 -0
- package/dist/templates/knowledge/transport-ot/systems.csv +117 -0
- package/dist/templates/knowledge/transport-ot.knowledge.yaml +55 -0
- package/dist/templates/knowledge/web-docs.knowledge.yaml +20 -0
- package/dist/templates/llm.json +7 -30
- package/dist/templates/mcp.json +10 -4
- package/dist/templates/skills/orcha-builder/SKILL.md +219 -0
- package/dist/templates/skills/pii-guard/SKILL.md +22 -0
- package/dist/templates/skills/sandbox/SKILL.md +40 -0
- package/dist/templates/skills/web-pilot/SKILL.md +51 -0
- package/dist/templates/workflows/example.workflow.yaml +25 -30
- package/dist/templates/workflows/react-example.workflow.yaml +53 -0
- package/package.json +22 -20
- package/dist/lib/knowledge/graph-rag/community-detector.d.ts +0 -16
- package/dist/lib/knowledge/graph-rag/community-detector.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/community-detector.js +0 -81
- package/dist/lib/knowledge/graph-rag/community-detector.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/community-summarizer.d.ts +0 -17
- package/dist/lib/knowledge/graph-rag/community-summarizer.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/community-summarizer.js +0 -87
- package/dist/lib/knowledge/graph-rag/community-summarizer.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/entity-extractor.d.ts +0 -36
- package/dist/lib/knowledge/graph-rag/entity-extractor.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/entity-extractor.js +0 -192
- package/dist/lib/knowledge/graph-rag/entity-extractor.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/extraction-cache.d.ts +0 -30
- package/dist/lib/knowledge/graph-rag/extraction-cache.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/extraction-cache.js +0 -88
- package/dist/lib/knowledge/graph-rag/extraction-cache.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/global-search.d.ts +0 -19
- package/dist/lib/knowledge/graph-rag/global-search.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/global-search.js +0 -96
- package/dist/lib/knowledge/graph-rag/global-search.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/graph-rag-factory.d.ts +0 -24
- package/dist/lib/knowledge/graph-rag/graph-rag-factory.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/graph-rag-factory.js +0 -239
- package/dist/lib/knowledge/graph-rag/graph-rag-factory.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/index.d.ts +0 -14
- package/dist/lib/knowledge/graph-rag/index.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/index.js +0 -12
- package/dist/lib/knowledge/graph-rag/index.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/local-search.d.ts +0 -20
- package/dist/lib/knowledge/graph-rag/local-search.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/local-search.js +0 -110
- package/dist/lib/knowledge/graph-rag/local-search.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/memory-graph-store.d.ts +0 -31
- package/dist/lib/knowledge/graph-rag/memory-graph-store.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/memory-graph-store.js +0 -165
- package/dist/lib/knowledge/graph-rag/memory-graph-store.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/neo4j-graph-store.d.ts +0 -38
- package/dist/lib/knowledge/graph-rag/neo4j-graph-store.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/neo4j-graph-store.js +0 -190
- package/dist/lib/knowledge/graph-rag/neo4j-graph-store.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/search-mode-detector.d.ts +0 -11
- package/dist/lib/knowledge/graph-rag/search-mode-detector.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/search-mode-detector.js +0 -50
- package/dist/lib/knowledge/graph-rag/search-mode-detector.js.map +0 -1
- package/dist/lib/knowledge/graph-rag/types.d.ts +0 -368
- package/dist/lib/knowledge/graph-rag/types.d.ts.map +0 -1
- package/dist/lib/knowledge/graph-rag/types.js +0 -48
- package/dist/lib/knowledge/graph-rag/types.js.map +0 -1
- package/dist/lib/knowledge/knowledge-store-factory.d.ts +0 -16
- package/dist/lib/knowledge/knowledge-store-factory.d.ts.map +0 -1
- package/dist/lib/knowledge/knowledge-store-factory.js +0 -376
- package/dist/lib/knowledge/knowledge-store-factory.js.map +0 -1
- package/dist/lib/knowledge/knowledge-store-manager.d.ts +0 -18
- package/dist/lib/knowledge/knowledge-store-manager.d.ts.map +0 -1
- package/dist/lib/knowledge/knowledge-store-manager.js +0 -98
- package/dist/lib/knowledge/knowledge-store-manager.js.map +0 -1
- package/dist/lib/knowledge/loaders/s3-loader.d.ts +0 -17
- package/dist/lib/knowledge/loaders/s3-loader.d.ts.map +0 -1
- package/dist/lib/knowledge/loaders/s3-loader.js +0 -185
- package/dist/lib/knowledge/loaders/s3-loader.js.map +0 -1
- package/dist/lib/workflows/langgraph-executor.d.ts +0 -51
- package/dist/lib/workflows/langgraph-executor.d.ts.map +0 -1
- package/dist/lib/workflows/langgraph-executor.js +0 -297
- package/dist/lib/workflows/langgraph-executor.js.map +0 -1
- package/dist/templates/agents/call-center-analyst-simple.agent.yaml +0 -36
- package/dist/templates/agents/math.agent.yaml +0 -28
- package/dist/templates/agents/sentiment-structured.agent.yaml +0 -42
- package/dist/templates/knowledge/example.knowledge.yaml +0 -28
- package/dist/templates/llm.md +0 -1195
- package/dist/templates/workflows/langgraph-example.workflow.yaml +0 -84
|
@@ -2,12 +2,28 @@
|
|
|
2
2
|
import { Component } from '../utils/Component.js';
|
|
3
3
|
import { api } from '../services/ApiService.js';
|
|
4
4
|
|
|
5
|
+
const LOG_CONFIG = {
|
|
6
|
+
workflow_start: { icon: 'fa-play', color: 'blue' },
|
|
7
|
+
workflow_complete: { icon: 'fa-check-circle', color: 'green' },
|
|
8
|
+
workflow_error: { icon: 'fa-times-circle', color: 'red' },
|
|
9
|
+
workflow_interrupt: { icon: 'fa-pause-circle', color: 'amber' },
|
|
10
|
+
step_start: { icon: 'fa-arrow-right', color: 'blue' },
|
|
11
|
+
step_complete: { icon: 'fa-check', color: 'green' },
|
|
12
|
+
step_error: { icon: 'fa-exclamation-triangle', color: 'red' },
|
|
13
|
+
tool_discovery: { icon: 'fa-search', color: 'purple' },
|
|
14
|
+
react_iteration: { icon: 'fa-sync-alt', color: 'blue' },
|
|
15
|
+
tool_call: { icon: 'fa-wrench', color: 'cyan' },
|
|
16
|
+
tool_result: { icon: 'fa-reply', color: 'teal' },
|
|
17
|
+
};
|
|
18
|
+
|
|
5
19
|
export class WorkflowsView extends Component {
|
|
6
20
|
constructor() {
|
|
7
21
|
super();
|
|
8
|
-
this.
|
|
22
|
+
this.workflows = [];
|
|
9
23
|
this.selectedWorkflow = null;
|
|
10
24
|
this.chartInterval = null;
|
|
25
|
+
this.activeTaskId = null;
|
|
26
|
+
this.eventSource = null;
|
|
11
27
|
}
|
|
12
28
|
|
|
13
29
|
async connectedCallback() {
|
|
@@ -17,223 +33,532 @@ export class WorkflowsView extends Component {
|
|
|
17
33
|
|
|
18
34
|
disconnectedCallback() {
|
|
19
35
|
this.stopChartUpdate();
|
|
36
|
+
this.closeEventSource();
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
closeEventSource() {
|
|
40
|
+
if (this.eventSource) {
|
|
41
|
+
this.eventSource.close();
|
|
42
|
+
this.eventSource = null;
|
|
43
|
+
}
|
|
20
44
|
}
|
|
21
45
|
|
|
46
|
+
// ── Data ──
|
|
47
|
+
|
|
22
48
|
async loadWorkflows() {
|
|
23
49
|
try {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
select.innerHTML = '<option value="">-- Select Workflow --</option>' +
|
|
27
|
-
workflows.map(wf => `<option value="${wf.name}">${wf.name} - ${wf.description}</option>`).join('');
|
|
50
|
+
this.workflows = await api.getWorkflows();
|
|
51
|
+
this.renderCards();
|
|
28
52
|
} catch (e) {
|
|
29
53
|
console.error('Failed to load workflows', e);
|
|
30
54
|
}
|
|
31
55
|
}
|
|
32
56
|
|
|
33
|
-
async
|
|
34
|
-
if (
|
|
35
|
-
this.selectedWorkflow = null;
|
|
36
|
-
this.renderDiagram([]);
|
|
37
|
-
this.querySelector('#workflowInputs').innerHTML = '';
|
|
38
|
-
this.querySelector('#runWorkflow').disabled = true;
|
|
39
|
-
return;
|
|
40
|
-
}
|
|
57
|
+
async selectWorkflow(name) {
|
|
58
|
+
if (this.selectedWorkflow?.name === name) return;
|
|
41
59
|
|
|
42
60
|
try {
|
|
43
|
-
const
|
|
44
|
-
this.selectedWorkflow =
|
|
45
|
-
this.
|
|
46
|
-
this.
|
|
47
|
-
this.querySelector('#runWorkflow').disabled = false;
|
|
61
|
+
const full = await api.getWorkflow(name);
|
|
62
|
+
this.selectedWorkflow = full;
|
|
63
|
+
this.renderCards();
|
|
64
|
+
this.renderDetail();
|
|
48
65
|
} catch (e) {
|
|
49
66
|
console.error('Failed to load workflow details', e);
|
|
50
67
|
}
|
|
51
68
|
}
|
|
52
69
|
|
|
53
|
-
|
|
54
|
-
const container = this.querySelector('#workflowInputs');
|
|
55
|
-
container.innerHTML = '';
|
|
70
|
+
// ── Left sidebar: cards ──
|
|
56
71
|
|
|
57
|
-
|
|
72
|
+
renderCards() {
|
|
73
|
+
const container = this.querySelector('#workflowCards');
|
|
74
|
+
if (!container) return;
|
|
58
75
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
<
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
76
|
+
if (!this.workflows.length) {
|
|
77
|
+
container.innerHTML = `
|
|
78
|
+
<div class="text-gray-500 text-center py-12">
|
|
79
|
+
<i class="fas fa-project-diagram text-4xl mb-4 block text-gray-600"></i>
|
|
80
|
+
<p class="text-sm">No workflows found</p>
|
|
81
|
+
</div>`;
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
container.innerHTML = this.workflows.map(wf => {
|
|
86
|
+
const isSelected = this.selectedWorkflow?.name === wf.name;
|
|
87
|
+
const isReact = wf.type === 'react';
|
|
88
|
+
const badgeClass = isReact ? 'bg-amber-500/20 text-amber-400' : 'bg-blue-500/20 text-blue-400';
|
|
89
|
+
|
|
90
|
+
return `
|
|
91
|
+
<div class="workflow-card cursor-pointer rounded-lg p-3 border transition-colors
|
|
92
|
+
${isSelected ? 'bg-dark-surface border-purple-500' : 'bg-dark-surface/50 border-dark-border hover:border-purple-500/50'}"
|
|
93
|
+
data-name="${wf.name}">
|
|
94
|
+
<div class="flex items-center justify-between mb-1">
|
|
95
|
+
<span class="font-semibold text-gray-100 text-sm truncate">${this.escapeHtml(wf.name)}</span>
|
|
96
|
+
<span class="text-xs px-1.5 py-0.5 rounded ${badgeClass} flex-shrink-0">${wf.type || 'steps'}</span>
|
|
97
|
+
</div>
|
|
98
|
+
<div class="text-xs text-gray-500 line-clamp-2">${this.escapeHtml(wf.description || 'No description')}</div>
|
|
99
|
+
<div class="text-xs text-gray-600 mt-1">v${wf.version || '1.0.0'}${!isReact && wf.steps ? ` · ${wf.steps} steps` : ''}</div>
|
|
100
|
+
</div>`;
|
|
101
|
+
}).join('');
|
|
102
|
+
|
|
103
|
+
container.querySelectorAll('.workflow-card').forEach(card => {
|
|
104
|
+
card.addEventListener('click', () => this.selectWorkflow(card.dataset.name));
|
|
105
|
+
});
|
|
70
106
|
}
|
|
71
107
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
108
|
+
// ── Right panel: detail ──
|
|
109
|
+
|
|
110
|
+
renderDetail() {
|
|
111
|
+
const container = this.querySelector('#workflowDetail');
|
|
112
|
+
if (!container || !this.selectedWorkflow) {
|
|
113
|
+
if (container) container.innerHTML = '<div class="text-gray-500 italic text-center py-12">Select a workflow to view details</div>';
|
|
76
114
|
return;
|
|
77
115
|
}
|
|
78
116
|
|
|
117
|
+
const wf = this.selectedWorkflow;
|
|
118
|
+
const isReact = wf.type === 'react';
|
|
119
|
+
|
|
79
120
|
container.innerHTML = `
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
121
|
+
${this.buildInfoHtml(wf)}
|
|
122
|
+
${!isReact ? this.buildDiagramHtml(wf.steps || []) : ''}
|
|
123
|
+
${this.buildInputsHtml(wf.input?.schema || {})}
|
|
124
|
+
<button id="runWorkflow"
|
|
125
|
+
class="bg-purple-600 hover:bg-purple-700 disabled:bg-gray-700 disabled:cursor-not-allowed text-white font-medium px-5 py-2 rounded-lg transition-colors flex items-center gap-2 text-sm">
|
|
126
|
+
<i class="fas fa-play text-xs"></i>
|
|
127
|
+
Run Workflow
|
|
128
|
+
</button>
|
|
129
|
+
`;
|
|
130
|
+
|
|
131
|
+
this.querySelector('#runWorkflow')?.addEventListener('click', () => this.runWorkflow());
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
buildInfoHtml(wf) {
|
|
135
|
+
const isReact = wf.type === 'react';
|
|
136
|
+
const badgeClass = isReact ? 'bg-amber-500/20 text-amber-400' : 'bg-blue-500/20 text-blue-400';
|
|
137
|
+
|
|
138
|
+
let metaHtml = '';
|
|
139
|
+
if (isReact) {
|
|
140
|
+
const g = wf.graph || {};
|
|
141
|
+
metaHtml = `
|
|
142
|
+
<div class="grid grid-cols-4 gap-3 mt-3 pt-3 border-t border-dark-border">
|
|
143
|
+
<div><span class="text-gray-500 text-xs block">Model</span><span class="text-gray-300 text-sm">${this.escapeHtml(g.model || 'default')}</span></div>
|
|
144
|
+
<div><span class="text-gray-500 text-xs block">Mode</span><span class="text-gray-300 text-sm">${g.executionMode || 'react'}</span></div>
|
|
145
|
+
<div><span class="text-gray-500 text-xs block">Max Iter</span><span class="text-gray-300 text-sm">${g.maxIterations ?? 10}</span></div>
|
|
146
|
+
<div><span class="text-gray-500 text-xs block">Tools</span><span class="text-gray-300 text-sm">${g.tools?.mode || 'all'}</span></div>
|
|
147
|
+
</div>`;
|
|
148
|
+
} else {
|
|
149
|
+
const c = wf.config || {};
|
|
150
|
+
metaHtml = `
|
|
151
|
+
<div class="grid grid-cols-3 gap-3 mt-3 pt-3 border-t border-dark-border">
|
|
152
|
+
<div><span class="text-gray-500 text-xs block">Steps</span><span class="text-gray-300 text-sm">${(wf.steps || []).length}</span></div>
|
|
153
|
+
<div><span class="text-gray-500 text-xs block">On Error</span><span class="text-gray-300 text-sm">${c.onError || 'stop'}</span></div>
|
|
154
|
+
<div><span class="text-gray-500 text-xs block">Timeout</span><span class="text-gray-300 text-sm">${((c.timeout || 300000) / 1000)}s</span></div>
|
|
155
|
+
</div>`;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
return `
|
|
159
|
+
<div class="bg-dark-surface border border-dark-border rounded-lg p-4">
|
|
160
|
+
<div class="flex items-center gap-3">
|
|
161
|
+
<i class="fas ${isReact ? 'fa-atom' : 'fa-project-diagram'} text-purple-400"></i>
|
|
162
|
+
<div class="min-w-0">
|
|
163
|
+
<div class="flex items-center gap-2 flex-wrap">
|
|
164
|
+
<span class="font-semibold text-gray-100">${this.escapeHtml(wf.name)}</span>
|
|
165
|
+
<span class="text-xs px-2 py-0.5 rounded-full ${badgeClass}">${wf.type || 'steps'}</span>
|
|
166
|
+
<span class="text-xs text-gray-500">v${wf.version || '1.0.0'}</span>
|
|
167
|
+
</div>
|
|
168
|
+
<p class="text-xs text-gray-400 mt-0.5">${this.escapeHtml(wf.description || '')}</p>
|
|
169
|
+
</div>
|
|
83
170
|
</div>
|
|
84
|
-
${
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
171
|
+
${metaHtml}
|
|
172
|
+
</div>`;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
buildDiagramHtml(steps) {
|
|
176
|
+
if (!steps.length) return '';
|
|
177
|
+
|
|
178
|
+
const nodes = steps.map(step => `
|
|
179
|
+
<span class="text-gray-600 text-lg flex-shrink-0">→</span>
|
|
180
|
+
<div id="step-${step.id}" class="step-node flex flex-col items-center px-3 py-2 bg-blue-500/10 border border-blue-500/30 rounded-lg min-w-[100px] text-center transition-all">
|
|
181
|
+
<span class="font-semibold text-blue-300 text-xs">${step.id}</span>
|
|
182
|
+
<span class="text-xs text-gray-400">${step.agent}</span>
|
|
183
|
+
</div>
|
|
184
|
+
`).join('');
|
|
185
|
+
|
|
186
|
+
return `
|
|
187
|
+
<div class="bg-dark-surface border border-dark-border rounded-lg p-4 overflow-x-auto">
|
|
188
|
+
<div class="flex items-center gap-2 flex-nowrap min-w-max">
|
|
189
|
+
<div class="flex flex-col items-center px-3 py-2 bg-green-500/10 border border-green-500/30 rounded-lg min-w-[80px] text-center">
|
|
190
|
+
<span class="font-semibold text-green-400 text-xs">Input</span>
|
|
191
|
+
</div>
|
|
192
|
+
${nodes}
|
|
193
|
+
<span class="text-gray-600 text-lg flex-shrink-0">→</span>
|
|
194
|
+
<div class="flex flex-col items-center px-3 py-2 bg-green-500/10 border border-green-500/30 rounded-lg min-w-[80px] text-center">
|
|
195
|
+
<span class="font-semibold text-green-400 text-xs">Output</span>
|
|
89
196
|
</div>
|
|
90
|
-
`).join('')}
|
|
91
|
-
<span class="text-gray-600 text-xl flex-shrink-0">→</span>
|
|
92
|
-
<div class="flex flex-col items-center px-5 py-3 bg-green-500/10 border border-green-500/30 rounded-lg min-w-[100px] text-center">
|
|
93
|
-
<span class="font-semibold text-green-400 text-sm">Output</span>
|
|
94
197
|
</div>
|
|
198
|
+
</div>`;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
buildInputsHtml(schema) {
|
|
202
|
+
const entries = Object.entries(schema);
|
|
203
|
+
if (!entries.length) return '';
|
|
204
|
+
|
|
205
|
+
const fields = entries.map(([key, field]) => `
|
|
206
|
+
<div class="bg-dark-surface/50 border border-dark-border rounded-lg p-3">
|
|
207
|
+
<div class="flex items-center justify-between mb-1">
|
|
208
|
+
<label class="text-sm font-medium text-gray-300" for="wf-${key}">
|
|
209
|
+
${this.escapeHtml(key)}${field.required ? '<span class="text-red-400 ml-1">*</span>' : ''}
|
|
210
|
+
</label>
|
|
211
|
+
<span class="text-xs px-1.5 py-0.5 rounded bg-gray-700 text-gray-500">${field.type || 'string'}</span>
|
|
212
|
+
</div>
|
|
213
|
+
<input type="text" id="wf-${key}"
|
|
214
|
+
placeholder="${field.default ? `Default: ${field.default}` : field.required ? 'Required' : 'Optional'}"
|
|
215
|
+
value="${field.default || ''}"
|
|
216
|
+
class="w-full bg-dark-bg border border-dark-border rounded-lg px-3 py-2 text-sm text-gray-100 placeholder-gray-600 focus:outline-none focus:ring-2 focus:ring-purple-500 focus:border-transparent">
|
|
217
|
+
${field.description ? `<p class="text-xs text-gray-500 mt-1">${this.escapeHtml(field.description)}</p>` : ''}
|
|
95
218
|
</div>
|
|
96
|
-
|
|
219
|
+
`).join('');
|
|
220
|
+
|
|
221
|
+
return `
|
|
222
|
+
<div class="space-y-3">
|
|
223
|
+
<h3 class="text-sm font-semibold text-gray-300 flex items-center gap-2">
|
|
224
|
+
<i class="fas fa-keyboard text-gray-500 text-xs"></i>
|
|
225
|
+
Inputs
|
|
226
|
+
</h3>
|
|
227
|
+
${fields}
|
|
228
|
+
</div>`;
|
|
97
229
|
}
|
|
98
230
|
|
|
99
|
-
|
|
100
|
-
if (!this.selectedWorkflow) return;
|
|
231
|
+
// ── Execution ──
|
|
101
232
|
|
|
233
|
+
resetRunUI() {
|
|
234
|
+
const logEl = this.querySelector('#statusLog');
|
|
235
|
+
const outputEl = this.querySelector('#workflowOutput');
|
|
236
|
+
|
|
237
|
+
logEl.innerHTML = '';
|
|
238
|
+
outputEl.textContent = 'No output yet';
|
|
239
|
+
outputEl.className = outputEl.className.replace('text-gray-300', 'text-gray-500');
|
|
240
|
+
this.querySelector('#statusMessage').textContent = 'Starting...';
|
|
241
|
+
this.querySelector('#statusDot').className = 'inline-block w-2 h-2 rounded-full bg-blue-400 animate-pulse';
|
|
242
|
+
this.clearInterruptPrompt();
|
|
243
|
+
this.closeEventSource();
|
|
244
|
+
this.activeTaskId = null;
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
collectInputs() {
|
|
102
248
|
const inputs = {};
|
|
103
249
|
this.querySelectorAll('input[id^="wf-"]').forEach(input => {
|
|
104
250
|
const key = input.id.replace('wf-', '');
|
|
105
251
|
if (input.value) inputs[key] = input.value;
|
|
106
252
|
});
|
|
253
|
+
return inputs;
|
|
254
|
+
}
|
|
107
255
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
const runBtn = this.querySelector('#runWorkflow');
|
|
111
|
-
|
|
112
|
-
statusEl.classList.remove('hidden');
|
|
113
|
-
outputEl.textContent = 'Starting workflow...';
|
|
114
|
-
runBtn.disabled = true;
|
|
256
|
+
async runWorkflow() {
|
|
257
|
+
if (!this.selectedWorkflow) return;
|
|
115
258
|
|
|
259
|
+
const inputs = this.collectInputs();
|
|
260
|
+
const runBtn = this.querySelector('#runWorkflow');
|
|
261
|
+
this.resetRunUI();
|
|
262
|
+
if (runBtn) runBtn.disabled = true;
|
|
116
263
|
this.startChartUpdate();
|
|
117
264
|
|
|
265
|
+
const isReact = this.selectedWorkflow.type === 'react';
|
|
266
|
+
|
|
118
267
|
try {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
while (true) {
|
|
124
|
-
const { done, value } = await reader.read();
|
|
125
|
-
if (done) break;
|
|
126
|
-
|
|
127
|
-
const chunk = decoder.decode(value);
|
|
128
|
-
const lines = chunk.split('\n');
|
|
129
|
-
|
|
130
|
-
for (const line of lines) {
|
|
131
|
-
if (line.startsWith('data: ')) {
|
|
132
|
-
const data = line.slice(6);
|
|
133
|
-
if (data === '[DONE]') continue;
|
|
134
|
-
try {
|
|
135
|
-
const update = JSON.parse(data);
|
|
136
|
-
this.handleStatusUpdate(update);
|
|
137
|
-
} catch (e) { }
|
|
138
|
-
}
|
|
139
|
-
}
|
|
268
|
+
if (isReact) {
|
|
269
|
+
await this.runReactWorkflow(inputs);
|
|
270
|
+
} else {
|
|
271
|
+
await this.runStepsWorkflow(inputs);
|
|
140
272
|
}
|
|
141
273
|
} catch (e) {
|
|
142
|
-
|
|
274
|
+
this.addLog(`Error: ${e.message}`, 'workflow_error');
|
|
275
|
+
this.querySelector('#statusMessage').textContent = 'Error';
|
|
276
|
+
this.querySelector('#statusDot').className = 'inline-block w-2 h-2 rounded-full bg-red-400';
|
|
143
277
|
} finally {
|
|
144
|
-
|
|
145
|
-
|
|
278
|
+
if (!isReact) {
|
|
279
|
+
if (runBtn) runBtn.disabled = false;
|
|
280
|
+
this.stopChartUpdate();
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
async runStepsWorkflow(inputs) {
|
|
286
|
+
const res = await api.startWorkflowStream(this.selectedWorkflow.name, inputs);
|
|
287
|
+
const reader = res.body.getReader();
|
|
288
|
+
const decoder = new TextDecoder();
|
|
289
|
+
|
|
290
|
+
while (true) {
|
|
291
|
+
const { done, value } = await reader.read();
|
|
292
|
+
if (done) break;
|
|
293
|
+
|
|
294
|
+
const chunk = decoder.decode(value);
|
|
295
|
+
for (const line of chunk.split('\n')) {
|
|
296
|
+
if (!line.startsWith('data: ')) continue;
|
|
297
|
+
const data = line.slice(6);
|
|
298
|
+
if (data === '[DONE]') continue;
|
|
299
|
+
try { this.handleStatusUpdate(JSON.parse(data)); } catch (e) { }
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
async runReactWorkflow(inputs) {
|
|
305
|
+
const { id: taskId } = await api.submitWorkflowTask(this.selectedWorkflow.name, inputs);
|
|
306
|
+
this.activeTaskId = taskId;
|
|
307
|
+
this.addLog('Task submitted', 'workflow_start');
|
|
308
|
+
|
|
309
|
+
this.eventSource = api.streamTask(taskId);
|
|
310
|
+
|
|
311
|
+
this.eventSource.onmessage = (event) => {
|
|
312
|
+
try {
|
|
313
|
+
const data = JSON.parse(event.data);
|
|
314
|
+
this.handleTaskSSE(data);
|
|
315
|
+
} catch { /* ignore parse errors */ }
|
|
316
|
+
};
|
|
317
|
+
|
|
318
|
+
this.eventSource.onerror = () => {
|
|
319
|
+
this.closeEventSource();
|
|
320
|
+
this.finishReactRun();
|
|
321
|
+
};
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
handleTaskSSE(data) {
|
|
325
|
+
if (data.type === 'status') {
|
|
326
|
+
const statusMsg = this.querySelector('#statusMessage');
|
|
327
|
+
const statusDot = this.querySelector('#statusDot');
|
|
328
|
+
|
|
329
|
+
if (data.status === 'working') {
|
|
330
|
+
statusMsg.textContent = 'Working...';
|
|
331
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-blue-400 animate-pulse';
|
|
332
|
+
this.clearInterruptPrompt();
|
|
333
|
+
this.addLog('Workflow running', 'react_iteration');
|
|
334
|
+
} else if (data.status === 'input-required') {
|
|
335
|
+
const question = data.inputRequest?.question || 'Input required';
|
|
336
|
+
statusMsg.textContent = 'Awaiting input';
|
|
337
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-amber-400';
|
|
338
|
+
this.addLog(`Input required: ${question}`, 'workflow_interrupt');
|
|
339
|
+
this.showInterruptPrompt(question);
|
|
340
|
+
} else if (data.status === 'completed') {
|
|
341
|
+
statusMsg.textContent = 'Completed';
|
|
342
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-green-400';
|
|
343
|
+
this.addLog('Workflow completed', 'workflow_complete');
|
|
344
|
+
if (data.result) {
|
|
345
|
+
const outputEl = this.querySelector('#workflowOutput');
|
|
346
|
+
outputEl.className = outputEl.className.replace('text-gray-500', 'text-gray-300');
|
|
347
|
+
outputEl.textContent = JSON.stringify(data.result, null, 2);
|
|
348
|
+
}
|
|
349
|
+
} else if (data.status === 'failed') {
|
|
350
|
+
statusMsg.textContent = 'Error';
|
|
351
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-red-400';
|
|
352
|
+
this.addLog(`Error: ${data.error || 'Unknown error'}`, 'workflow_error');
|
|
353
|
+
} else if (data.status === 'canceled') {
|
|
354
|
+
statusMsg.textContent = 'Canceled';
|
|
355
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-yellow-400';
|
|
356
|
+
this.addLog('Task canceled', 'workflow_error');
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
if (data.type === 'done') {
|
|
361
|
+
this.closeEventSource();
|
|
362
|
+
this.finishReactRun();
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
finishReactRun() {
|
|
367
|
+
const runBtn = this.querySelector('#runWorkflow');
|
|
368
|
+
if (runBtn) runBtn.disabled = false;
|
|
369
|
+
this.stopChartUpdate();
|
|
370
|
+
this.activeTaskId = null;
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
showInterruptPrompt(question) {
|
|
374
|
+
const container = this.querySelector('#interruptPrompt');
|
|
375
|
+
if (!container) return;
|
|
376
|
+
|
|
377
|
+
container.innerHTML = `
|
|
378
|
+
<div class="bg-amber-500/10 border border-amber-500/30 rounded-lg p-4">
|
|
379
|
+
<div class="flex items-center gap-2 mb-3">
|
|
380
|
+
<i class="fas fa-question-circle text-amber-400"></i>
|
|
381
|
+
<span class="text-sm font-medium text-amber-400">Input Required</span>
|
|
382
|
+
</div>
|
|
383
|
+
<p class="text-sm text-gray-300 mb-3">${this.escapeHtml(question)}</p>
|
|
384
|
+
<div class="flex gap-2">
|
|
385
|
+
<input id="interruptInput" type="text" placeholder="Type your response..."
|
|
386
|
+
class="flex-1 bg-dark-bg border border-dark-border rounded-lg px-3 py-2 text-sm text-gray-200 focus:outline-none focus:border-amber-500" />
|
|
387
|
+
<button id="interruptSendBtn" class="px-4 py-2 bg-amber-500 hover:bg-amber-600 text-white text-sm font-medium rounded-lg transition-colors">
|
|
388
|
+
Send
|
|
389
|
+
</button>
|
|
390
|
+
</div>
|
|
391
|
+
</div>`;
|
|
392
|
+
|
|
393
|
+
this.querySelector('#interruptSendBtn').addEventListener('click', () => this.handleInterruptResponse());
|
|
394
|
+
this.querySelector('#interruptInput').addEventListener('keydown', (e) => {
|
|
395
|
+
if (e.key === 'Enter') this.handleInterruptResponse();
|
|
396
|
+
});
|
|
397
|
+
this.querySelector('#interruptInput').focus();
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
clearInterruptPrompt() {
|
|
401
|
+
const container = this.querySelector('#interruptPrompt');
|
|
402
|
+
if (container) container.innerHTML = '';
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
async handleInterruptResponse() {
|
|
406
|
+
const input = this.querySelector('#interruptInput');
|
|
407
|
+
const response = input?.value?.trim();
|
|
408
|
+
if (!response || !this.activeTaskId) return;
|
|
409
|
+
|
|
410
|
+
try {
|
|
411
|
+
await api.respondToTask(this.activeTaskId, response);
|
|
412
|
+
this.clearInterruptPrompt();
|
|
413
|
+
this.addLog(`Responded: ${response}`, 'tool_result');
|
|
414
|
+
this.querySelector('#statusMessage').textContent = 'Resuming...';
|
|
415
|
+
this.querySelector('#statusDot').className = 'inline-block w-2 h-2 rounded-full bg-blue-400 animate-pulse';
|
|
416
|
+
} catch (e) {
|
|
417
|
+
this.addLog(`Failed to respond: ${e.message}`, 'workflow_error');
|
|
146
418
|
}
|
|
147
419
|
}
|
|
148
420
|
|
|
149
421
|
handleStatusUpdate(update) {
|
|
150
422
|
if (update.type === 'status') {
|
|
151
423
|
const { message, type, stepId } = update.data;
|
|
152
|
-
this.querySelector('#statusMessage')
|
|
424
|
+
const statusMsg = this.querySelector('#statusMessage');
|
|
425
|
+
const statusDot = this.querySelector('#statusDot');
|
|
426
|
+
|
|
427
|
+
if (type === 'workflow_complete') {
|
|
428
|
+
statusMsg.textContent = 'Completed';
|
|
429
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-green-400';
|
|
430
|
+
} else if (type === 'workflow_error') {
|
|
431
|
+
statusMsg.textContent = 'Error';
|
|
432
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-red-400';
|
|
433
|
+
} else if (type === 'workflow_interrupt') {
|
|
434
|
+
statusMsg.textContent = 'Interrupted — Awaiting input';
|
|
435
|
+
statusDot.className = 'inline-block w-2 h-2 rounded-full bg-amber-400';
|
|
436
|
+
} else {
|
|
437
|
+
statusMsg.textContent = message;
|
|
438
|
+
}
|
|
439
|
+
|
|
153
440
|
this.addLog(message, type);
|
|
154
441
|
|
|
155
442
|
if (stepId) {
|
|
156
443
|
const stepEl = this.querySelector(`#step-${stepId}`);
|
|
157
444
|
if (stepEl) {
|
|
158
|
-
if (type === 'step_start')
|
|
159
|
-
|
|
445
|
+
if (type === 'step_start') {
|
|
446
|
+
stepEl.className = stepEl.className
|
|
447
|
+
.replace('bg-blue-500/10', 'bg-yellow-500/10 animate-pulse')
|
|
448
|
+
.replace('border-blue-500/30', 'border-yellow-500/30');
|
|
449
|
+
}
|
|
450
|
+
if (type === 'step_complete') {
|
|
451
|
+
stepEl.className = stepEl.className
|
|
452
|
+
.replace('bg-yellow-500/10 animate-pulse', 'bg-green-500/10')
|
|
453
|
+
.replace('border-yellow-500/30', 'border-green-500/30');
|
|
454
|
+
}
|
|
160
455
|
}
|
|
161
456
|
}
|
|
162
457
|
} else if (update.type === 'result') {
|
|
163
458
|
const outputEl = this.querySelector('#workflowOutput');
|
|
164
|
-
outputEl.
|
|
459
|
+
outputEl.className = outputEl.className.replace('text-gray-500', 'text-gray-300');
|
|
460
|
+
outputEl.textContent = JSON.stringify(update.data.output || update.data, null, 2);
|
|
165
461
|
}
|
|
166
462
|
}
|
|
167
463
|
|
|
168
464
|
addLog(msg, type) {
|
|
169
465
|
const log = this.querySelector('#statusLog');
|
|
466
|
+
const config = LOG_CONFIG[type] || { icon: 'fa-circle', color: 'gray' };
|
|
467
|
+
|
|
170
468
|
const div = document.createElement('div');
|
|
171
|
-
div.className = 'text-xs font-mono';
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
469
|
+
div.className = 'text-xs font-mono flex items-start gap-2 py-0.5';
|
|
470
|
+
|
|
471
|
+
const time = new Date().toLocaleTimeString();
|
|
472
|
+
div.innerHTML = `
|
|
473
|
+
<span class="text-gray-600 flex-shrink-0">${time}</span>
|
|
474
|
+
<i class="fas ${config.icon} text-${config.color}-400 text-xs mt-0.5 flex-shrink-0 w-3 text-center"></i>
|
|
475
|
+
<span class="text-${config.color}-400">${this.escapeHtml(msg)}</span>
|
|
476
|
+
`;
|
|
175
477
|
|
|
176
|
-
div.textContent = `[${new Date().toLocaleTimeString()}] ${msg}`;
|
|
177
478
|
log.appendChild(div);
|
|
178
479
|
log.scrollTop = log.scrollHeight;
|
|
179
480
|
}
|
|
180
481
|
|
|
482
|
+
// ── Timer ──
|
|
483
|
+
|
|
181
484
|
startChartUpdate() {
|
|
485
|
+
this.stopChartUpdate();
|
|
182
486
|
const start = Date.now();
|
|
183
487
|
const timeEl = this.querySelector('#statusTime');
|
|
488
|
+
timeEl.textContent = '0s';
|
|
184
489
|
this.chartInterval = setInterval(() => {
|
|
185
|
-
|
|
186
|
-
timeEl.textContent = `${seconds}s`;
|
|
490
|
+
timeEl.textContent = `${Math.floor((Date.now() - start) / 1000)}s`;
|
|
187
491
|
}, 1000);
|
|
188
492
|
}
|
|
189
493
|
|
|
190
494
|
stopChartUpdate() {
|
|
191
|
-
if (this.chartInterval)
|
|
495
|
+
if (this.chartInterval) {
|
|
496
|
+
clearInterval(this.chartInterval);
|
|
497
|
+
this.chartInterval = null;
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
// ── Helpers ──
|
|
502
|
+
|
|
503
|
+
escapeHtml(text) {
|
|
504
|
+
if (!text) return '';
|
|
505
|
+
return String(text).replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">");
|
|
192
506
|
}
|
|
193
507
|
|
|
194
508
|
postRender() {
|
|
195
|
-
|
|
196
|
-
this.onWorkflowSelected(e.target.value);
|
|
197
|
-
});
|
|
198
|
-
this.querySelector('#runWorkflow').addEventListener('click', () => {
|
|
199
|
-
this.runWorkflow();
|
|
200
|
-
});
|
|
509
|
+
// No static event bindings needed — cards and run button bind dynamically
|
|
201
510
|
}
|
|
202
511
|
|
|
203
512
|
template() {
|
|
204
513
|
return `
|
|
205
|
-
<div class="
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
<
|
|
209
|
-
class="
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
<div id="flowDiagram" class="bg-dark-surface border border-dark-border rounded-lg p-6 overflow-x-auto min-h-[120px] flex items-center justify-center">
|
|
215
|
-
<div class="text-gray-500 italic">Select a workflow</div>
|
|
216
|
-
</div>
|
|
217
|
-
|
|
218
|
-
<div id="workflowInputs" class="space-y-3"></div>
|
|
219
|
-
|
|
220
|
-
<div id="workflowStatus" class="bg-dark-surface border border-dark-border rounded-lg p-5 hidden">
|
|
221
|
-
<div class="flex justify-between items-center mb-3">
|
|
222
|
-
<div id="statusMessage" class="font-medium text-gray-200">Ready</div>
|
|
223
|
-
<div id="statusTime" class="text-sm text-gray-400">0s</div>
|
|
514
|
+
<div class="flex h-full gap-4">
|
|
515
|
+
<!-- Left sidebar -->
|
|
516
|
+
<div class="w-64 flex-shrink-0 overflow-y-auto custom-scrollbar pr-2">
|
|
517
|
+
<div class="flex items-center justify-between mb-3">
|
|
518
|
+
<h3 class="text-sm font-semibold text-gray-400 uppercase tracking-wider">Workflows</h3>
|
|
519
|
+
</div>
|
|
520
|
+
<div id="workflowCards" class="space-y-2">
|
|
521
|
+
<div class="text-gray-500 italic text-center py-8 text-sm">Loading...</div>
|
|
224
522
|
</div>
|
|
225
|
-
<div id="statusLog" class="bg-dark-bg rounded-lg p-3 h-32 overflow-y-auto space-y-1 border border-dark-border"></div>
|
|
226
523
|
</div>
|
|
227
524
|
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
525
|
+
<!-- Right panel -->
|
|
526
|
+
<div class="flex-1 flex flex-col h-full overflow-hidden pl-4 border-l border-dark-border">
|
|
527
|
+
<!-- Detail area (scrollable) -->
|
|
528
|
+
<div id="workflowDetail" class="flex-1 overflow-y-auto custom-scrollbar space-y-3 pb-3 min-h-0">
|
|
529
|
+
<div class="text-gray-500 italic text-center py-12">Select a workflow to view details</div>
|
|
530
|
+
</div>
|
|
232
531
|
|
|
233
|
-
|
|
234
|
-
<
|
|
235
|
-
|
|
236
|
-
|
|
532
|
+
<!-- Activity & Output (always visible, pinned bottom) -->
|
|
533
|
+
<div class="flex-shrink-0 pt-3 border-t border-dark-border space-y-3">
|
|
534
|
+
<!-- Activity log -->
|
|
535
|
+
<div>
|
|
536
|
+
<div class="flex justify-between items-center mb-1.5">
|
|
537
|
+
<h3 class="text-xs font-semibold text-gray-400 uppercase tracking-wider flex items-center gap-1.5">
|
|
538
|
+
<i class="fas fa-terminal"></i>
|
|
539
|
+
Activity
|
|
540
|
+
</h3>
|
|
541
|
+
<div class="flex items-center gap-2">
|
|
542
|
+
<span id="statusDot" class="inline-block w-2 h-2 rounded-full bg-gray-600"></span>
|
|
543
|
+
<span id="statusMessage" class="text-xs text-gray-500">Idle</span>
|
|
544
|
+
<span id="statusTime" class="text-xs font-mono text-gray-600">—</span>
|
|
545
|
+
</div>
|
|
546
|
+
</div>
|
|
547
|
+
<div id="statusLog" class="bg-dark-bg rounded-lg p-2.5 h-32 overflow-y-auto space-y-0.5 border border-dark-border custom-scrollbar"></div>
|
|
548
|
+
</div>
|
|
549
|
+
|
|
550
|
+
<!-- Interrupt prompt (shown when HITL input required) -->
|
|
551
|
+
<div id="interruptPrompt"></div>
|
|
552
|
+
|
|
553
|
+
<!-- Output -->
|
|
554
|
+
<div>
|
|
555
|
+
<h3 class="text-xs font-semibold text-gray-400 uppercase tracking-wider mb-1.5 flex items-center gap-1.5">
|
|
556
|
+
<i class="fas fa-code"></i>
|
|
557
|
+
Output
|
|
558
|
+
</h3>
|
|
559
|
+
<div id="workflowOutput" class="bg-dark-bg border border-dark-border rounded-lg p-2.5 h-24 font-mono text-xs text-gray-500 whitespace-pre-wrap overflow-auto custom-scrollbar">No output yet</div>
|
|
560
|
+
</div>
|
|
561
|
+
</div>
|
|
237
562
|
</div>
|
|
238
563
|
</div>
|
|
239
564
|
`;
|