claude-mpm 4.25.10__py3-none-any.whl → 5.1.8__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 (507) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/PM_INSTRUCTIONS.md +1055 -2230
  4. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  5. claude_mpm/agents/WORKFLOW.md +4 -4
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent_loader.py +10 -35
  9. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +576 -66
  10. claude_mpm/agents/templates/context-management-examples.md +544 -0
  11. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  12. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  13. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  14. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  15. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  16. claude_mpm/cli/__init__.py +28 -3
  17. claude_mpm/cli/commands/__init__.py +2 -0
  18. claude_mpm/cli/commands/agent_source.py +774 -0
  19. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  20. claude_mpm/cli/commands/agents.py +959 -36
  21. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  22. claude_mpm/cli/commands/agents_discover.py +338 -0
  23. claude_mpm/cli/commands/auto_configure.py +537 -239
  24. claude_mpm/cli/commands/config.py +7 -4
  25. claude_mpm/cli/commands/configure.py +924 -45
  26. claude_mpm/cli/commands/configure_navigation.py +63 -46
  27. claude_mpm/cli/commands/doctor.py +10 -2
  28. claude_mpm/cli/commands/local_deploy.py +1 -4
  29. claude_mpm/cli/commands/postmortem.py +401 -0
  30. claude_mpm/cli/commands/run.py +1 -39
  31. claude_mpm/cli/commands/skill_source.py +694 -0
  32. claude_mpm/cli/commands/skills.py +322 -19
  33. claude_mpm/cli/executor.py +22 -3
  34. claude_mpm/cli/interactive/agent_wizard.py +1028 -43
  35. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  36. claude_mpm/cli/parsers/agents_parser.py +256 -4
  37. claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
  38. claude_mpm/cli/parsers/base_parser.py +25 -0
  39. claude_mpm/cli/parsers/config_parser.py +96 -43
  40. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  41. claude_mpm/cli/parsers/skills_parser.py +7 -0
  42. claude_mpm/cli/parsers/source_parser.py +138 -0
  43. claude_mpm/cli/startup.py +456 -103
  44. claude_mpm/cli/startup_display.py +4 -4
  45. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  46. claude_mpm/commands/mpm-agents-detect.md +9 -0
  47. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  48. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  49. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  50. claude_mpm/commands/mpm-doctor.md +9 -0
  51. claude_mpm/commands/mpm-help.md +14 -2
  52. claude_mpm/commands/mpm-init.md +9 -0
  53. claude_mpm/commands/mpm-monitor.md +9 -0
  54. claude_mpm/commands/mpm-postmortem.md +123 -0
  55. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  56. claude_mpm/commands/mpm-status.md +9 -0
  57. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  58. claude_mpm/commands/mpm-ticket-view.md +552 -0
  59. claude_mpm/commands/mpm-version.md +9 -0
  60. claude_mpm/commands/mpm.md +10 -0
  61. claude_mpm/config/agent_presets.py +488 -0
  62. claude_mpm/config/agent_sources.py +325 -0
  63. claude_mpm/config/skill_presets.py +392 -0
  64. claude_mpm/config/skill_sources.py +590 -0
  65. claude_mpm/constants.py +1 -0
  66. claude_mpm/core/claude_runner.py +5 -34
  67. claude_mpm/core/config.py +16 -0
  68. claude_mpm/core/framework/__init__.py +3 -16
  69. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  70. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  71. claude_mpm/core/interactive_session.py +83 -7
  72. claude_mpm/core/oneshot_session.py +71 -8
  73. claude_mpm/core/protocols/__init__.py +23 -0
  74. claude_mpm/core/protocols/runner_protocol.py +103 -0
  75. claude_mpm/core/protocols/session_protocol.py +131 -0
  76. claude_mpm/core/shared/singleton_manager.py +11 -4
  77. claude_mpm/core/system_context.py +38 -0
  78. claude_mpm/core/unified_config.py +22 -0
  79. claude_mpm/experimental/cli_enhancements.py +1 -5
  80. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  81. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  82. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  83. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  84. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  85. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  86. claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
  87. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  88. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  89. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  90. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  91. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  92. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  93. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  94. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  95. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  96. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  97. claude_mpm/models/git_repository.py +198 -0
  98. claude_mpm/services/agents/agent_builder.py +45 -9
  99. claude_mpm/services/agents/agent_preset_service.py +238 -0
  100. claude_mpm/services/agents/agent_selection_service.py +484 -0
  101. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  102. claude_mpm/services/agents/cache_git_manager.py +621 -0
  103. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  104. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  105. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  106. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  107. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  108. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  109. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  110. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  111. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  112. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  113. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  114. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  115. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  116. claude_mpm/services/agents/git_source_manager.py +629 -0
  117. claude_mpm/services/agents/loading/framework_agent_loader.py +1 -4
  118. claude_mpm/services/agents/local_template_manager.py +47 -9
  119. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  120. claude_mpm/services/agents/sources/__init__.py +13 -0
  121. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  122. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  123. claude_mpm/services/agents/startup_sync.py +239 -0
  124. claude_mpm/services/agents/toolchain_detector.py +474 -0
  125. claude_mpm/services/analysis/__init__.py +25 -0
  126. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  127. claude_mpm/services/analysis/postmortem_service.py +765 -0
  128. claude_mpm/services/command_deployment_service.py +200 -6
  129. claude_mpm/services/core/base.py +7 -2
  130. claude_mpm/services/core/interfaces/__init__.py +1 -3
  131. claude_mpm/services/core/interfaces/health.py +1 -4
  132. claude_mpm/services/core/models/__init__.py +2 -11
  133. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  134. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  135. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  136. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  137. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  138. claude_mpm/services/diagnostics/doctor_reporter.py +34 -6
  139. claude_mpm/services/git/__init__.py +21 -0
  140. claude_mpm/services/git/git_operations_service.py +494 -0
  141. claude_mpm/services/github/__init__.py +21 -0
  142. claude_mpm/services/github/github_cli_service.py +397 -0
  143. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  144. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  145. claude_mpm/services/instructions/__init__.py +9 -0
  146. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  147. claude_mpm/services/local_ops/__init__.py +3 -13
  148. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  149. claude_mpm/services/local_ops/health_manager.py +1 -4
  150. claude_mpm/services/mcp_config_manager.py +75 -145
  151. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  152. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  153. claude_mpm/services/mcp_service_verifier.py +6 -3
  154. claude_mpm/services/monitor/daemon.py +28 -8
  155. claude_mpm/services/monitor/daemon_manager.py +96 -19
  156. claude_mpm/services/pr/__init__.py +14 -0
  157. claude_mpm/services/pr/pr_template_service.py +329 -0
  158. claude_mpm/services/project/project_organizer.py +4 -0
  159. claude_mpm/services/runner_configuration_service.py +16 -3
  160. claude_mpm/services/session_management_service.py +16 -4
  161. claude_mpm/services/skills/__init__.py +18 -0
  162. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  163. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  164. claude_mpm/services/socketio/server/core.py +1 -4
  165. claude_mpm/services/socketio/server/main.py +1 -3
  166. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  167. claude_mpm/services/unified/unified_deployment.py +1 -5
  168. claude_mpm/services/visualization/__init__.py +1 -5
  169. claude_mpm/templates/questions/__init__.py +2 -7
  170. claude_mpm/templates/questions/pr_strategy.py +1 -4
  171. claude_mpm/templates/questions/project_init.py +1 -4
  172. claude_mpm/templates/questions/ticket_mgmt.py +1 -4
  173. claude_mpm/utils/agent_dependency_loader.py +77 -10
  174. claude_mpm/utils/agent_filters.py +288 -0
  175. claude_mpm/utils/gitignore.py +3 -0
  176. claude_mpm/utils/migration.py +372 -0
  177. claude_mpm/utils/progress.py +387 -0
  178. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/METADATA +356 -112
  179. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/RECORD +188 -439
  180. claude_mpm/agents/templates/agent-manager.json +0 -273
  181. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  182. claude_mpm/agents/templates/api_qa.json +0 -183
  183. claude_mpm/agents/templates/clerk-ops.json +0 -235
  184. claude_mpm/agents/templates/code_analyzer.json +0 -101
  185. claude_mpm/agents/templates/content-agent.json +0 -358
  186. claude_mpm/agents/templates/dart_engineer.json +0 -307
  187. claude_mpm/agents/templates/data_engineer.json +0 -225
  188. claude_mpm/agents/templates/documentation.json +0 -238
  189. claude_mpm/agents/templates/engineer.json +0 -210
  190. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  191. claude_mpm/agents/templates/golang_engineer.json +0 -270
  192. claude_mpm/agents/templates/imagemagick.json +0 -264
  193. claude_mpm/agents/templates/java_engineer.json +0 -346
  194. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  195. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  196. claude_mpm/agents/templates/memory_manager.json +0 -158
  197. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  198. claude_mpm/agents/templates/ops.json +0 -185
  199. claude_mpm/agents/templates/php-engineer.json +0 -287
  200. claude_mpm/agents/templates/product_owner.json +0 -338
  201. claude_mpm/agents/templates/project_organizer.json +0 -144
  202. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  203. claude_mpm/agents/templates/python_engineer.json +0 -387
  204. claude_mpm/agents/templates/qa.json +0 -243
  205. claude_mpm/agents/templates/react_engineer.json +0 -239
  206. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  207. claude_mpm/agents/templates/research.json +0 -258
  208. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  209. claude_mpm/agents/templates/rust_engineer.json +0 -275
  210. claude_mpm/agents/templates/security.json +0 -202
  211. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  212. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  213. claude_mpm/agents/templates/ticketing.json +0 -181
  214. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  215. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  216. claude_mpm/agents/templates/version_control.json +0 -159
  217. claude_mpm/agents/templates/web_qa.json +0 -400
  218. claude_mpm/agents/templates/web_ui.json +0 -189
  219. claude_mpm/cli/README.md +0 -253
  220. claude_mpm/cli/commands/mcp_install_commands.py.backup +0 -284
  221. claude_mpm/cli/commands/mpm_init/README.md +0 -365
  222. claude_mpm/cli_module/refactoring_guide.md +0 -253
  223. claude_mpm/commands/mpm-tickets.md +0 -151
  224. claude_mpm/config/agent_capabilities.yaml +0 -658
  225. claude_mpm/config/async_logging_config.yaml +0 -145
  226. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +0 -34
  227. claude_mpm/d2/.gitignore +0 -22
  228. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +0 -273
  229. claude_mpm/d2/FLASK_INTEGRATION.md +0 -156
  230. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +0 -452
  231. claude_mpm/d2/QUICKSTART.md +0 -186
  232. claude_mpm/d2/README.md +0 -232
  233. claude_mpm/d2/STORE_FIX_SUMMARY.md +0 -167
  234. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +0 -180
  235. claude_mpm/d2/TESTING.md +0 -288
  236. claude_mpm/d2/index.html +0 -118
  237. claude_mpm/d2/package.json +0 -19
  238. claude_mpm/d2/src/App.svelte +0 -110
  239. claude_mpm/d2/src/components/Header.svelte +0 -153
  240. claude_mpm/d2/src/components/MainContent.svelte +0 -74
  241. claude_mpm/d2/src/components/Sidebar.svelte +0 -85
  242. claude_mpm/d2/src/components/tabs/EventsTab.svelte +0 -326
  243. claude_mpm/d2/src/lib/socketio.js +0 -144
  244. claude_mpm/d2/src/main.js +0 -7
  245. claude_mpm/d2/src/stores/events.js +0 -114
  246. claude_mpm/d2/src/stores/socket.js +0 -108
  247. claude_mpm/d2/src/stores/theme.js +0 -65
  248. claude_mpm/d2/svelte.config.js +0 -12
  249. claude_mpm/d2/vite.config.js +0 -15
  250. claude_mpm/dashboard/.claude-mpm/memories/README.md +0 -36
  251. claude_mpm/dashboard/BUILD_NUMBER +0 -1
  252. claude_mpm/dashboard/README.md +0 -121
  253. claude_mpm/dashboard/VERSION +0 -1
  254. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  255. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +0 -273
  256. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +0 -75
  257. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  258. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +0 -141
  259. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  260. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +0 -36
  261. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  262. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +0 -89
  263. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +0 -215
  264. claude_mpm/dashboard/react/entries/events.tsx +0 -165
  265. claude_mpm/dashboard/react/hooks/useEvents.ts +0 -191
  266. claude_mpm/dashboard/react/hooks/useSocket.ts +0 -225
  267. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  268. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +0 -170
  269. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  270. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  271. claude_mpm/dashboard/static/built/components/activity-tree.js.map +0 -1
  272. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  273. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  274. claude_mpm/dashboard/static/built/components/agent-inference.js.map +0 -1
  275. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  276. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  277. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  278. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  279. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  280. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  281. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  282. claude_mpm/dashboard/static/built/components/code-tree.js.map +0 -1
  283. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  284. claude_mpm/dashboard/static/built/components/code-viewer.js.map +0 -1
  285. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  286. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  287. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  288. claude_mpm/dashboard/static/built/components/event-processor.js.map +0 -1
  289. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  290. claude_mpm/dashboard/static/built/components/event-viewer.js.map +0 -1
  291. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  292. claude_mpm/dashboard/static/built/components/export-manager.js.map +0 -1
  293. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  294. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  295. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  296. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +0 -1
  297. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  298. claude_mpm/dashboard/static/built/components/file-viewer.js.map +0 -1
  299. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  300. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +0 -1
  301. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  302. claude_mpm/dashboard/static/built/components/hud-manager.js.map +0 -1
  303. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  304. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +0 -1
  305. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  306. claude_mpm/dashboard/static/built/components/module-viewer.js.map +0 -1
  307. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  308. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  309. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  310. claude_mpm/dashboard/static/built/components/session-manager.js.map +0 -1
  311. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  312. claude_mpm/dashboard/static/built/components/socket-manager.js.map +0 -1
  313. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  314. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +0 -1
  315. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  316. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +0 -1
  317. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  318. claude_mpm/dashboard/static/built/components/working-directory.js.map +0 -1
  319. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  320. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  321. claude_mpm/dashboard/static/built/dashboard.js.map +0 -1
  322. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  323. claude_mpm/dashboard/static/built/react/events.js +0 -30
  324. claude_mpm/dashboard/static/built/react/events.js.map +0 -1
  325. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  326. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  327. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  328. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  329. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  330. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  331. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  332. claude_mpm/dashboard/static/built/socket-client.js.map +0 -1
  333. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  334. claude_mpm/dashboard/static/events.html +0 -607
  335. claude_mpm/dashboard/static/index.html +0 -635
  336. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +0 -170
  337. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  338. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  339. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  340. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  341. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  342. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  343. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  344. claude_mpm/dashboard/static/legacy/files.html +0 -747
  345. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  346. claude_mpm/dashboard/static/monitors.html +0 -431
  347. claude_mpm/dashboard/static/navigation-test-results.md +0 -118
  348. claude_mpm/dashboard/static/production/events.html +0 -659
  349. claude_mpm/dashboard/static/production/main.html +0 -698
  350. claude_mpm/dashboard/static/production/monitors.html +0 -483
  351. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  352. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  353. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  354. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  355. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +0 -36
  356. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +0 -39
  357. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +0 -38
  358. claude_mpm/hooks/README.md +0 -143
  359. claude_mpm/hooks/templates/README.md +0 -180
  360. claude_mpm/hooks/templates/settings.json.example +0 -147
  361. claude_mpm/schemas/agent_schema.json +0 -596
  362. claude_mpm/schemas/frontmatter_schema.json +0 -165
  363. claude_mpm/services/event_bus/README.md +0 -244
  364. claude_mpm/services/events/README.md +0 -303
  365. claude_mpm/services/framework_claude_md_generator/README.md +0 -119
  366. claude_mpm/services/mcp_gateway/README.md +0 -185
  367. claude_mpm/services/socketio/handlers/connection.py.backup +0 -217
  368. claude_mpm/services/socketio/handlers/hook.py.backup +0 -154
  369. claude_mpm/services/static/.gitkeep +0 -2
  370. claude_mpm/services/version_control/VERSION +0 -1
  371. claude_mpm/skills/bundled/.gitkeep +0 -2
  372. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  373. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  374. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  375. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  376. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  377. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  378. claude_mpm/skills/bundled/collaboration/git-worktrees.md +0 -317
  379. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  380. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  381. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  382. claude_mpm/skills/bundled/collaboration/stacked-prs.md +0 -251
  383. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  384. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  385. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  386. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  387. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +0 -63
  388. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  389. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  390. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  391. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  392. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  393. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  394. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  395. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  396. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  397. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  398. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  399. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  400. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  401. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  402. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  403. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  404. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  405. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  406. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  407. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +0 -611
  408. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +0 -596
  409. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +0 -260
  410. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +0 -315
  411. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +0 -436
  412. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +0 -433
  413. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +0 -452
  414. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +0 -404
  415. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +0 -420
  416. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +0 -202
  417. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  418. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +0 -54
  419. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +0 -322
  420. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  421. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +0 -202
  422. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  423. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  424. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  425. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  426. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  427. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +0 -202
  428. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  429. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  430. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  431. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  435. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +0 -22
  436. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +0 -2
  437. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +0 -202
  438. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  439. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  440. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  441. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  442. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  443. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  444. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  445. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  446. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  447. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  448. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  449. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  450. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  451. claude_mpm/skills/bundled/react/flexlayout-react.md +0 -742
  452. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  458. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  459. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +0 -495
  460. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +0 -599
  461. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +0 -535
  462. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +0 -613
  463. claude_mpm/skills/bundled/tauri/tauri-event-system.md +0 -648
  464. claude_mpm/skills/bundled/tauri/tauri-file-system.md +0 -673
  465. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +0 -767
  466. claude_mpm/skills/bundled/tauri/tauri-performance.md +0 -669
  467. claude_mpm/skills/bundled/tauri/tauri-state-management.md +0 -573
  468. claude_mpm/skills/bundled/tauri/tauri-testing.md +0 -384
  469. claude_mpm/skills/bundled/tauri/tauri-window-management.md +0 -628
  470. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  471. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +0 -158
  472. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  473. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  474. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  475. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  476. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  477. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  478. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  479. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +0 -458
  480. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +0 -411
  481. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +0 -317
  482. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +0 -270
  483. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +0 -436
  484. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  485. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  486. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  487. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  488. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  489. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +0 -202
  490. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  491. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  492. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  493. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  494. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  495. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  496. claude_mpm/templates/questions/EXAMPLES.md +0 -501
  497. claude_mpm/tools/README_SOCKETIO_DEBUG.md +0 -224
  498. claude_mpm/tools/code_tree_analyzer/README.md +0 -64
  499. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  500. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  501. /claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +0 -0
  502. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  503. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  504. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/WHEEL +0 -0
  505. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/entry_points.txt +0 -0
  506. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/licenses/LICENSE +0 -0
  507. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/top_level.txt +0 -0
@@ -1,742 +0,0 @@
1
- ---
2
- name: flexlayout-react
3
- description: FlexLayout for React - Advanced docking layout manager with drag-and-drop, tabs, splitters, and complex window management
4
- version: 1.0.0
5
- category: development
6
- author: Claude MPM Team
7
- license: MIT
8
- progressive_disclosure:
9
- entry_point:
10
- summary: "Professional docking layout system: drag-and-drop panels, tabs, splitters, persistence, complex multi-pane interfaces"
11
- when_to_use: "Building IDE-like interfaces, dashboard builders, multi-document editors, complex admin panels with draggable panes"
12
- quick_start: "1. Create model with Model.fromJson() 2. Wrap app in Layout component 3. Define factory function 4. Persist with model.toJson()"
13
- context_limit: 700
14
- tags:
15
- - react
16
- - layout
17
- - docking
18
- - drag-drop
19
- - ide
20
- - dashboard
21
- - flexlayout
22
- requires_tools: []
23
- ---
24
-
25
- # FlexLayout-React - Professional Docking Layouts
26
-
27
- ## Overview
28
-
29
- FlexLayout-React provides IDE-quality docking layouts with drag-and-drop, tabs, splitters, and complex window management. Perfect for dashboards, IDEs, admin panels, and any interface requiring flexible, user-customizable layouts.
30
-
31
- **Key Features**:
32
- - Drag-and-drop panel repositioning
33
- - Tabbed interfaces with close, maximize, minimize
34
- - Splitters for resizable panes
35
- - Border docking areas
36
- - Layout persistence (save/restore)
37
- - Programmatic layout control
38
- - TypeScript support
39
-
40
- **Installation**:
41
- ```bash
42
- npm install flexlayout-react
43
- ```
44
-
45
- ## Basic Setup
46
-
47
- ### 1. Define Layout Model
48
-
49
- ```typescript
50
- import { Model, IJsonModel } from 'flexlayout-react';
51
-
52
- const initialLayout: IJsonModel = {
53
- global: {
54
- tabEnableClose: true,
55
- tabEnableRename: false,
56
- },
57
- borders: [],
58
- layout: {
59
- type: 'row',
60
- weight: 100,
61
- children: [
62
- {
63
- type: 'tabset',
64
- weight: 50,
65
- children: [
66
- {
67
- type: 'tab',
68
- name: 'Explorer',
69
- component: 'explorer',
70
- }
71
- ]
72
- },
73
- {
74
- type: 'tabset',
75
- weight: 50,
76
- children: [
77
- {
78
- type: 'tab',
79
- name: 'Editor',
80
- component: 'editor',
81
- }
82
- ]
83
- }
84
- ]
85
- }
86
- };
87
-
88
- // Create model
89
- const model = Model.fromJson(initialLayout);
90
- ```
91
-
92
- ### 2. Create Layout Component
93
-
94
- ```typescript
95
- import React, { useRef } from 'react';
96
- import { Layout, Model, TabNode, IJsonTabNode } from 'flexlayout-react';
97
- import 'flexlayout-react/style/dark.css'; // or light.css
98
-
99
- interface ComponentRegistry {
100
- explorer: React.ComponentType;
101
- editor: React.ComponentType;
102
- terminal: React.ComponentType;
103
- }
104
-
105
- function App() {
106
- const modelRef = useRef(Model.fromJson(initialLayout));
107
-
108
- const factory = (node: TabNode) => {
109
- const component = node.getComponent();
110
-
111
- switch (component) {
112
- case 'explorer':
113
- return <ExplorerPanel />;
114
- case 'editor':
115
- return <EditorPanel />;
116
- case 'terminal':
117
- return <TerminalPanel />;
118
- default:
119
- return <div>Unknown component: {component}</div>;
120
- }
121
- };
122
-
123
- return (
124
- <div style={{ width: '100vw', height: '100vh' }}>
125
- <Layout
126
- model={modelRef.current}
127
- factory={factory}
128
- />
129
- </div>
130
- );
131
- }
132
- ```
133
-
134
- ### 3. Component Implementation
135
-
136
- ```typescript
137
- function ExplorerPanel() {
138
- return (
139
- <div className="panel-explorer">
140
- <h3>File Explorer</h3>
141
- <ul>
142
- <li>src/</li>
143
- <li>public/</li>
144
- <li>package.json</li>
145
- </ul>
146
- </div>
147
- );
148
- }
149
-
150
- function EditorPanel() {
151
- return (
152
- <div className="panel-editor">
153
- <textarea
154
- style={{ width: '100%', height: '100%' }}
155
- placeholder="Start typing..."
156
- />
157
- </div>
158
- );
159
- }
160
- ```
161
-
162
- ## Advanced Layout Configurations
163
-
164
- ### Complex Multi-Pane Layout
165
-
166
- ```typescript
167
- const complexLayout: IJsonModel = {
168
- global: {
169
- tabEnableClose: true,
170
- tabEnableRename: false,
171
- tabEnableDrag: true,
172
- tabEnableFloat: true,
173
- borderSize: 200,
174
- },
175
- borders: [
176
- {
177
- type: 'border',
178
- location: 'left',
179
- size: 250,
180
- children: [
181
- {
182
- type: 'tab',
183
- name: 'Explorer',
184
- component: 'explorer',
185
- }
186
- ]
187
- },
188
- {
189
- type: 'border',
190
- location: 'bottom',
191
- size: 200,
192
- children: [
193
- {
194
- type: 'tab',
195
- name: 'Terminal',
196
- component: 'terminal',
197
- },
198
- {
199
- type: 'tab',
200
- name: 'Output',
201
- component: 'output',
202
- }
203
- ]
204
- }
205
- ],
206
- layout: {
207
- type: 'row',
208
- weight: 100,
209
- children: [
210
- {
211
- type: 'tabset',
212
- weight: 70,
213
- children: [
214
- {
215
- type: 'tab',
216
- name: 'Editor 1',
217
- component: 'editor',
218
- },
219
- {
220
- type: 'tab',
221
- name: 'Editor 2',
222
- component: 'editor',
223
- }
224
- ]
225
- },
226
- {
227
- type: 'tabset',
228
- weight: 30,
229
- children: [
230
- {
231
- type: 'tab',
232
- name: 'Properties',
233
- component: 'properties',
234
- },
235
- {
236
- type: 'tab',
237
- name: 'Outline',
238
- component: 'outline',
239
- }
240
- ]
241
- }
242
- ]
243
- }
244
- };
245
- ```
246
-
247
- ### Nested Rows and Columns
248
-
249
- ```typescript
250
- const nestedLayout: IJsonModel = {
251
- global: {},
252
- borders: [],
253
- layout: {
254
- type: 'row',
255
- children: [
256
- {
257
- type: 'col',
258
- weight: 50,
259
- children: [
260
- {
261
- type: 'tabset',
262
- weight: 70,
263
- children: [
264
- { type: 'tab', name: 'Top Left', component: 'panel-a' }
265
- ]
266
- },
267
- {
268
- type: 'tabset',
269
- weight: 30,
270
- children: [
271
- { type: 'tab', name: 'Bottom Left', component: 'panel-b' }
272
- ]
273
- }
274
- ]
275
- },
276
- {
277
- type: 'col',
278
- weight: 50,
279
- children: [
280
- {
281
- type: 'tabset',
282
- weight: 30,
283
- children: [
284
- { type: 'tab', name: 'Top Right', component: 'panel-c' }
285
- ]
286
- },
287
- {
288
- type: 'tabset',
289
- weight: 70,
290
- children: [
291
- { type: 'tab', name: 'Bottom Right', component: 'panel-d' }
292
- ]
293
- }
294
- ]
295
- }
296
- ]
297
- }
298
- };
299
- ```
300
-
301
- ## Layout Persistence
302
-
303
- ### Save and Restore Layout
304
-
305
- ```typescript
306
- import { useState, useEffect } from 'react';
307
- import { Model, Actions } from 'flexlayout-react';
308
-
309
- function LayoutManager() {
310
- const [model, setModel] = useState(() => {
311
- // Load from localStorage
312
- const saved = localStorage.getItem('layout');
313
- return saved
314
- ? Model.fromJson(JSON.parse(saved))
315
- : Model.fromJson(defaultLayout);
316
- });
317
-
318
- // Save on model change
319
- const onModelChange = (newModel: Model) => {
320
- const json = newModel.toJson();
321
- localStorage.setItem('layout', JSON.stringify(json));
322
- };
323
-
324
- return (
325
- <Layout
326
- model={model}
327
- factory={factory}
328
- onModelChange={onModelChange}
329
- />
330
- );
331
- }
332
- ```
333
-
334
- ### Reset to Default Layout
335
-
336
- ```typescript
337
- function LayoutControls({ model }: { model: Model }) {
338
- const resetLayout = () => {
339
- const newModel = Model.fromJson(defaultLayout);
340
- // Need to replace model reference
341
- window.location.reload(); // Simple approach
342
- };
343
-
344
- const saveLayout = () => {
345
- const json = model.toJson();
346
- const blob = new Blob([JSON.stringify(json, null, 2)], {
347
- type: 'application/json'
348
- });
349
- const url = URL.createObjectURL(blob);
350
- const a = document.createElement('a');
351
- a.href = url;
352
- a.download = 'layout.json';
353
- a.click();
354
- };
355
-
356
- return (
357
- <div className="layout-controls">
358
- <button onClick={resetLayout}>Reset Layout</button>
359
- <button onClick={saveLayout}>Export Layout</button>
360
- </div>
361
- );
362
- }
363
- ```
364
-
365
- ## Dynamic Tab Management
366
-
367
- ### Adding Tabs Programmatically
368
-
369
- ```typescript
370
- import { Actions, DockLocation } from 'flexlayout-react';
371
-
372
- function addNewTab(model: Model, tabsetId: string) {
373
- model.doAction(Actions.addNode(
374
- {
375
- type: 'tab',
376
- name: `New Tab ${Date.now()}`,
377
- component: 'editor',
378
- },
379
- tabsetId,
380
- DockLocation.CENTER,
381
- -1
382
- ));
383
- }
384
-
385
- // Add to specific tabset
386
- const addToExplorer = () => {
387
- addNewTab(model, 'explorer-tabset-id');
388
- };
389
-
390
- // Add to active tabset
391
- const addToActive = () => {
392
- const activeTabset = model.getActiveTabset();
393
- if (activeTabset) {
394
- addNewTab(model, activeTabset.getId());
395
- }
396
- };
397
- ```
398
-
399
- ### Closing Tabs
400
-
401
- ```typescript
402
- function closeTab(model: Model, tabId: string) {
403
- model.doAction(Actions.deleteTab(tabId));
404
- }
405
-
406
- function closeAllTabs(model: Model) {
407
- const tabsets = model.getRoot().getChildren();
408
- tabsets.forEach(tabset => {
409
- if (tabset.getType() === 'tabset') {
410
- const tabs = tabset.getChildren();
411
- tabs.forEach(tab => {
412
- if (tab.getType() === 'tab') {
413
- model.doAction(Actions.deleteTab(tab.getId()));
414
- }
415
- });
416
- }
417
- });
418
- }
419
- ```
420
-
421
- ## Tab Context and Props
422
-
423
- ### Passing Data to Components
424
-
425
- ```typescript
426
- interface EditorTabProps {
427
- node: TabNode;
428
- }
429
-
430
- function EditorTab({ node }: EditorTabProps) {
431
- const filepath = node.getConfig()?.filepath as string;
432
- const readonly = node.getConfig()?.readonly as boolean;
433
-
434
- return (
435
- <div>
436
- <p>Editing: {filepath}</p>
437
- <textarea readOnly={readonly} />
438
- </div>
439
- );
440
- }
441
-
442
- // Factory with data passing
443
- const factory = (node: TabNode) => {
444
- const component = node.getComponent();
445
-
446
- switch (component) {
447
- case 'editor':
448
- return <EditorTab node={node} />;
449
- default:
450
- return <div>Unknown</div>;
451
- }
452
- };
453
-
454
- // Create tab with config
455
- const newTab: IJsonTabNode = {
456
- type: 'tab',
457
- name: 'my-file.ts',
458
- component: 'editor',
459
- config: {
460
- filepath: '/src/my-file.ts',
461
- readonly: false,
462
- }
463
- };
464
- ```
465
-
466
- ### Accessing Tab State
467
-
468
- ```typescript
469
- function SmartPanel({ node }: { node: TabNode }) {
470
- const name = node.getName();
471
- const isActive = node.isSelected();
472
- const isVisible = node.isVisible();
473
-
474
- return (
475
- <div className={isActive ? 'active' : 'inactive'}>
476
- <h3>{name}</h3>
477
- {isVisible && <p>This tab is visible</p>}
478
- </div>
479
- );
480
- }
481
- ```
482
-
483
- ## Styling and Theming
484
-
485
- ### Custom CSS
486
-
487
- ```css
488
- /* Override FlexLayout styles */
489
- .flexlayout__layout {
490
- background: #1e1e1e;
491
- }
492
-
493
- .flexlayout__tab {
494
- background: #2d2d2d;
495
- color: #cccccc;
496
- }
497
-
498
- .flexlayout__tab:hover {
499
- background: #3e3e3e;
500
- }
501
-
502
- .flexlayout__tab_button--selected {
503
- background: #1e1e1e;
504
- border-bottom: 2px solid #007acc;
505
- }
506
-
507
- .flexlayout__splitter {
508
- background: #2d2d2d;
509
- }
510
-
511
- .flexlayout__splitter:hover {
512
- background: #007acc;
513
- }
514
- ```
515
-
516
- ### Dark/Light Theme Toggle
517
-
518
- ```typescript
519
- import 'flexlayout-react/style/dark.css';
520
- // or
521
- import 'flexlayout-react/style/light.css';
522
-
523
- function ThemeToggle() {
524
- const [theme, setTheme] = useState<'dark' | 'light'>('dark');
525
-
526
- useEffect(() => {
527
- // Dynamically load theme
528
- const link = document.createElement('link');
529
- link.rel = 'stylesheet';
530
- link.href = `flexlayout-react/style/${theme}.css`;
531
- document.head.appendChild(link);
532
-
533
- return () => {
534
- document.head.removeChild(link);
535
- };
536
- }, [theme]);
537
-
538
- return (
539
- <button onClick={() => setTheme(theme === 'dark' ? 'light' : 'dark')}>
540
- Toggle Theme
541
- </button>
542
- );
543
- }
544
- ```
545
-
546
- ## Integration with Tauri
547
-
548
- ### Persisting Layout to Tauri Backend
549
-
550
- ```typescript
551
- import { invoke } from '@tauri-apps/api/core';
552
-
553
- async function saveLayoutToTauri(model: Model) {
554
- const json = model.toJson();
555
- await invoke('save_layout', {
556
- layout: JSON.stringify(json)
557
- });
558
- }
559
-
560
- async function loadLayoutFromTauri(): Promise<Model> {
561
- const layout = await invoke<string>('load_layout');
562
- return Model.fromJson(JSON.parse(layout));
563
- }
564
-
565
- // Tauri command (Rust)
566
- // #[tauri::command]
567
- // async fn save_layout(layout: String) -> Result<(), String> {
568
- // let app_dir = app.path_resolver().app_data_dir()?;
569
- // let layout_file = app_dir.join("layout.json");
570
- // tokio::fs::write(layout_file, layout).await?;
571
- // Ok(())
572
- // }
573
- ```
574
-
575
- ### Window-Specific Layouts
576
-
577
- ```typescript
578
- import { invoke } from '@tauri-apps/api/core';
579
- import { getCurrent } from '@tauri-apps/api/window';
580
-
581
- function WindowLayout() {
582
- const [model, setModel] = useState<Model | null>(null);
583
-
584
- useEffect(() => {
585
- const currentWindow = getCurrent();
586
- const windowLabel = currentWindow.label;
587
-
588
- // Load layout for this specific window
589
- invoke<string>('load_window_layout', { windowLabel })
590
- .then(layout => {
591
- setModel(Model.fromJson(JSON.parse(layout)));
592
- })
593
- .catch(() => {
594
- setModel(Model.fromJson(defaultLayout));
595
- });
596
- }, []);
597
-
598
- const onModelChange = (newModel: Model) => {
599
- const currentWindow = getCurrent();
600
- const json = newModel.toJson();
601
-
602
- invoke('save_window_layout', {
603
- windowLabel: currentWindow.label,
604
- layout: JSON.stringify(json)
605
- });
606
- };
607
-
608
- if (!model) return <div>Loading...</div>;
609
-
610
- return (
611
- <Layout
612
- model={model}
613
- factory={factory}
614
- onModelChange={onModelChange}
615
- />
616
- );
617
- }
618
- ```
619
-
620
- ## Advanced Patterns
621
-
622
- ### Custom Tab Headers
623
-
624
- ```typescript
625
- import { Layout, Model, TabNode, ITabRenderValues } from 'flexlayout-react';
626
-
627
- function App() {
628
- const onRenderTab = (
629
- node: TabNode,
630
- renderValues: ITabRenderValues
631
- ) => {
632
- const modified = node.getConfig()?.modified as boolean;
633
-
634
- renderValues.content = (
635
- <div className="custom-tab-header">
636
- <span>{node.getName()}</span>
637
- {modified && <span className="modified-indicator">●</span>}
638
- </div>
639
- );
640
- };
641
-
642
- return (
643
- <Layout
644
- model={model}
645
- factory={factory}
646
- onRenderTab={onRenderTab}
647
- />
648
- );
649
- }
650
- ```
651
-
652
- ### Tab Actions (Custom Buttons)
653
-
654
- ```typescript
655
- const onRenderTab = (node: TabNode, renderValues: ITabRenderValues) => {
656
- renderValues.buttons.push(
657
- <button
658
- key="save"
659
- onClick={() => saveTabContent(node)}
660
- title="Save"
661
- >
662
- 💾
663
- </button>
664
- );
665
-
666
- renderValues.buttons.push(
667
- <button
668
- key="duplicate"
669
- onClick={() => duplicateTab(node)}
670
- title="Duplicate"
671
- >
672
- 📋
673
- </button>
674
- );
675
- };
676
- ```
677
-
678
- ## Best Practices
679
-
680
- 1. **Persist layouts** - Save to localStorage or backend for user experience
681
- 2. **Use unique component names** - Avoid collisions in factory function
682
- 3. **Handle missing components** - Factory should have default case
683
- 4. **Memoize factory function** - Prevent unnecessary re-renders
684
- 5. **Use config for tab data** - Store tab-specific props in config
685
- 6. **Provide reset mechanism** - Users can restore default layout
686
- 7. **Test layout changes** - Verify persistence works correctly
687
- 8. **Handle edge cases** - Empty tabsets, deleted components
688
- 9. **Use borders wisely** - Left/right/top/bottom for tools, main area for content
689
- 10. **Optimize large layouts** - Lazy-load components when possible
690
-
691
- ## Common Pitfalls
692
-
693
- ❌ **Not memoizing model**:
694
- ```typescript
695
- // WRONG - creates new model on every render
696
- function App() {
697
- const model = Model.fromJson(layout); // Bad!
698
- return <Layout model={model} />;
699
- }
700
-
701
- // CORRECT
702
- function App() {
703
- const modelRef = useRef(Model.fromJson(layout));
704
- return <Layout model={modelRef.current} />;
705
- }
706
- ```
707
-
708
- ❌ **Forgetting CSS import**:
709
- ```typescript
710
- // WRONG - layout won't display correctly
711
- import { Layout } from 'flexlayout-react';
712
- // Missing: import 'flexlayout-react/style/dark.css';
713
- ```
714
-
715
- ❌ **Not handling onModelChange**:
716
- ```typescript
717
- // WRONG - layout changes not persisted
718
- <Layout model={model} factory={factory} />
719
-
720
- // CORRECT
721
- <Layout
722
- model={model}
723
- factory={factory}
724
- onModelChange={saveLayout}
725
- />
726
- ```
727
-
728
- ## Resources
729
-
730
- - **Documentation**: https://github.com/caplin/FlexLayout
731
- - **Examples**: https://rawgit.com/caplin/FlexLayout/demos/demos/index.html
732
- - **TypeScript Types**: Included in package
733
-
734
- ## Summary
735
-
736
- - **FlexLayout** provides IDE-quality docking layouts
737
- - **Model-driven** - Define layout as JSON, control programmatically
738
- - **Persistent** - Save/restore user layouts easily
739
- - **Customizable** - Custom tabs, borders, themes
740
- - **React-friendly** - Hooks, TypeScript support
741
- - **Perfect for** - IDEs, dashboards, admin panels, complex UIs
742
- - **Tauri integration** - Persist to backend, window-specific layouts