claude-mpm 4.16.0__py3-none-any.whl → 4.25.10__py3-none-any.whl

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.

Potentially problematic release.


This version of claude-mpm might be problematic. Click here for more details.

Files changed (531) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_ENGINEER.md +286 -0
  3. claude_mpm/agents/BASE_PM.md +272 -23
  4. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  5. claude_mpm/agents/PM_INSTRUCTIONS.md +1821 -32
  6. claude_mpm/agents/WORKFLOW.md +75 -2
  7. claude_mpm/agents/agent_loader.py +4 -4
  8. claude_mpm/agents/base_agent.json +6 -3
  9. claude_mpm/agents/frontmatter_validator.py +1 -1
  10. claude_mpm/agents/templates/api_qa.json +5 -2
  11. claude_mpm/agents/templates/circuit_breakers.md +108 -2
  12. claude_mpm/agents/templates/documentation.json +33 -6
  13. claude_mpm/agents/templates/engineer.json +5 -1
  14. claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
  15. claude_mpm/agents/templates/php-engineer.json +10 -4
  16. claude_mpm/agents/templates/pm_red_flags.md +89 -19
  17. claude_mpm/agents/templates/project_organizer.json +7 -3
  18. claude_mpm/agents/templates/python_engineer.json +8 -3
  19. claude_mpm/agents/templates/qa.json +2 -1
  20. claude_mpm/agents/templates/react_engineer.json +1 -0
  21. claude_mpm/agents/templates/research.json +82 -12
  22. claude_mpm/agents/templates/rust_engineer.json +12 -7
  23. claude_mpm/agents/templates/security.json +4 -4
  24. claude_mpm/agents/templates/svelte-engineer.json +225 -0
  25. claude_mpm/agents/templates/tauri_engineer.json +274 -0
  26. claude_mpm/agents/templates/ticketing.json +10 -6
  27. claude_mpm/agents/templates/version_control.json +4 -2
  28. claude_mpm/agents/templates/web_qa.json +2 -1
  29. claude_mpm/cli/README.md +253 -0
  30. claude_mpm/cli/__init__.py +11 -1
  31. claude_mpm/cli/commands/__init__.py +2 -0
  32. claude_mpm/cli/commands/aggregate.py +1 -1
  33. claude_mpm/cli/commands/analyze.py +3 -3
  34. claude_mpm/cli/commands/cleanup.py +1 -1
  35. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  36. claude_mpm/cli/commands/debug.py +12 -12
  37. claude_mpm/cli/commands/hook_errors.py +277 -0
  38. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  39. claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
  40. claude_mpm/cli/commands/mpm_init/README.md +365 -0
  41. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  42. claude_mpm/cli/commands/mpm_init/core.py +573 -0
  43. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  44. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  45. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  46. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  47. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  48. claude_mpm/cli/commands/mpm_init_handler.py +67 -1
  49. claude_mpm/cli/commands/run.py +124 -128
  50. claude_mpm/cli/commands/skills.py +922 -0
  51. claude_mpm/cli/executor.py +58 -0
  52. claude_mpm/cli/interactive/agent_wizard.py +5 -5
  53. claude_mpm/cli/parsers/base_parser.py +35 -0
  54. claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
  55. claude_mpm/cli/parsers/skills_parser.py +275 -0
  56. claude_mpm/cli/startup.py +168 -8
  57. claude_mpm/cli/startup_display.py +480 -0
  58. claude_mpm/cli/utils.py +1 -1
  59. claude_mpm/cli_module/commands.py +1 -1
  60. claude_mpm/cli_module/refactoring_guide.md +253 -0
  61. claude_mpm/commands/mpm-auto-configure.md +52 -0
  62. claude_mpm/commands/mpm-help.md +6 -0
  63. claude_mpm/commands/mpm-init.md +130 -8
  64. claude_mpm/commands/mpm-resume.md +372 -0
  65. claude_mpm/commands/mpm-tickets.md +56 -7
  66. claude_mpm/commands/mpm-version.md +113 -0
  67. claude_mpm/commands/mpm.md +2 -0
  68. claude_mpm/config/agent_capabilities.yaml +658 -0
  69. claude_mpm/config/agent_config.py +2 -2
  70. claude_mpm/config/async_logging_config.yaml +145 -0
  71. claude_mpm/constants.py +24 -0
  72. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
  73. claude_mpm/core/api_validator.py +1 -1
  74. claude_mpm/core/claude_runner.py +14 -1
  75. claude_mpm/core/config.py +50 -0
  76. claude_mpm/core/constants.py +1 -1
  77. claude_mpm/core/factories.py +1 -1
  78. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  79. claude_mpm/core/hook_error_memory.py +381 -0
  80. claude_mpm/core/hook_manager.py +41 -2
  81. claude_mpm/core/interactive_session.py +48 -3
  82. claude_mpm/core/interfaces.py +56 -1
  83. claude_mpm/core/logger.py +3 -1
  84. claude_mpm/core/oneshot_session.py +39 -0
  85. claude_mpm/core/optimized_agent_loader.py +3 -3
  86. claude_mpm/d2/.gitignore +22 -0
  87. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
  88. claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
  89. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
  90. claude_mpm/d2/QUICKSTART.md +186 -0
  91. claude_mpm/d2/README.md +232 -0
  92. claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
  93. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
  94. claude_mpm/d2/TESTING.md +288 -0
  95. claude_mpm/d2/index.html +118 -0
  96. claude_mpm/d2/package.json +19 -0
  97. claude_mpm/d2/src/App.svelte +110 -0
  98. claude_mpm/d2/src/components/Header.svelte +153 -0
  99. claude_mpm/d2/src/components/MainContent.svelte +74 -0
  100. claude_mpm/d2/src/components/Sidebar.svelte +85 -0
  101. claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
  102. claude_mpm/d2/src/lib/socketio.js +144 -0
  103. claude_mpm/d2/src/main.js +7 -0
  104. claude_mpm/d2/src/stores/events.js +114 -0
  105. claude_mpm/d2/src/stores/socket.js +108 -0
  106. claude_mpm/d2/src/stores/theme.js +65 -0
  107. claude_mpm/d2/svelte.config.js +12 -0
  108. claude_mpm/d2/vite.config.js +15 -0
  109. claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
  110. claude_mpm/dashboard/BUILD_NUMBER +1 -0
  111. claude_mpm/dashboard/README.md +121 -0
  112. claude_mpm/dashboard/VERSION +1 -0
  113. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
  114. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
  115. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
  116. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
  117. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
  118. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
  119. claude_mpm/dashboard/react/entries/events.tsx +165 -0
  120. claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
  121. claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
  122. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
  123. claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
  124. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
  125. claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
  126. claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
  127. claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
  128. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
  129. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
  130. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
  131. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
  132. claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
  133. claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
  134. claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
  135. claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
  136. claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
  137. claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
  138. claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
  139. claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
  140. claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
  141. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
  142. claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
  143. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
  144. claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
  145. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
  146. claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
  147. claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
  148. claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
  149. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
  150. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
  151. claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
  152. claude_mpm/dashboard/static/built/connection-manager.js +76 -76
  153. claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
  154. claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
  155. claude_mpm/dashboard/static/built/react/events.js.map +1 -0
  156. claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
  157. claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
  158. claude_mpm/dashboard/static/built/shared/logger.js +16 -16
  159. claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
  160. claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
  161. claude_mpm/dashboard/static/css/activity.css +69 -69
  162. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  163. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  164. claude_mpm/dashboard/static/index.html +22 -22
  165. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
  166. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  167. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  168. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  169. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  170. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  171. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  172. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  173. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  174. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  175. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  176. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  177. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  178. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  179. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  180. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  181. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  182. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  183. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  184. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  185. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  186. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  187. claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
  188. claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
  189. claude_mpm/dashboard/static/js/shared/logger.js +16 -16
  190. claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
  191. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  192. claude_mpm/dashboard/static/navigation-test-results.md +118 -0
  193. claude_mpm/dashboard/static/production/main.html +21 -21
  194. claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
  195. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
  196. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
  197. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
  198. claude_mpm/dashboard/templates/code_simple.html +23 -23
  199. claude_mpm/dashboard/templates/index.html +18 -18
  200. claude_mpm/hooks/README.md +143 -0
  201. claude_mpm/hooks/__init__.py +8 -0
  202. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  203. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  204. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  205. claude_mpm/hooks/claude_hooks/response_tracking.py +35 -1
  206. claude_mpm/hooks/session_resume_hook.py +121 -0
  207. claude_mpm/hooks/templates/README.md +180 -0
  208. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  209. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  210. claude_mpm/hooks/templates/settings.json.example +147 -0
  211. claude_mpm/models/resume_log.py +340 -0
  212. claude_mpm/schemas/agent_schema.json +596 -0
  213. claude_mpm/schemas/frontmatter_schema.json +165 -0
  214. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  215. claude_mpm/scripts/start_activity_logging.py +3 -1
  216. claude_mpm/services/agents/auto_config_manager.py +1 -1
  217. claude_mpm/services/agents/deployment/agent_configuration_manager.py +1 -1
  218. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  219. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  220. claude_mpm/services/agents/deployment/agent_record_service.py +1 -1
  221. claude_mpm/services/agents/deployment/agent_validator.py +17 -1
  222. claude_mpm/services/agents/deployment/async_agent_deployment.py +1 -1
  223. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  224. claude_mpm/services/agents/deployment/local_template_deployment.py +1 -1
  225. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  226. claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
  227. claude_mpm/services/agents/local_template_manager.py +4 -2
  228. claude_mpm/services/agents/recommender.py +47 -0
  229. claude_mpm/services/cli/resume_service.py +617 -0
  230. claude_mpm/services/cli/session_manager.py +87 -0
  231. claude_mpm/services/cli/session_pause_manager.py +504 -0
  232. claude_mpm/services/cli/session_resume_helper.py +372 -0
  233. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  234. claude_mpm/services/core/base.py +26 -11
  235. claude_mpm/services/core/interfaces.py +56 -1
  236. claude_mpm/services/core/models/agent_config.py +3 -0
  237. claude_mpm/services/core/models/process.py +4 -0
  238. claude_mpm/services/core/path_resolver.py +1 -1
  239. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  240. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  241. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  242. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  243. claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
  244. claude_mpm/services/diagnostics/models.py +21 -0
  245. claude_mpm/services/event_bus/README.md +244 -0
  246. claude_mpm/services/event_bus/direct_relay.py +3 -3
  247. claude_mpm/services/event_bus/event_bus.py +36 -3
  248. claude_mpm/services/event_bus/relay.py +23 -7
  249. claude_mpm/services/events/README.md +303 -0
  250. claude_mpm/services/events/consumers/logging.py +1 -2
  251. claude_mpm/services/framework_claude_md_generator/README.md +119 -0
  252. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  253. claude_mpm/services/infrastructure/resume_log_generator.py +439 -0
  254. claude_mpm/services/local_ops/__init__.py +2 -0
  255. claude_mpm/services/local_ops/process_manager.py +1 -1
  256. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  257. claude_mpm/services/mcp_config_manager.py +7 -131
  258. claude_mpm/services/mcp_gateway/README.md +185 -0
  259. claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
  260. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  261. claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
  262. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  263. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  264. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
  265. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  266. claude_mpm/services/memory/failure_tracker.py +19 -4
  267. claude_mpm/services/memory/optimizer.py +1 -1
  268. claude_mpm/services/model/model_router.py +8 -9
  269. claude_mpm/services/monitor/daemon.py +1 -1
  270. claude_mpm/services/monitor/server.py +2 -2
  271. claude_mpm/services/native_agent_converter.py +356 -0
  272. claude_mpm/services/port_manager.py +1 -1
  273. claude_mpm/services/project/documentation_manager.py +2 -1
  274. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  275. claude_mpm/services/runner_configuration_service.py +1 -0
  276. claude_mpm/services/self_upgrade_service.py +165 -7
  277. claude_mpm/services/session_manager.py +205 -1
  278. claude_mpm/services/skills_config.py +547 -0
  279. claude_mpm/services/skills_deployer.py +955 -0
  280. claude_mpm/services/socketio/handlers/connection.py +1 -1
  281. claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
  282. claude_mpm/services/socketio/handlers/git.py +2 -2
  283. claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
  284. claude_mpm/services/static/.gitkeep +2 -0
  285. claude_mpm/services/system_instructions_service.py +1 -3
  286. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  287. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  288. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  289. claude_mpm/services/unified/deployment_strategies/local.py +1 -1
  290. claude_mpm/services/version_control/VERSION +1 -0
  291. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  292. claude_mpm/services/version_service.py +104 -1
  293. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  294. claude_mpm/skills/__init__.py +21 -0
  295. claude_mpm/skills/agent_skills_injector.py +324 -0
  296. claude_mpm/skills/bundled/.gitkeep +2 -0
  297. claude_mpm/skills/bundled/LICENSE_ATTRIBUTIONS.md +79 -0
  298. claude_mpm/skills/bundled/api-documentation.md +393 -0
  299. claude_mpm/skills/bundled/async-testing.md +571 -0
  300. claude_mpm/skills/bundled/code-review.md +143 -0
  301. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
  302. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
  303. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  304. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  305. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  306. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  307. claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
  308. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
  309. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
  310. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  311. claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
  312. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
  313. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  314. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  315. claude_mpm/skills/bundled/database-migration.md +199 -0
  316. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
  317. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
  318. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  319. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  320. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  321. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  322. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
  323. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
  324. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
  325. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
  326. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
  327. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
  328. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
  329. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
  330. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
  331. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
  332. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
  333. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
  334. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  335. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  336. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
  337. claude_mpm/skills/bundled/docker-containerization.md +194 -0
  338. claude_mpm/skills/bundled/express-local-dev.md +1429 -0
  339. claude_mpm/skills/bundled/fastapi-local-dev.md +1199 -0
  340. claude_mpm/skills/bundled/git-workflow.md +414 -0
  341. claude_mpm/skills/bundled/imagemagick.md +204 -0
  342. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
  343. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
  344. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
  345. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
  346. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
  347. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
  348. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
  349. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
  350. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
  351. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  352. claude_mpm/skills/bundled/json-data-handling.md +223 -0
  353. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
  354. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
  355. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
  356. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
  357. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  358. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
  359. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
  360. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
  361. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
  362. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
  363. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
  364. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
  365. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
  366. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  367. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
  368. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
  369. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
  370. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
  371. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  372. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +157 -0
  373. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +425 -0
  374. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
  375. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
  376. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
  377. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
  378. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  379. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  380. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  381. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  382. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  383. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +303 -0
  384. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +113 -0
  385. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +72 -0
  386. claude_mpm/skills/bundled/nextjs-local-dev.md +807 -0
  387. claude_mpm/skills/bundled/pdf.md +141 -0
  388. claude_mpm/skills/bundled/performance-profiling.md +573 -0
  389. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  390. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  391. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  392. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  393. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  394. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  395. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  396. claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
  397. claude_mpm/skills/bundled/refactoring-patterns.md +180 -0
  398. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  399. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  400. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  401. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  402. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  403. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  404. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  405. claude_mpm/skills/bundled/security-scanning.md +327 -0
  406. claude_mpm/skills/bundled/systematic-debugging.md +473 -0
  407. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
  408. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
  409. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
  410. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
  411. claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
  412. claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
  413. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
  414. claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
  415. claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
  416. claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
  417. claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
  418. claude_mpm/skills/bundled/test-driven-development.md +378 -0
  419. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
  420. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
  421. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  422. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
  423. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
  424. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
  425. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
  426. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
  427. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
  428. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
  429. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
  430. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
  431. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
  432. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
  433. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
  434. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  435. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  436. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  437. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  438. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
  439. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
  440. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  441. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +35 -0
  442. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +44 -0
  443. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +34 -0
  444. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  445. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  446. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +129 -0
  447. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  448. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  449. claude_mpm/skills/bundled/vite-local-dev.md +1061 -0
  450. claude_mpm/skills/bundled/web-performance-optimization.md +2305 -0
  451. claude_mpm/skills/bundled/xlsx.md +157 -0
  452. claude_mpm/skills/registry.py +97 -9
  453. claude_mpm/skills/skills_registry.py +347 -0
  454. claude_mpm/skills/skills_service.py +739 -0
  455. claude_mpm/templates/questions/EXAMPLES.md +501 -0
  456. claude_mpm/templates/questions/__init__.py +43 -0
  457. claude_mpm/templates/questions/base.py +193 -0
  458. claude_mpm/templates/questions/pr_strategy.py +314 -0
  459. claude_mpm/templates/questions/project_init.py +388 -0
  460. claude_mpm/templates/questions/ticket_mgmt.py +397 -0
  461. claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
  462. claude_mpm/tools/__main__.py +8 -8
  463. claude_mpm/tools/code_tree_analyzer/README.md +64 -0
  464. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  465. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  466. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  467. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  468. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  469. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  470. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  471. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  472. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  473. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  474. claude_mpm/utils/agent_dependency_loader.py +5 -5
  475. claude_mpm/utils/dependency_cache.py +3 -1
  476. claude_mpm/utils/gitignore.py +241 -0
  477. claude_mpm/utils/log_cleanup.py +3 -3
  478. claude_mpm/utils/robust_installer.py +3 -5
  479. claude_mpm/utils/structured_questions.py +619 -0
  480. claude_mpm-4.25.10.dist-info/METADATA +789 -0
  481. {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +485 -240
  482. claude_mpm/agents/INSTRUCTIONS_OLD_DEPRECATED.md +0 -602
  483. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  484. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  485. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  486. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  487. claude_mpm/cli/commands/mpm_init.py +0 -2008
  488. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  489. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  490. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  491. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  492. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  493. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  494. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  495. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  496. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  497. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  498. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  499. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  500. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  501. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  502. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  503. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  504. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  505. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  506. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  507. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  508. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  509. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  510. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  511. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  512. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  513. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  514. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  515. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  516. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  517. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  518. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  519. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  520. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  521. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  522. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  523. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  524. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  525. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  526. claude_mpm/tools/code_tree_analyzer.py +0 -1825
  527. claude_mpm-4.16.0.dist-info/METADATA +0 -453
  528. {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
  529. {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
  530. {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
  531. {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * File Change Viewer Component
3
- *
3
+ *
4
4
  * Displays files edited by Claude in a tree structure grouped by working directory.
5
5
  * Integrates with FileChangeTracker for tracking changes and DiffViewer for showing diffs.
6
6
  * Supports session-based filtering and displays change indicators.
@@ -22,16 +22,16 @@ class FileChangeViewer {
22
22
  */
23
23
  initialize() {
24
24
  if (this.initialized) return;
25
-
25
+
26
26
  // Create dependent components
27
27
  this.fileTracker = new FileChangeTracker();
28
28
  this.diffViewer = new DiffViewer();
29
-
29
+
30
30
  this.createModal();
31
31
  this.setupEventHandlers();
32
32
  this.subscribeToEvents();
33
33
  this.injectStyles();
34
-
34
+
35
35
  this.initialized = true;
36
36
  console.log('File change viewer initialized');
37
37
  }
@@ -96,7 +96,7 @@ class FileChangeViewer {
96
96
  injectStyles() {
97
97
  const styleId = 'file-change-viewer-styles';
98
98
  if (document.getElementById(styleId)) return;
99
-
99
+
100
100
  const styles = `
101
101
  <style id="${styleId}">
102
102
  .file-change-modal {
@@ -111,13 +111,13 @@ class FileChangeViewer {
111
111
  padding: 20px;
112
112
  overflow: auto;
113
113
  }
114
-
114
+
115
115
  .file-change-modal.show {
116
116
  display: flex;
117
117
  align-items: center;
118
118
  justify-content: center;
119
119
  }
120
-
120
+
121
121
  .file-change-content {
122
122
  background: white;
123
123
  border-radius: 8px;
@@ -128,7 +128,7 @@ class FileChangeViewer {
128
128
  flex-direction: column;
129
129
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
130
130
  }
131
-
131
+
132
132
  .file-change-header {
133
133
  display: flex;
134
134
  justify-content: space-between;
@@ -138,7 +138,7 @@ class FileChangeViewer {
138
138
  background: #f8fafc;
139
139
  border-radius: 8px 8px 0 0;
140
140
  }
141
-
141
+
142
142
  .file-change-title {
143
143
  display: flex;
144
144
  align-items: center;
@@ -147,28 +147,28 @@ class FileChangeViewer {
147
147
  font-weight: 600;
148
148
  color: #2d3748;
149
149
  }
150
-
150
+
151
151
  .title-icon {
152
152
  font-size: 20px;
153
153
  }
154
-
154
+
155
155
  .file-change-controls {
156
156
  display: flex;
157
157
  align-items: center;
158
158
  gap: 20px;
159
159
  }
160
-
160
+
161
161
  .session-filter {
162
162
  display: flex;
163
163
  align-items: center;
164
164
  gap: 8px;
165
165
  }
166
-
166
+
167
167
  .session-filter label {
168
168
  font-size: 13px;
169
169
  color: #4a5568;
170
170
  }
171
-
171
+
172
172
  .session-select {
173
173
  padding: 4px 8px;
174
174
  border: 1px solid #cbd5e0;
@@ -176,12 +176,12 @@ class FileChangeViewer {
176
176
  font-size: 13px;
177
177
  background: white;
178
178
  }
179
-
179
+
180
180
  .file-stats {
181
181
  display: flex;
182
182
  gap: 16px;
183
183
  }
184
-
184
+
185
185
  .stat-item {
186
186
  display: flex;
187
187
  align-items: center;
@@ -189,16 +189,16 @@ class FileChangeViewer {
189
189
  font-size: 13px;
190
190
  color: #4a5568;
191
191
  }
192
-
192
+
193
193
  .stat-icon {
194
194
  font-size: 14px;
195
195
  }
196
-
196
+
197
197
  .stat-value {
198
198
  font-weight: 600;
199
199
  color: #2d3748;
200
200
  }
201
-
201
+
202
202
  .file-change-close {
203
203
  width: 32px;
204
204
  height: 32px;
@@ -213,25 +213,25 @@ class FileChangeViewer {
213
213
  border-radius: 4px;
214
214
  transition: all 0.2s;
215
215
  }
216
-
216
+
217
217
  .file-change-close:hover {
218
218
  background: #e2e8f0;
219
219
  color: #2d3748;
220
220
  }
221
-
221
+
222
222
  .file-change-body {
223
223
  flex: 1;
224
224
  overflow: auto;
225
225
  padding: 20px;
226
226
  background: #fafbfc;
227
227
  }
228
-
228
+
229
229
  .file-tree-container {
230
230
  display: flex;
231
231
  flex-direction: column;
232
232
  gap: 16px;
233
233
  }
234
-
234
+
235
235
  /* Directory groups */
236
236
  .directory-group {
237
237
  background: white;
@@ -239,7 +239,7 @@ class FileChangeViewer {
239
239
  border-radius: 6px;
240
240
  overflow: hidden;
241
241
  }
242
-
242
+
243
243
  .directory-header {
244
244
  display: flex;
245
245
  align-items: center;
@@ -250,53 +250,53 @@ class FileChangeViewer {
250
250
  cursor: pointer;
251
251
  transition: background 0.2s;
252
252
  }
253
-
253
+
254
254
  .directory-header:hover {
255
255
  background: #f1f5f9;
256
256
  }
257
-
257
+
258
258
  .directory-info {
259
259
  display: flex;
260
260
  align-items: center;
261
261
  gap: 8px;
262
262
  }
263
-
263
+
264
264
  .directory-icon {
265
265
  font-size: 16px;
266
266
  color: #4299e1;
267
267
  }
268
-
268
+
269
269
  .directory-path {
270
270
  font-family: 'SF Mono', Monaco, monospace;
271
271
  font-size: 13px;
272
272
  font-weight: 600;
273
273
  color: #2d3748;
274
274
  }
275
-
275
+
276
276
  .directory-stats {
277
277
  display: flex;
278
278
  gap: 12px;
279
279
  font-size: 12px;
280
280
  color: #718096;
281
281
  }
282
-
282
+
283
283
  .directory-files {
284
284
  padding: 12px;
285
285
  display: none;
286
286
  }
287
-
287
+
288
288
  .directory-group.expanded .directory-files {
289
289
  display: block;
290
290
  }
291
-
291
+
292
292
  .directory-group.expanded .directory-icon::before {
293
293
  content: '📂';
294
294
  }
295
-
295
+
296
296
  .directory-group:not(.expanded) .directory-icon::before {
297
297
  content: '📁';
298
298
  }
299
-
299
+
300
300
  /* File items */
301
301
  .file-item {
302
302
  display: flex;
@@ -310,85 +310,85 @@ class FileChangeViewer {
310
310
  cursor: pointer;
311
311
  transition: all 0.2s;
312
312
  }
313
-
313
+
314
314
  .file-item:hover {
315
315
  background: white;
316
316
  border-color: #4299e1;
317
317
  transform: translateX(4px);
318
318
  }
319
-
319
+
320
320
  .file-item:last-child {
321
321
  margin-bottom: 0;
322
322
  }
323
-
323
+
324
324
  .file-info {
325
325
  display: flex;
326
326
  align-items: center;
327
327
  gap: 8px;
328
328
  flex: 1;
329
329
  }
330
-
330
+
331
331
  .file-icon {
332
332
  font-size: 14px;
333
333
  }
334
-
334
+
335
335
  .file-name {
336
336
  font-family: 'SF Mono', Monaco, monospace;
337
337
  font-size: 13px;
338
338
  color: #2d3748;
339
339
  font-weight: 500;
340
340
  }
341
-
341
+
342
342
  .file-badges {
343
343
  display: flex;
344
344
  gap: 6px;
345
345
  }
346
-
346
+
347
347
  .file-badge {
348
348
  padding: 2px 6px;
349
349
  font-size: 11px;
350
350
  border-radius: 3px;
351
351
  font-weight: 600;
352
352
  }
353
-
353
+
354
354
  .badge-edit {
355
355
  background: #fef3c7;
356
356
  color: #92400e;
357
357
  }
358
-
358
+
359
359
  .badge-write {
360
360
  background: #dbeafe;
361
361
  color: #1e40af;
362
362
  }
363
-
363
+
364
364
  .badge-read {
365
365
  background: #e0e7ff;
366
366
  color: #3730a3;
367
367
  }
368
-
368
+
369
369
  .file-timestamp {
370
370
  font-size: 11px;
371
371
  color: #a0aec0;
372
372
  }
373
-
373
+
374
374
  /* Empty state */
375
375
  .empty-state {
376
376
  text-align: center;
377
377
  padding: 40px;
378
378
  color: #718096;
379
379
  }
380
-
380
+
381
381
  .empty-state-icon {
382
382
  font-size: 48px;
383
383
  margin-bottom: 16px;
384
384
  }
385
-
385
+
386
386
  .empty-state-text {
387
387
  font-size: 14px;
388
388
  }
389
389
  </style>
390
390
  `;
391
-
391
+
392
392
  document.head.insertAdjacentHTML('beforeend', styles);
393
393
  }
394
394
 
@@ -400,21 +400,21 @@ class FileChangeViewer {
400
400
  document.getElementById('file-change-close').addEventListener('click', () => {
401
401
  this.hide();
402
402
  });
403
-
403
+
404
404
  // Close on backdrop click
405
405
  this.modal.addEventListener('click', (e) => {
406
406
  if (e.target === this.modal) {
407
407
  this.hide();
408
408
  }
409
409
  });
410
-
410
+
411
411
  // Close on ESC key
412
412
  document.addEventListener('keydown', (e) => {
413
413
  if (e.key === 'Escape' && this.modal.classList.contains('show')) {
414
414
  this.hide();
415
415
  }
416
416
  });
417
-
417
+
418
418
  // Session filter
419
419
  document.getElementById('file-session-filter').addEventListener('change', (e) => {
420
420
  this.currentSessionId = e.target.value;
@@ -430,7 +430,7 @@ class FileChangeViewer {
430
430
  if (window.socket) {
431
431
  // We might want to listen for file operation events
432
432
  }
433
-
433
+
434
434
  // Listen for event viewer updates
435
435
  if (window.eventViewer) {
436
436
  // Hook into event updates to refresh our view
@@ -452,22 +452,22 @@ class FileChangeViewer {
452
452
  if (!this.initialized) {
453
453
  this.initialize();
454
454
  }
455
-
455
+
456
456
  this.modal.classList.add('show');
457
-
457
+
458
458
  // Update with events
459
459
  if (events) {
460
460
  this.fileTracker.updateEvents(events);
461
461
  } else if (window.eventViewer) {
462
462
  this.fileTracker.updateEvents(window.eventViewer.events);
463
463
  }
464
-
464
+
465
465
  // Update session filter
466
466
  this.updateSessionFilter();
467
-
467
+
468
468
  // Display file tree
469
469
  this.updateFileTree();
470
-
470
+
471
471
  // Update statistics
472
472
  this.updateStatistics();
473
473
  }
@@ -497,10 +497,10 @@ class FileChangeViewer {
497
497
  updateSessionFilter() {
498
498
  const select = document.getElementById('file-session-filter');
499
499
  const sessions = Array.from(this.fileTracker.sessionData.keys());
500
-
500
+
501
501
  // Clear existing options except "All Sessions"
502
502
  select.innerHTML = '<option value="">All Sessions</option>';
503
-
503
+
504
504
  // Add session options
505
505
  sessions.forEach(sessionId => {
506
506
  const option = document.createElement('option');
@@ -508,7 +508,7 @@ class FileChangeViewer {
508
508
  option.textContent = `Session: ${sessionId.substring(0, 8)}...`;
509
509
  select.appendChild(option);
510
510
  });
511
-
511
+
512
512
  // Restore selection
513
513
  if (this.currentSessionId) {
514
514
  select.value = this.currentSessionId;
@@ -520,7 +520,7 @@ class FileChangeViewer {
520
520
  */
521
521
  updateFileTree() {
522
522
  const tree = this.fileTracker.getFileTree(this.currentSessionId);
523
-
523
+
524
524
  if (Object.keys(tree).length === 0) {
525
525
  this.treeContainer.innerHTML = `
526
526
  <div class="empty-state">
@@ -530,15 +530,15 @@ class FileChangeViewer {
530
530
  `;
531
531
  return;
532
532
  }
533
-
533
+
534
534
  // Build tree HTML
535
535
  const treeHtml = Object.entries(tree)
536
536
  .sort((a, b) => b[1].totalOperations - a[1].totalOperations)
537
537
  .map(([dirPath, dirData]) => this.renderDirectoryGroup(dirPath, dirData))
538
538
  .join('');
539
-
539
+
540
540
  this.treeContainer.innerHTML = treeHtml;
541
-
541
+
542
542
  // Add event handlers
543
543
  this.attachTreeHandlers();
544
544
  }
@@ -551,7 +551,7 @@ class FileChangeViewer {
551
551
  */
552
552
  renderDirectoryGroup(dirPath, dirData) {
553
553
  const displayPath = dirPath === 'unknown' ? 'Unknown Directory' : dirPath;
554
-
554
+
555
555
  return `
556
556
  <div class="directory-group" data-path="${dirPath}">
557
557
  <div class="directory-header">
@@ -588,9 +588,9 @@ class FileChangeViewer {
588
588
  if (fileData.totalReads > 0 && fileData.totalEdits === 0 && fileData.totalWrites === 0) {
589
589
  badges.push(`<span class="file-badge badge-read">👁️ ${fileData.totalReads}</span>`);
590
590
  }
591
-
591
+
592
592
  const timestamp = new Date(fileData.lastModified).toLocaleTimeString();
593
-
593
+
594
594
  return `
595
595
  <div class="file-item" data-path="${fileData.path}">
596
596
  <div class="file-info">
@@ -614,7 +614,7 @@ class FileChangeViewer {
614
614
  group.classList.toggle('expanded');
615
615
  });
616
616
  });
617
-
617
+
618
618
  // File items - show diff or content
619
619
  document.querySelectorAll('.file-item').forEach(item => {
620
620
  item.addEventListener('click', (e) => {
@@ -623,7 +623,7 @@ class FileChangeViewer {
623
623
  this.showFileDetails(filePath);
624
624
  });
625
625
  });
626
-
626
+
627
627
  // Auto-expand first directory
628
628
  const firstDir = document.querySelector('.directory-group');
629
629
  if (firstDir) {
@@ -638,7 +638,7 @@ class FileChangeViewer {
638
638
  showFileDetails(filePath) {
639
639
  const fileData = this.fileTracker.getFileDetails(filePath);
640
640
  if (!fileData) return;
641
-
641
+
642
642
  // If file has edits or writes, show diff
643
643
  if (fileData.totalEdits > 0 || fileData.totalWrites > 0) {
644
644
  const diffData = this.fileTracker.getFileDiff(filePath);
@@ -657,12 +657,12 @@ class FileChangeViewer {
657
657
  */
658
658
  updateStatistics() {
659
659
  const stats = this.fileTracker.getStatistics();
660
-
660
+
661
661
  document.getElementById('total-files').textContent = stats.totalFiles;
662
- document.getElementById('total-edits').textContent =
662
+ document.getElementById('total-edits').textContent =
663
663
  Array.from(this.fileTracker.fileChanges.values())
664
664
  .reduce((sum, f) => sum + f.totalEdits, 0);
665
- document.getElementById('total-writes').textContent =
665
+ document.getElementById('total-writes').textContent =
666
666
  Array.from(this.fileTracker.fileChanges.values())
667
667
  .reduce((sum, f) => sum + f.totalWrites, 0);
668
668
  }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-tool-tracker.js","sources":["../../js/components/file-tool-tracker.js"],"sourcesContent":["/**\n * File and Tool Tracker Module\n *\n * Tracks file operations and tool calls by pairing pre/post events and maintaining\n * organized collections for the files and tools tabs. Provides analysis of\n * tool execution patterns and file operation history.\n *\n * WHY: Extracted from main dashboard to isolate complex event pairing logic\n * that groups related events into meaningful operations. This provides better\n * maintainability for the intricate logic of matching tool events with their results.\n *\n * DESIGN DECISION: Uses intelligent correlation strategy for tool calls that:\n * - Separates pre_tool and post_tool events first\n * - Correlates based on temporal proximity, parameter similarity, and context\n * - Handles timing differences between pre/post events (tools can run for minutes)\n * - Prevents duplicate tool entries by ensuring each tool call appears once\n * - Supports both paired and orphaned events for comprehensive tracking\n */\nclass FileToolTracker {\n constructor(agentInference, workingDirectoryManager) {\n this.agentInference = agentInference;\n this.workingDirectoryManager = workingDirectoryManager;\n\n // File tracking for files tab\n this.fileOperations = new Map(); // Map of file paths to operations\n\n // Tool call tracking for tools tab\n this.toolCalls = new Map(); // Map of tool call keys to paired pre/post events\n\n console.log('File-tool tracker initialized');\n }\n\n /**\n * Update file operations from events\n * @param {Array} events - Events to process\n */\n updateFileOperations(events) {\n // Clear existing data\n this.fileOperations.clear();\n\n console.log('updateFileOperations - processing', events.length, 'events');\n\n // Group events by session and timestamp to match pre/post pairs\n const eventPairs = new Map(); // Key: session_id + timestamp + tool_name\n let fileOperationCount = 0;\n\n // First pass: collect all tool events and group them\n events.forEach((event, index) => {\n const isFileOp = this.isFileOperation(event);\n if (isFileOp) fileOperationCount++;\n\n if (index < 5) { // Debug first 5 events with more detail\n console.log(`Event ${index}:`, {\n type: event.type,\n subtype: event.subtype,\n tool_name: event.tool_name,\n tool_parameters: event.tool_parameters,\n isFileOp: isFileOp\n });\n }\n\n if (isFileOp) {\n const toolName = event.tool_name || (event.data && event.data.tool_name);\n const sessionId = event.session_id || (event.data && event.data.session_id) || 'unknown';\n const eventKey = `${sessionId}_${toolName}_${Math.floor(new Date(event.timestamp).getTime() / 1000)}`; // Group by second\n\n if (!eventPairs.has(eventKey)) {\n eventPairs.set(eventKey, {\n pre_event: null,\n post_event: null,\n tool_name: toolName,\n session_id: sessionId\n });\n }\n\n const pair = eventPairs.get(eventKey);\n if (event.subtype === 'pre_tool' || (event.type === 'hook' && event.subtype && !event.subtype.includes('post'))) {\n pair.pre_event = event;\n } else if (event.subtype === 'post_tool' || (event.subtype && event.subtype.includes('post'))) {\n pair.post_event = event;\n } else {\n // For events without clear pre/post distinction, treat as both\n pair.pre_event = event;\n pair.post_event = event;\n }\n }\n });\n\n console.log('updateFileOperations - found', fileOperationCount, 'file operations in', eventPairs.size, 'event pairs');\n\n // Second pass: extract file paths and operations from paired events\n eventPairs.forEach((pair, key) => {\n const filePath = this.extractFilePathFromPair(pair);\n\n if (filePath) {\n console.log('File operation detected for:', filePath, 'from pair:', key);\n\n if (!this.fileOperations.has(filePath)) {\n this.fileOperations.set(filePath, {\n path: filePath,\n operations: [],\n lastOperation: null\n });\n }\n\n const fileData = this.fileOperations.get(filePath);\n const operation = this.getFileOperationFromPair(pair);\n const timestamp = pair.post_event?.timestamp || pair.pre_event?.timestamp;\n\n const agentInfo = this.extractAgentFromPair(pair);\n const workingDirectory = this.workingDirectoryManager.extractWorkingDirectoryFromPair(pair);\n\n fileData.operations.push({\n operation: operation,\n timestamp: timestamp,\n agent: agentInfo.name,\n confidence: agentInfo.confidence,\n sessionId: pair.session_id,\n details: this.getFileOperationDetailsFromPair(pair),\n workingDirectory: workingDirectory\n });\n fileData.lastOperation = timestamp;\n } else {\n console.log('No file path found for pair:', key, pair);\n }\n });\n\n console.log('updateFileOperations - final result:', this.fileOperations.size, 'file operations');\n if (this.fileOperations.size > 0) {\n console.log('File operations map:', Array.from(this.fileOperations.entries()));\n }\n }\n\n /**\n * Update tool calls from events - pairs pre/post tool events into complete tool calls\n * @param {Array} events - Events to process\n */\n updateToolCalls(events) {\n // Clear existing data\n this.toolCalls.clear();\n\n console.log('updateToolCalls - processing', events.length, 'events');\n\n // Improved correlation strategy: collect events first, then correlate intelligently\n const preToolEvents = [];\n const postToolEvents = [];\n let toolOperationCount = 0;\n\n // First pass: separate pre_tool and post_tool events\n events.forEach((event, index) => {\n const isToolOp = this.isToolOperation(event);\n if (isToolOp) toolOperationCount++;\n\n if (index < 5) { // Debug first 5 events with more detail\n console.log(`Tool Event ${index}:`, {\n type: event.type,\n subtype: event.subtype,\n tool_name: event.tool_name,\n tool_parameters: event.tool_parameters,\n isToolOp: isToolOp\n });\n }\n\n if (isToolOp) {\n if (event.subtype === 'pre_tool' || (event.type === 'hook' && event.subtype && !event.subtype.includes('post'))) {\n preToolEvents.push(event);\n } else if (event.subtype === 'post_tool' || (event.subtype && event.subtype.includes('post'))) {\n postToolEvents.push(event);\n } else {\n // For events without clear pre/post distinction, treat as standalone\n preToolEvents.push(event);\n postToolEvents.push(event);\n }\n }\n });\n\n console.log('updateToolCalls - found', toolOperationCount, 'tool operations:', preToolEvents.length, 'pre_tool,', postToolEvents.length, 'post_tool');\n\n // Second pass: correlate pre_tool events with post_tool events\n const toolCallPairs = new Map();\n const usedPostEvents = new Set();\n\n preToolEvents.forEach((preEvent, preIndex) => {\n const toolName = preEvent.tool_name || (preEvent.data && preEvent.data.tool_name);\n const sessionId = preEvent.session_id || (preEvent.data && preEvent.data.session_id) || 'unknown';\n const preTimestamp = new Date(preEvent.timestamp).getTime();\n\n // Create a base pair for this pre_tool event\n const pairKey = `${sessionId}_${toolName}_${preIndex}_${preTimestamp}`;\n const pair = {\n pre_event: preEvent,\n post_event: null,\n tool_name: toolName,\n session_id: sessionId,\n operation_type: preEvent.operation_type || 'tool_execution',\n timestamp: preEvent.timestamp,\n duration_ms: null,\n success: null,\n exit_code: null,\n result_summary: null,\n agent_type: null,\n agent_confidence: null\n };\n\n // Get agent info from pre_event\n const agentInfo = this.extractAgentFromEvent(preEvent);\n pair.agent_type = agentInfo.name;\n pair.agent_confidence = agentInfo.confidence;\n\n // Try to find matching post_tool event\n let bestMatchIndex = -1;\n let bestMatchScore = -1;\n const maxTimeDiffMs = 300000; // 5 minutes max time difference\n\n postToolEvents.forEach((postEvent, postIndex) => {\n // Skip already used post events\n if (usedPostEvents.has(postIndex)) return;\n\n // Must match tool name and session\n const postToolName = postEvent.tool_name || (postEvent.data && postEvent.data.tool_name);\n const postSessionId = postEvent.session_id || (postEvent.data && postEvent.data.session_id) || 'unknown';\n if (postToolName !== toolName || postSessionId !== sessionId) return;\n\n const postTimestamp = new Date(postEvent.timestamp).getTime();\n const timeDiff = Math.abs(postTimestamp - preTimestamp);\n\n // Post event should generally come after pre event (or very close)\n const isTemporallyValid = postTimestamp >= preTimestamp - 1000; // Allow 1s clock skew\n\n // Calculate correlation score (higher is better)\n let score = 0;\n if (isTemporallyValid && timeDiff <= maxTimeDiffMs) {\n score = 1000 - (timeDiff / 1000); // Prefer closer timestamps\n\n // Boost score for parameter similarity (if available)\n if (this.compareToolParameters(preEvent, postEvent)) {\n score += 500;\n }\n\n // Boost score for same working directory\n if (preEvent.working_directory && postEvent.working_directory &&\n preEvent.working_directory === postEvent.working_directory) {\n score += 100;\n }\n }\n\n if (score > bestMatchScore) {\n bestMatchScore = score;\n bestMatchIndex = postIndex;\n }\n });\n\n // If we found a good match, pair them\n if (bestMatchIndex >= 0 && bestMatchScore > 0) {\n const postEvent = postToolEvents[bestMatchIndex];\n pair.post_event = postEvent;\n pair.duration_ms = postEvent.duration_ms;\n pair.success = postEvent.success;\n pair.exit_code = postEvent.exit_code;\n pair.result_summary = postEvent.result_summary;\n\n usedPostEvents.add(bestMatchIndex);\n console.log(`Paired pre_tool ${toolName} at ${preEvent.timestamp} with post_tool at ${postEvent.timestamp} (score: ${bestMatchScore})`);\n } else {\n console.log(`No matching post_tool found for ${toolName} at ${preEvent.timestamp} (still running or orphaned)`);\n }\n\n toolCallPairs.set(pairKey, pair);\n });\n\n // Third pass: handle any orphaned post_tool events (shouldn't happen but be safe)\n postToolEvents.forEach((postEvent, postIndex) => {\n if (usedPostEvents.has(postIndex)) return;\n\n const toolName = postEvent.tool_name || (postEvent.data && postEvent.data.tool_name);\n console.log('Orphaned post_tool event found:', toolName, 'at', postEvent.timestamp);\n\n const sessionId = postEvent.session_id || (postEvent.data && postEvent.data.session_id) || 'unknown';\n const postTimestamp = new Date(postEvent.timestamp).getTime();\n\n const pairKey = `orphaned_${sessionId}_${toolName}_${postIndex}_${postTimestamp}`;\n const pair = {\n pre_event: null,\n post_event: postEvent,\n tool_name: toolName,\n session_id: sessionId,\n operation_type: 'tool_execution',\n timestamp: postEvent.timestamp,\n duration_ms: postEvent.duration_ms,\n success: postEvent.success,\n exit_code: postEvent.exit_code,\n result_summary: postEvent.result_summary,\n agent_type: null,\n agent_confidence: null\n };\n\n const agentInfo = this.extractAgentFromEvent(postEvent);\n pair.agent_type = agentInfo.name;\n pair.agent_confidence = agentInfo.confidence;\n\n toolCallPairs.set(pairKey, pair);\n });\n\n // Store the correlated tool calls\n this.toolCalls = toolCallPairs;\n\n console.log('updateToolCalls - final result:', this.toolCalls.size, 'tool calls');\n if (this.toolCalls.size > 0) {\n console.log('Tool calls map keys:', Array.from(this.toolCalls.keys()));\n }\n }\n\n /**\n * Check if event is a tool operation\n * @param {Object} event - Event to check\n * @returns {boolean} - True if tool operation\n */\n isToolOperation(event) {\n // Tool operations have tool_name - be more inclusive about event types\n // Check both top-level and data.tool_name for compatibility\n const hasToolName = event.tool_name || (event.data && event.data.tool_name);\n\n // Accept multiple event types that might contain tool operations\n const validEventTypes = ['hook', 'tool_use', 'tool', 'agent', 'response'];\n const isValidEventType = validEventTypes.includes(event.type) ||\n (event.type && event.type.includes('tool'));\n\n // Check for tool-related subtypes or any indication this is a tool operation\n const isToolSubtype = event.subtype === 'pre_tool' ||\n event.subtype === 'post_tool' ||\n (event.subtype && typeof event.subtype === 'string' && event.subtype.includes('tool')) ||\n event.type === 'tool_use' ||\n event.type === 'tool';\n\n // If it has a tool_name and either a valid event type or tool subtype, it's a tool operation\n return hasToolName && (isValidEventType || isToolSubtype);\n }\n\n /**\n * Check if event is a file operation\n * @param {Object} event - Event to check\n * @returns {boolean} - True if file operation\n */\n isFileOperation(event) {\n // File operations are events with file-related tools - be more inclusive\n // Check both top-level and data for tool_name\n let toolName = event.tool_name || (event.data && event.data.tool_name) || '';\n\n // If no tool name, not a file operation\n if (!toolName) {\n return false;\n }\n\n toolName = toolName.toLowerCase();\n\n // Check case-insensitively since tool names can come in different cases\n const fileTools = ['read', 'write', 'edit', 'grep', 'multiedit', 'glob', 'ls', 'bash', 'notebookedit'];\n\n // Get tool parameters from either location\n const toolParams = event.tool_parameters || (event.data && event.data.tool_parameters);\n\n // Also check if Bash commands involve file operations\n if (toolName === 'bash' && toolParams) {\n const command = toolParams.command || '';\n // Check for common file operations in bash commands\n if (command.match(/\\b(cat|less|more|head|tail|touch|mv|cp|rm|mkdir|ls|find)\\b/)) {\n return true;\n }\n }\n\n // If it's a file tool, it's a file operation regardless of event type\n return fileTools.includes(toolName);\n }\n\n /**\n * Extract file path from event\n * @param {Object} event - Event to extract from\n * @returns {string|null} - File path or null\n */\n extractFilePath(event) {\n // Debug logging for file path extraction\n const fileTools = ['Read', 'Write', 'Edit', 'MultiEdit', 'NotebookEdit'];\n const toolName = event.tool_name || (event.data && event.data.tool_name);\n \n if (fileTools.includes(toolName)) {\n console.log('Extracting file path from event:', {\n tool_name: toolName,\n has_tool_parameters_top: !!event.tool_parameters,\n has_tool_parameters_data: !!(event.data && event.data.tool_parameters),\n tool_parameters: event.tool_parameters,\n data_tool_parameters: event.data?.tool_parameters\n });\n }\n \n // Try various locations where file path might be stored\n // Check top-level tool_parameters first (after transformation)\n if (event.tool_parameters?.file_path) return event.tool_parameters.file_path;\n if (event.tool_parameters?.path) return event.tool_parameters.path;\n if (event.tool_parameters?.notebook_path) return event.tool_parameters.notebook_path;\n \n // Check in data object as fallback\n if (event.data?.tool_parameters?.file_path) return event.data.tool_parameters.file_path;\n if (event.data?.tool_parameters?.path) return event.data.tool_parameters.path;\n if (event.data?.tool_parameters?.notebook_path) return event.data.tool_parameters.notebook_path;\n if (event.file_path) return event.file_path;\n if (event.path) return event.path;\n\n // For Glob tool, use the pattern as a pseudo-path\n if (event.tool_name?.toLowerCase() === 'glob' && event.tool_parameters?.pattern) {\n return `[glob] ${event.tool_parameters.pattern}`;\n }\n\n // For Bash commands, try to extract file paths from the command\n if (event.tool_name?.toLowerCase() === 'bash' && event.tool_parameters?.command) {\n const command = event.tool_parameters.command;\n \n // Enhanced regex to handle commands with flags\n // Match command followed by optional flags (starting with -) and then the file path\n // Patterns to handle:\n // 1. tail -50 /path/to/file\n // 2. head -n 100 /path/to/file \n // 3. cat /path/to/file\n // 4. grep -r \"pattern\" /path/to/file\n const fileMatch = command.match(/(?:cat|less|more|head|tail|touch|mv|cp|rm|mkdir|ls|find|echo.*>|sed|awk|grep)(?:\\s+-[a-zA-Z0-9]+)*(?:\\s+[0-9]+)*\\s+([^\\s;|&]+)/);\n \n // If first match might be a flag, try a more specific pattern\n if (fileMatch && fileMatch[1]) {\n const possiblePath = fileMatch[1];\n // Check if it's actually a flag (starts with -)\n if (possiblePath.startsWith('-')) {\n // Try alternative pattern that skips all flags\n const altMatch = command.match(/(?:cat|less|more|head|tail|touch|mv|cp|rm|mkdir|ls|find|echo.*>|sed|awk|grep)(?:\\s+-[^\\s]+)*\\s+([^-][^\\s;|&]*)/);\n if (altMatch && altMatch[1]) {\n return altMatch[1];\n }\n }\n return possiblePath;\n }\n }\n\n return null;\n }\n\n /**\n * Extract file path from event pair\n * @param {Object} pair - Event pair object\n * @returns {string|null} - File path or null\n */\n extractFilePathFromPair(pair) {\n // Try pre_event first, then post_event\n let filePath = null;\n\n if (pair.pre_event) {\n filePath = this.extractFilePath(pair.pre_event);\n }\n\n if (!filePath && pair.post_event) {\n filePath = this.extractFilePath(pair.post_event);\n }\n\n return filePath;\n }\n\n /**\n * Get file operation type from event\n * @param {Object} event - Event to analyze\n * @returns {string} - Operation type\n */\n getFileOperation(event) {\n if (!event.tool_name) return 'unknown';\n\n const toolName = event.tool_name.toLowerCase();\n switch (toolName) {\n case 'read': return 'read';\n case 'write': return 'write';\n case 'edit': return 'edit';\n case 'multiedit': return 'edit';\n case 'notebookedit': return 'edit';\n case 'grep': return 'search';\n case 'glob': return 'search';\n case 'ls': return 'list';\n case 'bash':\n // Check bash command for file operation type\n const command = event.tool_parameters?.command || '';\n if (command.match(/\\b(cat|less|more|head|tail)\\b/)) return 'read';\n if (command.match(/\\b(touch|echo.*>|tee)\\b/)) return 'write';\n if (command.match(/\\b(sed|awk)\\b/)) return 'edit';\n if (command.match(/\\b(grep|find)\\b/)) return 'search';\n if (command.match(/\\b(ls|dir)\\b/)) return 'list';\n if (command.match(/\\b(mv|cp)\\b/)) return 'copy/move';\n if (command.match(/\\b(rm|rmdir)\\b/)) return 'delete';\n if (command.match(/\\b(mkdir)\\b/)) return 'create';\n return 'bash';\n default: return toolName;\n }\n }\n\n /**\n * Get file operation from event pair\n * @param {Object} pair - Event pair object\n * @returns {string} - Operation type\n */\n getFileOperationFromPair(pair) {\n // Try pre_event first, then post_event\n if (pair.pre_event) {\n return this.getFileOperation(pair.pre_event);\n }\n\n if (pair.post_event) {\n return this.getFileOperation(pair.post_event);\n }\n\n return 'unknown';\n }\n\n /**\n * Extract agent information from event pair\n * @param {Object} pair - Event pair object\n * @returns {Object} - Agent info with name and confidence\n */\n extractAgentFromPair(pair) {\n // Try to get agent info from inference system first\n const event = pair.pre_event || pair.post_event;\n if (event && this.agentInference) {\n const inference = this.agentInference.getInferredAgentForEvent(event);\n if (inference) {\n return {\n name: inference.agentName || 'Unknown',\n confidence: inference.confidence || 'unknown'\n };\n }\n }\n\n // Fallback to direct event properties\n const agentName = event?.agent_type || event?.subagent_type ||\n pair.pre_event?.agent_type || pair.post_event?.agent_type || 'PM';\n\n return {\n name: agentName,\n confidence: 'direct'\n };\n }\n\n /**\n * Get detailed operation information from event pair\n * @param {Object} pair - Event pair object\n * @returns {Object} - Operation details\n */\n getFileOperationDetailsFromPair(pair) {\n const details = {};\n\n // Extract details from pre_event (parameters)\n if (pair.pre_event) {\n const params = pair.pre_event.tool_parameters || pair.pre_event.data?.tool_parameters || {};\n details.parameters = params;\n details.tool_input = pair.pre_event.tool_input;\n }\n\n // Extract details from post_event (results)\n if (pair.post_event) {\n details.result = pair.post_event.result;\n details.success = pair.post_event.success;\n details.error = pair.post_event.error;\n details.exit_code = pair.post_event.exit_code;\n details.duration_ms = pair.post_event.duration_ms;\n }\n\n return details;\n }\n\n /**\n * Get file operations map\n * @returns {Map} - File operations map\n */\n getFileOperations() {\n return this.fileOperations;\n }\n\n /**\n * Get tool calls map\n * @returns {Map} - Tool calls map\n */\n getToolCalls() {\n return this.toolCalls;\n }\n\n /**\n * Get tool calls as array for unique instance view\n * Each entry represents a unique tool call instance\n * @returns {Array} - Array of [key, toolCall] pairs\n */\n getToolCallsArray() {\n return Array.from(this.toolCalls.entries());\n }\n\n /**\n * Get file operations for a specific file\n * @param {string} filePath - File path\n * @returns {Object|null} - File operations data or null\n */\n getFileOperationsForFile(filePath) {\n return this.fileOperations.get(filePath) || null;\n }\n\n /**\n * Get tool call by key\n * @param {string} key - Tool call key\n * @returns {Object|null} - Tool call data or null\n */\n getToolCall(key) {\n return this.toolCalls.get(key) || null;\n }\n\n /**\n * Clear all tracking data\n */\n clear() {\n this.fileOperations.clear();\n this.toolCalls.clear();\n console.log('File-tool tracker cleared');\n }\n\n /**\n * Get statistics about tracked operations\n * @returns {Object} - Statistics\n */\n getStatistics() {\n return {\n fileOperations: this.fileOperations.size,\n toolCalls: this.toolCalls.size,\n uniqueFiles: this.fileOperations.size,\n totalFileOperations: Array.from(this.fileOperations.values())\n .reduce((sum, data) => sum + data.operations.length, 0)\n };\n }\n\n /**\n * Compare tool parameters between pre_tool and post_tool events\n * to determine if they're likely from the same tool call\n * @param {Object} preEvent - Pre-tool event\n * @param {Object} postEvent - Post-tool event\n * @returns {boolean} - True if parameters suggest same tool call\n */\n compareToolParameters(preEvent, postEvent) {\n // Extract parameters from both events\n const preParams = preEvent.tool_parameters || preEvent.data?.tool_parameters || {};\n const postParams = postEvent.tool_parameters || postEvent.data?.tool_parameters || {};\n\n // If no parameters in either event, can't compare meaningfully\n if (Object.keys(preParams).length === 0 && Object.keys(postParams).length === 0) {\n return false; // No boost for empty parameters\n }\n\n // Compare key parameters that are likely to be the same\n const importantParams = ['file_path', 'path', 'pattern', 'command', 'notebook_path'];\n let matchedParams = 0;\n let totalComparableParams = 0;\n\n importantParams.forEach(param => {\n const preValue = preParams[param];\n const postValue = postParams[param];\n\n if (preValue !== undefined || postValue !== undefined) {\n totalComparableParams++;\n if (preValue === postValue) {\n matchedParams++;\n }\n }\n });\n\n // If we found comparable parameters, check if most match\n if (totalComparableParams > 0) {\n return (matchedParams / totalComparableParams) >= 0.8; // 80% parameter match threshold\n }\n\n // If no important parameters to compare, check if the parameter structure is similar\n const preKeys = Object.keys(preParams).sort();\n const postKeys = Object.keys(postParams).sort();\n\n if (preKeys.length === 0 && postKeys.length === 0) {\n return false;\n }\n\n // Simple structural similarity check\n if (preKeys.length === postKeys.length) {\n const keyMatches = preKeys.filter(key => postKeys.includes(key)).length;\n return keyMatches >= Math.max(1, preKeys.length * 0.5); // At least 50% key overlap\n }\n\n return false;\n }\n\n /**\n * Extract agent information from event using inference system\n * @param {Object} event - Event to extract agent from\n * @returns {Object} - Agent info with name and confidence\n */\n extractAgentFromEvent(event) {\n if (this.agentInference) {\n const inference = this.agentInference.getInferredAgentForEvent(event);\n if (inference) {\n return {\n name: inference.agentName || 'Unknown',\n confidence: inference.confidence || 'unknown'\n };\n }\n }\n\n // Fallback to direct event properties\n const agentName = event.agent_type || event.subagent_type ||\n event.data?.agent_type || event.data?.subagent_type || 'PM';\n\n return {\n name: agentName,\n confidence: 'direct'\n };\n }\n}\n// ES6 Module export\nexport { FileToolTracker };\nexport default FileToolTracker;\n\n// Make FileToolTracker globally available for dist/dashboard.js\nwindow.FileToolTracker = FileToolTracker;\n"],"names":["window","FileToolTracker","constructor","agentInference","workingDirectoryManager","this","fileOperations","Map","toolCalls","console","log","updateFileOperations","events","clear","length","eventPairs","fileOperationCount","forEach","event","index","isFileOp","isFileOperation","type","subtype","tool_name","tool_parameters","toolName","data","sessionId","session_id","eventKey","Math","floor","Date","timestamp","getTime","has","set","pre_event","post_event","pair","get","includes","size","key","filePath","extractFilePathFromPair","path","operations","lastOperation","fileData","operation","getFileOperationFromPair","agentInfo","extractAgentFromPair","workingDirectory","extractWorkingDirectoryFromPair","push","agent","name","confidence","details","getFileOperationDetailsFromPair","Array","from","entries","updateToolCalls","preToolEvents","postToolEvents","toolOperationCount","isToolOp","isToolOperation","toolCallPairs","usedPostEvents","Set","preEvent","preIndex","preTimestamp","pairKey","operation_type","duration_ms","success","exit_code","result_summary","agent_type","agent_confidence","extractAgentFromEvent","bestMatchIndex","bestMatchScore","postEvent","postIndex","postToolName","postSessionId","postTimestamp","timeDiff","abs","score","compareToolParameters","working_directory","add","keys","hasToolName","isValidEventType","isToolSubtype","toLowerCase","toolParams","command","match","extractFilePath","has_tool_parameters_top","has_tool_parameters_data","data_tool_parameters","file_path","notebook_path","pattern","fileMatch","possiblePath","startsWith","altMatch","getFileOperation","inference","getInferredAgentForEvent","agentName","subagent_type","params","parameters","tool_input","result","error","getFileOperations","getToolCalls","getToolCallsArray","getFileOperationsForFile","getToolCall","getStatistics","uniqueFiles","totalFileOperations","values","reduce","sum","preParams","postParams","Object","matchedParams","totalComparableParams","param","preValue","postValue","preKeys","sort","postKeys","filter","max"],"mappings":"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"}