claude-code-workflow 6.1.4 → 6.2.2
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/.claude/CLAUDE.md +10 -0
- package/.claude/agents/action-planning-agent.md +857 -778
- package/.claude/agents/cli-execution-agent.md +266 -269
- package/.claude/agents/cli-explore-agent.md +2 -2
- package/.claude/agents/cli-lite-planning-agent.md +142 -92
- package/.claude/agents/cli-planning-agent.md +4 -4
- package/.claude/agents/code-developer.md +7 -6
- package/.claude/agents/conceptual-planning-agent.md +2 -2
- package/.claude/agents/context-search-agent.md +31 -32
- package/.claude/agents/doc-generator.md +4 -4
- package/.claude/agents/memory-bridge.md +93 -93
- package/.claude/agents/test-context-search-agent.md +8 -7
- package/.claude/agents/test-fix-agent.md +7 -6
- package/.claude/commands/clean.md +516 -0
- package/.claude/commands/memory/compact.md +383 -0
- package/.claude/commands/memory/docs-full-cli.md +471 -471
- package/.claude/commands/memory/docs-related-cli.md +386 -386
- package/.claude/commands/memory/docs.md +615 -615
- package/.claude/commands/memory/load.md +5 -5
- package/.claude/commands/memory/tech-research-rules.md +310 -0
- package/.claude/commands/memory/update-full.md +332 -332
- package/.claude/commands/memory/workflow-skill-memory.md +4 -4
- package/.claude/commands/task/create.md +151 -151
- package/.claude/commands/version.md +254 -254
- package/.claude/commands/workflow/brainstorm/api-designer.md +587 -585
- package/.claude/commands/workflow/brainstorm/artifacts.md +1 -0
- package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -443
- package/.claude/commands/workflow/brainstorm/data-architect.md +220 -220
- package/.claude/commands/workflow/brainstorm/product-manager.md +200 -200
- package/.claude/commands/workflow/brainstorm/product-owner.md +200 -200
- package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -200
- package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
- package/.claude/commands/workflow/brainstorm/system-architect.md +389 -387
- package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -221
- package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -221
- package/.claude/commands/workflow/debug.md +321 -0
- package/.claude/commands/workflow/execute.md +13 -0
- package/.claude/commands/workflow/init.md +165 -164
- package/.claude/commands/workflow/lite-execute.md +119 -13
- package/.claude/commands/workflow/lite-fix.md +623 -621
- package/.claude/commands/workflow/lite-plan.md +610 -592
- package/.claude/commands/workflow/plan.md +5 -5
- package/.claude/commands/workflow/review-module-cycle.md +2 -0
- package/.claude/commands/workflow/review-session-cycle.md +2 -0
- package/.claude/commands/workflow/review.md +297 -291
- package/.claude/commands/workflow/session/complete.md +153 -500
- package/.claude/commands/workflow/session/list.md +95 -95
- package/.claude/commands/workflow/session/resume.md +60 -60
- package/.claude/commands/workflow/session/start.md +199 -199
- package/.claude/commands/workflow/tdd-plan.md +3 -3
- package/.claude/commands/workflow/tdd-verify.md +23 -9
- package/.claude/commands/workflow/test-cycle-execute.md +2 -0
- package/.claude/commands/workflow/test-fix-gen.md +699 -699
- package/.claude/commands/workflow/tools/conflict-resolution.md +104 -18
- package/.claude/commands/workflow/tools/context-gather.md +436 -434
- package/.claude/commands/workflow/tools/task-generate-agent.md +490 -291
- package/.claude/commands/workflow/tools/task-generate-tdd.md +18 -10
- package/.claude/commands/workflow/tools/test-concept-enhanced.md +2 -1
- package/.claude/commands/workflow/tools/test-context-gather.md +1 -0
- package/.claude/commands/workflow/tools/test-task-generate.md +1 -0
- package/.claude/commands/workflow/ui-design/import-from-code.md +9 -6
- package/.claude/skills/command-guide/SKILL.md +5 -5
- package/.claude/skills/command-guide/index/all-commands.json +1 -1
- package/.claude/skills/command-guide/index/by-category.json +1 -1
- package/.claude/skills/command-guide/index/by-use-case.json +1 -1
- package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -778
- package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +266 -269
- package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +2 -2
- package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +142 -92
- package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +4 -4
- package/.claude/skills/command-guide/reference/agents/code-developer.md +7 -6
- package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +2 -2
- package/.claude/skills/command-guide/reference/agents/context-search-agent.md +31 -32
- package/.claude/skills/command-guide/reference/agents/doc-generator.md +4 -4
- package/.claude/skills/command-guide/reference/agents/memory-bridge.md +93 -93
- package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +8 -7
- package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +7 -6
- package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -471
- package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -386
- package/.claude/skills/command-guide/reference/commands/memory/docs.md +17 -16
- package/.claude/skills/command-guide/reference/commands/memory/load.md +5 -5
- package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +194 -357
- package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -332
- package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +4 -4
- package/.claude/skills/command-guide/reference/commands/task/create.md +151 -151
- package/.claude/skills/command-guide/reference/commands/version.md +254 -254
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -585
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -443
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -220
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -387
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -221
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -221
- package/.claude/skills/command-guide/reference/commands/workflow/execute.md +25 -20
- package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -164
- package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -686
- package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -621
- package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -592
- package/.claude/skills/command-guide/reference/commands/workflow/plan.md +5 -5
- package/.claude/skills/command-guide/reference/commands/workflow/review.md +25 -18
- package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -500
- package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +45 -27
- package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +35 -19
- package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +90 -33
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +3 -3
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +23 -9
- package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -699
- package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +103 -17
- package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -434
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -291
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +17 -10
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +1 -1
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +6 -6
- package/.claude/workflows/chinese-response.md +38 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
- package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
- package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
- package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -131
- package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +5 -9
- package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +5 -9
- package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
- package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
- package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
- package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
- package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +25 -0
- package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +25 -0
- package/.claude/workflows/cli-tools-usage.md +526 -0
- package/{CLAUDE.md → .claude/workflows/coding-philosophy.md} +24 -45
- package/.claude/workflows/context-tools.md +84 -0
- package/.claude/workflows/file-modification.md +64 -0
- package/.claude/workflows/tool-strategy.md +216 -79
- package/.claude/workflows/windows-platform.md +16 -0
- package/.claude/workflows/workflow-architecture.md +942 -942
- package/.codex/AGENTS.md +63 -330
- package/.codex/prompts/debug.md +318 -0
- package/.codex/prompts/execute.md +273 -0
- package/.codex/prompts/lite-execute.md +164 -0
- package/.codex/prompts/lite-plan.md +469 -0
- package/.codex/prompts.zip +0 -0
- package/.gemini/GEMINI.md +25 -164
- package/.qwen/QWEN.md +0 -139
- package/README.md +29 -9
- package/ccw/README.md +30 -6
- package/ccw/bin/ccw-mcp.js +7 -0
- package/ccw/bin/ccw.js +9 -9
- package/ccw/package.json +65 -47
- package/ccw/src/.workflow/.cli-history/history.db +0 -0
- package/ccw/src/.workflow/.cli-history/history.db-shm +0 -0
- package/ccw/src/.workflow/.cli-history/history.db-wal +0 -0
- package/ccw/src/cli.ts +244 -0
- package/ccw/src/commands/cli.ts +740 -0
- package/ccw/src/commands/core-memory.ts +770 -0
- package/ccw/src/commands/hook.ts +315 -0
- package/ccw/src/commands/install.ts +519 -0
- package/ccw/src/commands/{list.js → list.ts} +1 -1
- package/ccw/src/commands/memory.ts +1090 -0
- package/ccw/src/commands/{serve.js → serve.ts} +14 -5
- package/ccw/src/commands/session-path-resolver.ts +372 -0
- package/ccw/src/commands/session.ts +1141 -0
- package/ccw/src/commands/{stop.js → stop.ts} +16 -6
- package/ccw/src/commands/tool.ts +201 -0
- package/ccw/src/commands/{uninstall.js → uninstall.ts} +89 -40
- package/ccw/src/commands/{upgrade.js → upgrade.ts} +68 -23
- package/ccw/src/commands/{view.js → view.ts} +22 -8
- package/ccw/src/config/storage-paths.ts +670 -0
- package/ccw/src/core/cache-manager.ts +294 -0
- package/ccw/src/core/claude-freshness.ts +319 -0
- package/ccw/src/core/core-memory-store.ts +1528 -0
- package/ccw/src/core/{dashboard-generator-patch.js → dashboard-generator-patch.ts} +18 -0
- package/ccw/src/core/{dashboard-generator.js → dashboard-generator.ts} +69 -12
- package/ccw/src/core/data-aggregator.ts +584 -0
- package/ccw/src/core/history-importer.ts +625 -0
- package/ccw/src/core/{lite-scanner.js → lite-scanner-complete.ts} +162 -66
- package/ccw/src/core/lite-scanner.ts +469 -0
- package/ccw/src/core/{manifest.js → manifest.ts} +104 -34
- package/ccw/src/core/memory-embedder-bridge.ts +262 -0
- package/ccw/src/core/memory-store.ts +978 -0
- package/ccw/src/core/routes/ccw-routes.ts +96 -0
- package/ccw/src/core/routes/claude-routes.ts +1183 -0
- package/ccw/src/core/routes/cli-routes.ts +561 -0
- package/ccw/src/core/routes/codexlens-routes.ts +806 -0
- package/ccw/src/core/routes/core-memory-routes.ts +605 -0
- package/ccw/src/core/routes/files-routes.ts +428 -0
- package/ccw/src/core/routes/graph-routes.md +164 -0
- package/ccw/src/core/routes/graph-routes.ts +626 -0
- package/ccw/src/core/routes/help-routes.ts +308 -0
- package/ccw/src/core/routes/hooks-routes.ts +405 -0
- package/ccw/src/core/routes/mcp-routes.ts +1271 -0
- package/ccw/src/core/routes/mcp-routes.ts.backup +550 -0
- package/ccw/src/core/routes/mcp-templates-db.ts +268 -0
- package/ccw/src/core/routes/memory-routes.ts +1206 -0
- package/ccw/src/core/routes/rules-routes.ts +526 -0
- package/ccw/src/core/routes/session-routes.ts +467 -0
- package/ccw/src/core/routes/skills-routes.ts +599 -0
- package/ccw/src/core/routes/status-routes.ts +57 -0
- package/ccw/src/core/routes/system-routes.ts +427 -0
- package/ccw/src/core/server.ts +431 -0
- package/ccw/src/core/session-clustering-service.ts +1258 -0
- package/ccw/src/core/session-scanner.ts +283 -0
- package/ccw/src/core/websocket.ts +190 -0
- package/ccw/src/{index.js → index.ts} +1 -0
- package/ccw/src/mcp-server/index.ts +186 -0
- package/ccw/src/templates/assets/css/github-dark.min.css +10 -0
- package/ccw/src/templates/assets/css/github.min.css +10 -0
- package/ccw/src/templates/assets/js/cytoscape.min.js +32 -0
- package/ccw/src/templates/assets/js/d3.min.js +2 -0
- package/ccw/src/templates/assets/js/highlight.min.js +1244 -0
- package/ccw/src/templates/assets/js/lucide.min.js +12 -0
- package/ccw/src/templates/assets/js/marked.min.js +69 -0
- package/ccw/src/templates/assets/js/tailwind.js +83 -0
- package/ccw/src/templates/dashboard-css/01-base.css +11 -0
- package/ccw/src/templates/dashboard-css/02-session.css +22 -0
- package/ccw/src/templates/dashboard-css/04-lite-tasks.css +10 -0
- package/ccw/src/templates/dashboard-css/06-cards.css +10 -4
- package/ccw/src/templates/dashboard-css/07-managers.css +1178 -7
- package/ccw/src/templates/dashboard-css/09-explorer.css +23 -12
- package/ccw/src/templates/dashboard-css/10-cli-status.css +337 -0
- package/ccw/src/templates/dashboard-css/11-cli-history.css +271 -0
- package/ccw/src/templates/dashboard-css/12-cli-legacy.css +796 -0
- package/ccw/src/templates/dashboard-css/13-cli-ccw.css +199 -0
- package/ccw/src/templates/dashboard-css/14-cli-modals.css +258 -0
- package/ccw/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
- package/ccw/src/templates/dashboard-css/16-cli-session.css +241 -0
- package/ccw/src/templates/dashboard-css/17-cli-conversation.css +283 -0
- package/ccw/src/templates/dashboard-css/18-cli-settings.css +160 -0
- package/ccw/src/templates/dashboard-css/19-cli-native-session.css +496 -0
- package/ccw/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
- package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
- package/ccw/src/templates/dashboard-css/22-cli-semantic.css +240 -0
- package/ccw/src/templates/dashboard-css/23-memory.css +2390 -0
- package/ccw/src/templates/dashboard-css/24-prompt-history.css +1089 -0
- package/ccw/src/templates/dashboard-css/25-skills-rules.css +326 -0
- package/ccw/src/templates/dashboard-css/26-claude-manager.css +908 -0
- package/ccw/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
- package/ccw/src/templates/dashboard-css/28-mcp-manager.css +748 -0
- package/ccw/src/templates/dashboard-css/29-help.css +264 -0
- package/ccw/src/templates/dashboard-css/30-core-memory.css +1700 -0
- package/ccw/src/templates/dashboard-js/api.js +162 -142
- package/ccw/src/templates/dashboard-js/components/carousel.js +4 -4
- package/ccw/src/templates/dashboard-js/components/cli-history.js +876 -0
- package/ccw/src/templates/dashboard-js/components/cli-status.js +978 -0
- package/ccw/src/templates/dashboard-js/components/global-notifications.js +508 -219
- package/ccw/src/templates/dashboard-js/components/hook-manager.js +1277 -282
- package/ccw/src/templates/dashboard-js/components/index-manager.js +302 -0
- package/ccw/src/templates/dashboard-js/components/mcp-manager.js +718 -27
- package/ccw/src/templates/dashboard-js/components/modals.js +66 -0
- package/ccw/src/templates/dashboard-js/components/navigation.js +80 -12
- package/ccw/src/templates/dashboard-js/components/notifications.js +758 -194
- package/ccw/src/templates/dashboard-js/components/storage-manager.js +478 -0
- package/ccw/src/templates/dashboard-js/components/tabs-other.js +157 -6
- package/ccw/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
- package/ccw/src/templates/dashboard-js/help-i18n.js +272 -0
- package/ccw/src/templates/dashboard-js/i18n.js +2807 -0
- package/ccw/src/templates/dashboard-js/main.js +15 -0
- package/ccw/src/templates/dashboard-js/state.js +243 -42
- package/ccw/src/templates/dashboard-js/utils.js +47 -1
- package/ccw/src/templates/dashboard-js/views/claude-manager.js +912 -0
- package/ccw/src/templates/dashboard-js/views/cli-manager.js +2272 -0
- package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
- package/ccw/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
- package/ccw/src/templates/dashboard-js/views/core-memory.js +782 -0
- package/ccw/src/templates/dashboard-js/views/explorer.js +888 -852
- package/ccw/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
- package/ccw/src/templates/dashboard-js/views/help.js +856 -0
- package/ccw/src/templates/dashboard-js/views/history.js +337 -0
- package/ccw/src/templates/dashboard-js/views/home.js +61 -15
- package/ccw/src/templates/dashboard-js/views/hook-manager.js +311 -43
- package/ccw/src/templates/dashboard-js/views/lite-tasks.js +204 -28
- package/ccw/src/templates/dashboard-js/views/mcp-manager.js +2187 -411
- package/ccw/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
- package/ccw/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
- package/ccw/src/templates/dashboard-js/views/memory.js +1221 -0
- package/ccw/src/templates/dashboard-js/views/prompt-history.js +713 -0
- package/ccw/src/templates/dashboard-js/views/rules-manager.js +828 -0
- package/ccw/src/templates/dashboard-js/views/session-detail.js +54 -53
- package/ccw/src/templates/dashboard-js/views/skills-manager.js +819 -0
- package/ccw/src/templates/dashboard.html +185 -85
- package/ccw/src/templates/hooks-config-example.json +60 -0
- package/ccw/src/tools/classify-folders.ts +245 -0
- package/ccw/src/tools/cli-config-manager.ts +268 -0
- package/ccw/src/tools/cli-executor.ts +2014 -0
- package/ccw/src/tools/cli-history-store.ts +1195 -0
- package/ccw/src/tools/codex-lens.ts +1141 -0
- package/ccw/src/tools/{convert-tokens-to-css.js → convert-tokens-to-css.ts} +73 -23
- package/ccw/src/tools/core-memory.ts +444 -0
- package/ccw/src/tools/detect-changed-modules.ts +325 -0
- package/ccw/src/tools/{discover-design-files.js → discover-design-files.ts} +74 -24
- package/ccw/src/tools/edit-file.ts +568 -0
- package/ccw/src/tools/{generate-module-docs.js → generate-module-docs.ts} +207 -185
- package/ccw/src/tools/{get-modules-by-depth.js → get-modules-by-depth.ts} +120 -79
- package/ccw/src/tools/index.ts +370 -0
- package/ccw/src/tools/native-session-discovery.ts +795 -0
- package/ccw/src/tools/notifier.ts +129 -0
- package/ccw/src/tools/read-file.ts +410 -0
- package/ccw/src/tools/resume-strategy.ts +345 -0
- package/ccw/src/tools/session-content-parser.ts +619 -0
- package/ccw/src/tools/session-manager.ts +1026 -0
- package/ccw/src/tools/smart-context.ts +228 -0
- package/ccw/src/tools/smart-search.ts +2065 -0
- package/ccw/src/tools/smart-search.ts.backup +1233 -0
- package/ccw/src/tools/storage-manager.ts +455 -0
- package/ccw/src/tools/write-file.ts +222 -0
- package/ccw/src/types/config.ts +11 -0
- package/ccw/src/types/index.ts +3 -0
- package/ccw/src/types/session.ts +25 -0
- package/ccw/src/types/tool.ts +41 -0
- package/ccw/src/utils/{browser-launcher.js → browser-launcher.ts} +10 -8
- package/ccw/src/utils/file-utils.ts +48 -0
- package/ccw/src/utils/{path-resolver.js → path-resolver.ts} +114 -78
- package/ccw/src/utils/path-validator.ts +153 -0
- package/ccw/src/utils/{ui.js → ui.ts} +32 -25
- package/codex-lens/pyproject.toml +48 -0
- package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
- package/codex-lens/src/codexlens/__init__.py +28 -0
- package/codex-lens/src/codexlens/__main__.py +14 -0
- package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__init__.py +27 -0
- package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/cli/commands.py +1931 -0
- package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
- package/codex-lens/src/codexlens/cli/model_manager.py +289 -0
- package/codex-lens/src/codexlens/cli/output.py +124 -0
- package/codex-lens/src/codexlens/config.py +201 -0
- package/codex-lens/src/codexlens/entities.py +121 -0
- package/codex-lens/src/codexlens/errors.py +55 -0
- package/codex-lens/src/codexlens/indexing/README.md +77 -0
- package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
- package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
- package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
- package/codex-lens/src/codexlens/parsers/factory.py +256 -0
- package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
- package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
- package/codex-lens/src/codexlens/search/__init__.py +15 -0
- package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/search/chain_search.py +647 -0
- package/codex-lens/src/codexlens/search/enrichment.py +150 -0
- package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
- package/codex-lens/src/codexlens/search/query_parser.py +242 -0
- package/codex-lens/src/codexlens/search/ranking.py +274 -0
- package/codex-lens/src/codexlens/semantic/__init__.py +39 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
- package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
- package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
- package/codex-lens/src/codexlens/semantic/embedder.py +185 -0
- package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
- package/codex-lens/src/codexlens/storage/__init__.py +29 -0
- package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
- package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
- package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
- package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
- package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
- package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
- package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
- package/codex-lens/src/codexlens/storage/registry.py +670 -0
- package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
- package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
- package/package.json +4 -1
- package/.claude/commands/memory/tech-research.md +0 -477
- package/.claude/scripts/classify-folders.sh +0 -39
- package/.claude/scripts/convert_tokens_to_css.sh +0 -229
- package/.claude/scripts/detect_changed_modules.sh +0 -161
- package/.claude/scripts/discover-design-files.sh +0 -87
- package/.claude/scripts/extract-animations.js +0 -243
- package/.claude/scripts/extract-computed-styles.js +0 -118
- package/.claude/scripts/extract-layout-structure.js +0 -411
- package/.claude/scripts/generate_module_docs.sh +0 -717
- package/.claude/scripts/get_modules_by_depth.sh +0 -170
- package/.claude/scripts/ui-generate-preview.sh +0 -395
- package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
- package/.claude/scripts/update_module_claude.sh +0 -337
- package/.claude/workflows/context-search-strategy.md +0 -77
- package/.claude/workflows/intelligent-tools-strategy.md +0 -662
- package/ccw/src/cli.js +0 -119
- package/ccw/src/commands/install.js +0 -324
- package/ccw/src/commands/tool.js +0 -138
- package/ccw/src/core/data-aggregator.js +0 -409
- package/ccw/src/core/server.js +0 -2063
- package/ccw/src/core/session-scanner.js +0 -235
- package/ccw/src/tools/classify-folders.js +0 -204
- package/ccw/src/tools/detect-changed-modules.js +0 -288
- package/ccw/src/tools/edit-file.js +0 -266
- package/ccw/src/tools/index.js +0 -176
- package/ccw/src/utils/file-utils.js +0 -48
|
@@ -0,0 +1,503 @@
|
|
|
1
|
+
// Session Clustering visualization for Core Memory
|
|
2
|
+
// Dependencies: This file requires core-memory.js to be loaded first
|
|
3
|
+
// - Uses: viewMemoryDetail(), fetchMemoryById(), showNotification(), t(), escapeHtml(), projectPath
|
|
4
|
+
|
|
5
|
+
// Global state
|
|
6
|
+
var clusterList = [];
|
|
7
|
+
var selectedCluster = null;
|
|
8
|
+
var embeddingStatus = null;
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Check embedding status for better clustering
|
|
12
|
+
*/
|
|
13
|
+
async function checkEmbeddingStatus() {
|
|
14
|
+
try {
|
|
15
|
+
const response = await fetch(`/api/core-memory/embed-status?path=${encodeURIComponent(projectPath)}`);
|
|
16
|
+
if (response.ok) {
|
|
17
|
+
embeddingStatus = await response.json();
|
|
18
|
+
}
|
|
19
|
+
} catch (error) {
|
|
20
|
+
console.log('Embedding status check skipped:', error.message);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Fetch and render cluster list
|
|
26
|
+
*/
|
|
27
|
+
async function loadClusters() {
|
|
28
|
+
try {
|
|
29
|
+
// Check embedding status first
|
|
30
|
+
await checkEmbeddingStatus();
|
|
31
|
+
|
|
32
|
+
const response = await fetch(`/api/core-memory/clusters?path=${encodeURIComponent(projectPath)}`);
|
|
33
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
34
|
+
|
|
35
|
+
const result = await response.json();
|
|
36
|
+
clusterList = result.clusters || [];
|
|
37
|
+
renderClusterList();
|
|
38
|
+
} catch (error) {
|
|
39
|
+
console.error('Failed to load clusters:', error);
|
|
40
|
+
showNotification(t('coreMemory.clusterLoadError'), 'error');
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Render embedding status hint
|
|
46
|
+
*/
|
|
47
|
+
function renderEmbeddingHint() {
|
|
48
|
+
// No status data - API call failed
|
|
49
|
+
if (!embeddingStatus) {
|
|
50
|
+
return '';
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// Embedder not available - show install hint linking to status page
|
|
54
|
+
if (embeddingStatus.available === false) {
|
|
55
|
+
return `
|
|
56
|
+
<div class="embedding-hint warning">
|
|
57
|
+
<i data-lucide="alert-triangle"></i>
|
|
58
|
+
<span>${t('coreMemory.embeddingNotAvailable')}</span>
|
|
59
|
+
<a href="#" onclick="switchToSemanticStatus(); return false;" class="hint-link">
|
|
60
|
+
${t('coreMemory.installGuide')}
|
|
61
|
+
</a>
|
|
62
|
+
</div>
|
|
63
|
+
`;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Has pending chunks - show progress
|
|
67
|
+
if (embeddingStatus.pending_chunks > 0) {
|
|
68
|
+
const pct = embeddingStatus.total_chunks > 0
|
|
69
|
+
? Math.round((embeddingStatus.embedded_chunks / embeddingStatus.total_chunks) * 100)
|
|
70
|
+
: 0;
|
|
71
|
+
return `
|
|
72
|
+
<div class="embedding-hint info">
|
|
73
|
+
<i data-lucide="cpu"></i>
|
|
74
|
+
<span>${t('coreMemory.embeddingProgress', { pct, pending: embeddingStatus.pending_chunks })}</span>
|
|
75
|
+
<button class="btn btn-xs" onclick="triggerEmbedding()">
|
|
76
|
+
${t('coreMemory.generateEmbeddings')}
|
|
77
|
+
</button>
|
|
78
|
+
</div>
|
|
79
|
+
`;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// No chunks yet - show hint to run embed
|
|
83
|
+
if (embeddingStatus.total_chunks === 0) {
|
|
84
|
+
return `
|
|
85
|
+
<div class="embedding-hint info">
|
|
86
|
+
<i data-lucide="info"></i>
|
|
87
|
+
<span>${t('coreMemory.noChunksYet')}</span>
|
|
88
|
+
<button class="btn btn-xs" onclick="triggerEmbedding()">
|
|
89
|
+
${t('coreMemory.generateEmbeddings')}
|
|
90
|
+
</button>
|
|
91
|
+
</div>
|
|
92
|
+
`;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// All embedded - no hint needed
|
|
96
|
+
return '';
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Switch to CLI Manager and show semantic install hint
|
|
101
|
+
*/
|
|
102
|
+
function switchToSemanticStatus() {
|
|
103
|
+
// Navigate to CLI Manager view (which contains the Semantic Search section)
|
|
104
|
+
const navItem = document.querySelector('[data-view="cli-manager"]');
|
|
105
|
+
if (navItem) {
|
|
106
|
+
navItem.click();
|
|
107
|
+
// Open CodexLens config modal after navigation
|
|
108
|
+
setTimeout(() => {
|
|
109
|
+
if (typeof openCodexLensConfig === 'function') {
|
|
110
|
+
openCodexLensConfig();
|
|
111
|
+
}
|
|
112
|
+
}, 300);
|
|
113
|
+
} else {
|
|
114
|
+
showNotification(t('coreMemory.goToSemanticStatus'), 'info');
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Trigger embedding generation
|
|
120
|
+
*/
|
|
121
|
+
async function triggerEmbedding() {
|
|
122
|
+
try {
|
|
123
|
+
showNotification(t('coreMemory.embeddingInProgress'), 'info');
|
|
124
|
+
const response = await fetch(`/api/core-memory/embed?path=${encodeURIComponent(projectPath)}`, {
|
|
125
|
+
method: 'POST'
|
|
126
|
+
});
|
|
127
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
128
|
+
const result = await response.json();
|
|
129
|
+
showNotification(t('coreMemory.embeddingComplete', { count: result.chunks_processed }), 'success');
|
|
130
|
+
await loadClusters();
|
|
131
|
+
} catch (error) {
|
|
132
|
+
console.error('Embedding failed:', error);
|
|
133
|
+
showNotification(t('coreMemory.embeddingError'), 'error');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Render cluster list in sidebar
|
|
139
|
+
*/
|
|
140
|
+
function renderClusterList() {
|
|
141
|
+
const container = document.getElementById('clusterListContainer');
|
|
142
|
+
if (!container) return;
|
|
143
|
+
|
|
144
|
+
// Add embedding status hint at top
|
|
145
|
+
const embeddingHint = renderEmbeddingHint();
|
|
146
|
+
|
|
147
|
+
if (clusterList.length === 0) {
|
|
148
|
+
container.innerHTML = `
|
|
149
|
+
${embeddingHint}
|
|
150
|
+
<div class="empty-state">
|
|
151
|
+
<i data-lucide="folder-tree"></i>
|
|
152
|
+
<p>${t('coreMemory.noClusters')}</p>
|
|
153
|
+
<button class="btn btn-primary btn-sm" onclick="triggerAutoClustering()">
|
|
154
|
+
<i data-lucide="sparkles"></i>
|
|
155
|
+
${t('coreMemory.autoCluster')}
|
|
156
|
+
</button>
|
|
157
|
+
</div>
|
|
158
|
+
`;
|
|
159
|
+
lucide.createIcons();
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
container.innerHTML = embeddingHint + clusterList.map(cluster => `
|
|
164
|
+
<div class="cluster-item ${selectedCluster?.id === cluster.id ? 'active' : ''}"
|
|
165
|
+
onclick="selectCluster('${cluster.id}')">
|
|
166
|
+
<div class="cluster-icon">
|
|
167
|
+
<i data-lucide="${cluster.status === 'active' ? 'folder-open' : 'folder'}"></i>
|
|
168
|
+
</div>
|
|
169
|
+
<div class="cluster-info">
|
|
170
|
+
<div class="cluster-name">${escapeHtml(cluster.name)}</div>
|
|
171
|
+
<div class="cluster-meta">
|
|
172
|
+
<span>${cluster.memberCount} sessions</span>
|
|
173
|
+
<span>${formatDate(cluster.updated_at)}</span>
|
|
174
|
+
</div>
|
|
175
|
+
</div>
|
|
176
|
+
<span class="badge badge-${cluster.status}">${cluster.status}</span>
|
|
177
|
+
</div>
|
|
178
|
+
`).join('');
|
|
179
|
+
|
|
180
|
+
lucide.createIcons();
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/**
|
|
184
|
+
* Select and load cluster details
|
|
185
|
+
*/
|
|
186
|
+
async function selectCluster(clusterId) {
|
|
187
|
+
try {
|
|
188
|
+
const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`);
|
|
189
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
190
|
+
|
|
191
|
+
const result = await response.json();
|
|
192
|
+
selectedCluster = result.cluster;
|
|
193
|
+
renderClusterDetail(result.cluster, result.members, result.relations);
|
|
194
|
+
|
|
195
|
+
// Update list to show selection
|
|
196
|
+
renderClusterList();
|
|
197
|
+
} catch (error) {
|
|
198
|
+
console.error('Failed to load cluster:', error);
|
|
199
|
+
showNotification(t('coreMemory.clusterDetailError'), 'error');
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Render cluster detail view
|
|
205
|
+
*/
|
|
206
|
+
function renderClusterDetail(cluster, members, relations) {
|
|
207
|
+
const container = document.getElementById('clusterDetailContainer');
|
|
208
|
+
if (!container) return;
|
|
209
|
+
|
|
210
|
+
container.innerHTML = `
|
|
211
|
+
<div class="cluster-detail">
|
|
212
|
+
<div class="cluster-header">
|
|
213
|
+
<h3>${escapeHtml(cluster.name)}</h3>
|
|
214
|
+
<div class="cluster-actions">
|
|
215
|
+
<button class="btn btn-sm" onclick="editCluster('${cluster.id}')" title="${t('common.edit')}">
|
|
216
|
+
<i data-lucide="edit-2"></i>
|
|
217
|
+
</button>
|
|
218
|
+
<button class="btn btn-sm btn-danger" onclick="deleteCluster('${cluster.id}')" title="${t('common.delete')}">
|
|
219
|
+
<i data-lucide="trash-2"></i>
|
|
220
|
+
</button>
|
|
221
|
+
</div>
|
|
222
|
+
</div>
|
|
223
|
+
|
|
224
|
+
${cluster.description ? `<p class="cluster-description">${escapeHtml(cluster.description)}</p>` : ''}
|
|
225
|
+
${cluster.intent ? `<div class="cluster-intent"><strong>${t('coreMemory.intent')}:</strong> ${escapeHtml(cluster.intent)}</div>` : ''}
|
|
226
|
+
|
|
227
|
+
<div class="cluster-timeline">
|
|
228
|
+
<h4><i data-lucide="git-branch"></i> ${t('coreMemory.sessionTimeline')}</h4>
|
|
229
|
+
${renderTimeline(members)}
|
|
230
|
+
</div>
|
|
231
|
+
|
|
232
|
+
${relations && relations.length > 0 ? `
|
|
233
|
+
<div class="cluster-relations">
|
|
234
|
+
<h4><i data-lucide="link"></i> ${t('coreMemory.relatedClusters')}</h4>
|
|
235
|
+
${renderRelations(relations)}
|
|
236
|
+
</div>
|
|
237
|
+
` : ''}
|
|
238
|
+
</div>
|
|
239
|
+
`;
|
|
240
|
+
|
|
241
|
+
lucide.createIcons();
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* Render session timeline
|
|
246
|
+
*/
|
|
247
|
+
function renderTimeline(members) {
|
|
248
|
+
if (!members || members.length === 0) {
|
|
249
|
+
return `<p class="text-muted">${t('coreMemory.noSessions')}</p>`;
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
// Sort by sequence order
|
|
253
|
+
const sorted = [...members].sort((a, b) => a.sequence_order - b.sequence_order);
|
|
254
|
+
|
|
255
|
+
return `
|
|
256
|
+
<div class="timeline">
|
|
257
|
+
${sorted.map((member, index) => {
|
|
258
|
+
const meta = member.metadata || {};
|
|
259
|
+
// Get display text - prefer title, fallback to summary
|
|
260
|
+
const displayTitle = meta.title || meta.summary || '';
|
|
261
|
+
// Truncate for display
|
|
262
|
+
const truncatedTitle = displayTitle.length > 120
|
|
263
|
+
? displayTitle.substring(0, 120) + '...'
|
|
264
|
+
: displayTitle;
|
|
265
|
+
|
|
266
|
+
return `
|
|
267
|
+
<div class="timeline-item">
|
|
268
|
+
<div class="timeline-marker">
|
|
269
|
+
<span class="timeline-number">${index + 1}</span>
|
|
270
|
+
</div>
|
|
271
|
+
<div class="timeline-content clickable" onclick="previewSession('${member.session_id}', '${member.session_type}')">
|
|
272
|
+
<div class="timeline-header">
|
|
273
|
+
<span class="session-id">${escapeHtml(member.session_id)}</span>
|
|
274
|
+
<span class="badge badge-${member.session_type}">${member.session_type}</span>
|
|
275
|
+
</div>
|
|
276
|
+
${truncatedTitle ? `<div class="session-title">${escapeHtml(truncatedTitle)}</div>` : ''}
|
|
277
|
+
${meta.token_estimate ? `<div class="session-tokens">~${meta.token_estimate} tokens</div>` : ''}
|
|
278
|
+
<div class="timeline-card-footer">
|
|
279
|
+
<span class="preview-hint"><i data-lucide="eye"></i> ${t('coreMemory.clickToPreview')}</span>
|
|
280
|
+
<button class="btn btn-xs btn-ghost btn-danger" onclick="event.stopPropagation(); removeMember('${selectedCluster.id}', '${member.session_id}')" title="${t('common.delete')}">
|
|
281
|
+
<i data-lucide="trash-2"></i>
|
|
282
|
+
</button>
|
|
283
|
+
</div>
|
|
284
|
+
</div>
|
|
285
|
+
</div>
|
|
286
|
+
`}).join('')}
|
|
287
|
+
</div>
|
|
288
|
+
`;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
/**
|
|
292
|
+
* Preview session in modal based on type
|
|
293
|
+
*/
|
|
294
|
+
async function previewSession(sessionId, sessionType) {
|
|
295
|
+
try {
|
|
296
|
+
if (sessionType === 'cli_history') {
|
|
297
|
+
// Use CLI history preview modal
|
|
298
|
+
if (typeof showExecutionDetail === 'function') {
|
|
299
|
+
await showExecutionDetail(sessionId);
|
|
300
|
+
} else {
|
|
301
|
+
console.error('showExecutionDetail is not available. Make sure cli-history.js is loaded.');
|
|
302
|
+
showNotification(t('coreMemory.previewError'), 'error');
|
|
303
|
+
}
|
|
304
|
+
} else if (sessionType === 'core_memory') {
|
|
305
|
+
// Use memory preview modal
|
|
306
|
+
await viewMemoryContent(sessionId);
|
|
307
|
+
} else if (sessionType === 'workflow') {
|
|
308
|
+
// Navigate to workflow view for now
|
|
309
|
+
window.location.hash = `#workflow/${sessionId}`;
|
|
310
|
+
} else {
|
|
311
|
+
showNotification(t('coreMemory.unknownSessionType'), 'warning');
|
|
312
|
+
}
|
|
313
|
+
} catch (error) {
|
|
314
|
+
console.error('Failed to preview session:', error);
|
|
315
|
+
showNotification(t('coreMemory.previewError'), 'error');
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
/**
|
|
320
|
+
* Render cluster relations
|
|
321
|
+
*/
|
|
322
|
+
function renderRelations(relations) {
|
|
323
|
+
return `
|
|
324
|
+
<div class="relations-list">
|
|
325
|
+
${relations.map(rel => `
|
|
326
|
+
<div class="relation-item">
|
|
327
|
+
<i data-lucide="arrow-right"></i>
|
|
328
|
+
<span class="relation-type">${rel.relation_type}</span>
|
|
329
|
+
<a href="#" onclick="selectCluster('${rel.target_cluster_id}'); return false;">
|
|
330
|
+
${rel.target_cluster_id}
|
|
331
|
+
</a>
|
|
332
|
+
</div>
|
|
333
|
+
`).join('')}
|
|
334
|
+
</div>
|
|
335
|
+
`;
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
/**
|
|
339
|
+
* Trigger auto-clustering
|
|
340
|
+
*/
|
|
341
|
+
async function triggerAutoClustering(scope = 'recent') {
|
|
342
|
+
try {
|
|
343
|
+
showNotification(t('coreMemory.clusteringInProgress'), 'info');
|
|
344
|
+
|
|
345
|
+
const response = await fetch(`/api/core-memory/clusters/auto?path=${encodeURIComponent(projectPath)}`, {
|
|
346
|
+
method: 'POST',
|
|
347
|
+
headers: { 'Content-Type': 'application/json' },
|
|
348
|
+
body: JSON.stringify({ scope })
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
352
|
+
|
|
353
|
+
const result = await response.json();
|
|
354
|
+
showNotification(
|
|
355
|
+
t('coreMemory.clusteringComplete', {
|
|
356
|
+
created: result.clustersCreated,
|
|
357
|
+
sessions: result.sessionsClustered
|
|
358
|
+
}),
|
|
359
|
+
'success'
|
|
360
|
+
);
|
|
361
|
+
|
|
362
|
+
// Reload clusters
|
|
363
|
+
await loadClusters();
|
|
364
|
+
} catch (error) {
|
|
365
|
+
console.error('Auto-clustering failed:', error);
|
|
366
|
+
showNotification(t('coreMemory.clusteringError'), 'error');
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
/**
|
|
371
|
+
* Create new cluster
|
|
372
|
+
*/
|
|
373
|
+
async function createCluster() {
|
|
374
|
+
const name = prompt(t('coreMemory.enterClusterName'));
|
|
375
|
+
if (!name) return;
|
|
376
|
+
|
|
377
|
+
try {
|
|
378
|
+
const response = await fetch(`/api/core-memory/clusters?path=${encodeURIComponent(projectPath)}`, {
|
|
379
|
+
method: 'POST',
|
|
380
|
+
headers: { 'Content-Type': 'application/json' },
|
|
381
|
+
body: JSON.stringify({ name })
|
|
382
|
+
});
|
|
383
|
+
|
|
384
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
385
|
+
|
|
386
|
+
showNotification(t('coreMemory.clusterCreated'), 'success');
|
|
387
|
+
await loadClusters();
|
|
388
|
+
} catch (error) {
|
|
389
|
+
console.error('Failed to create cluster:', error);
|
|
390
|
+
showNotification(t('coreMemory.clusterCreateError'), 'error');
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
/**
|
|
395
|
+
* Edit cluster (placeholder)
|
|
396
|
+
*/
|
|
397
|
+
function editCluster(clusterId) {
|
|
398
|
+
const cluster = selectedCluster;
|
|
399
|
+
if (!cluster) return;
|
|
400
|
+
|
|
401
|
+
const newName = prompt(t('coreMemory.enterClusterName'), cluster.name);
|
|
402
|
+
if (!newName || newName === cluster.name) return;
|
|
403
|
+
|
|
404
|
+
updateCluster(clusterId, { name: newName });
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
/**
|
|
408
|
+
* Update cluster
|
|
409
|
+
*/
|
|
410
|
+
async function updateCluster(clusterId, updates) {
|
|
411
|
+
try {
|
|
412
|
+
const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`, {
|
|
413
|
+
method: 'PATCH',
|
|
414
|
+
headers: { 'Content-Type': 'application/json' },
|
|
415
|
+
body: JSON.stringify(updates)
|
|
416
|
+
});
|
|
417
|
+
|
|
418
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
419
|
+
|
|
420
|
+
showNotification(t('coreMemory.clusterUpdated'), 'success');
|
|
421
|
+
await loadClusters();
|
|
422
|
+
if (selectedCluster?.id === clusterId) {
|
|
423
|
+
await selectCluster(clusterId);
|
|
424
|
+
}
|
|
425
|
+
} catch (error) {
|
|
426
|
+
console.error('Failed to update cluster:', error);
|
|
427
|
+
showNotification(t('coreMemory.clusterUpdateError'), 'error');
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
/**
|
|
432
|
+
* Delete cluster
|
|
433
|
+
*/
|
|
434
|
+
async function deleteCluster(clusterId) {
|
|
435
|
+
if (!confirm(t('coreMemory.confirmDeleteCluster'))) return;
|
|
436
|
+
|
|
437
|
+
try {
|
|
438
|
+
const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`, {
|
|
439
|
+
method: 'DELETE'
|
|
440
|
+
});
|
|
441
|
+
|
|
442
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
443
|
+
|
|
444
|
+
showNotification(t('coreMemory.clusterDeleted'), 'success');
|
|
445
|
+
selectedCluster = null;
|
|
446
|
+
await loadClusters();
|
|
447
|
+
|
|
448
|
+
// Clear detail view
|
|
449
|
+
const container = document.getElementById('clusterDetailContainer');
|
|
450
|
+
if (container) container.innerHTML = '';
|
|
451
|
+
} catch (error) {
|
|
452
|
+
console.error('Failed to delete cluster:', error);
|
|
453
|
+
showNotification(t('coreMemory.clusterDeleteError'), 'error');
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
|
|
457
|
+
/**
|
|
458
|
+
* Remove member from cluster
|
|
459
|
+
*/
|
|
460
|
+
async function removeMember(clusterId, sessionId) {
|
|
461
|
+
try {
|
|
462
|
+
const response = await fetch(
|
|
463
|
+
`/api/core-memory/clusters/${clusterId}/members/${sessionId}?path=${encodeURIComponent(projectPath)}`,
|
|
464
|
+
{ method: 'DELETE' }
|
|
465
|
+
);
|
|
466
|
+
|
|
467
|
+
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
468
|
+
|
|
469
|
+
showNotification(t('coreMemory.memberRemoved'), 'success');
|
|
470
|
+
await selectCluster(clusterId); // Refresh detail
|
|
471
|
+
} catch (error) {
|
|
472
|
+
console.error('Failed to remove member:', error);
|
|
473
|
+
showNotification(t('coreMemory.memberRemoveError'), 'error');
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
/**
|
|
478
|
+
* View memory content in modal
|
|
479
|
+
* Requires: viewMemoryDetail from core-memory.js
|
|
480
|
+
*/
|
|
481
|
+
async function viewMemoryContent(memoryId) {
|
|
482
|
+
try {
|
|
483
|
+
// Check if required functions exist (from core-memory.js)
|
|
484
|
+
if (typeof viewMemoryDetail === 'function') {
|
|
485
|
+
await viewMemoryDetail(memoryId);
|
|
486
|
+
} else {
|
|
487
|
+
console.error('viewMemoryDetail is not available. Make sure core-memory.js is loaded.');
|
|
488
|
+
showNotification(t('coreMemory.fetchError'), 'error');
|
|
489
|
+
}
|
|
490
|
+
} catch (error) {
|
|
491
|
+
console.error('Failed to load memory content:', error);
|
|
492
|
+
showNotification(t('coreMemory.fetchError'), 'error');
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
|
|
496
|
+
/**
|
|
497
|
+
* Format date for display
|
|
498
|
+
*/
|
|
499
|
+
function formatDate(dateStr) {
|
|
500
|
+
if (!dateStr) return '';
|
|
501
|
+
const date = new Date(dateStr);
|
|
502
|
+
return date.toLocaleDateString();
|
|
503
|
+
}
|