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.
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,767 +0,0 @@
1
- ---
2
- name: tauri-frontend-integration
3
- description: Frontend integration patterns for Tauri including TypeScript services, React hooks, Vue composition, Svelte stores, and framework-agnostic patterns
4
- version: 1.0.0
5
- category: development
6
- author: Claude MPM Team
7
- license: MIT
8
- progressive_disclosure:
9
- entry_point:
10
- summary: "Frontend patterns: TypeScript service layer, React hooks for commands/events, Vue/Svelte integration, type safety across IPC boundary"
11
- when_to_use: "Building Tauri frontend with React, Vue, Svelte, or vanilla JS with proper TypeScript types and abstractions"
12
- quick_start: "1. Create typed service layer 2. Framework-specific hooks/composables 3. Event handling 4. Error boundaries"
13
- context_limit: 700
14
- tags:
15
- - tauri
16
- - frontend
17
- - react
18
- - vue
19
- - svelte
20
- - typescript
21
- - integration
22
- requires_tools: []
23
- ---
24
-
25
- # Tauri Frontend Integration
26
-
27
- ## TypeScript Service Layer
28
-
29
- ### Type-Safe Command Service
30
-
31
- ```typescript
32
- // src/services/tauri.ts
33
- import { invoke } from '@tauri-apps/api/core';
34
-
35
- // Backend command types
36
- export interface FileMetadata {
37
- name: string;
38
- size: number;
39
- modified: number;
40
- isDir: boolean;
41
- }
42
-
43
- export interface UserConfig {
44
- theme: 'light' | 'dark';
45
- language: string;
46
- autoSave: boolean;
47
- }
48
-
49
- // Command service with full typing
50
- export class TauriService {
51
- static async readFile(path: string): Promise<string> {
52
- return await invoke<string>('read_file', { path });
53
- }
54
-
55
- static async writeFile(path: string, content: string): Promise<void> {
56
- await invoke('write_file', { path, content });
57
- }
58
-
59
- static async listFiles(directory: string): Promise<FileMetadata[]> {
60
- return await invoke<FileMetadata[]>('list_files', { directory });
61
- }
62
-
63
- static async getConfig(): Promise<UserConfig> {
64
- return await invoke<UserConfig>('get_config');
65
- }
66
-
67
- static async updateConfig(config: Partial<UserConfig>): Promise<void> {
68
- await invoke('update_config', { config });
69
- }
70
-
71
- static async performSearch(query: string, caseSensitive: boolean): Promise<string[]> {
72
- return await invoke<string[]>('perform_search', {
73
- query,
74
- caseSensitive
75
- });
76
- }
77
- }
78
- ```
79
-
80
- ### Result Type Pattern
81
-
82
- ```typescript
83
- // src/types/result.ts
84
- export type Result<T, E = string> =
85
- | { ok: true; value: T }
86
- | { ok: false; error: E };
87
-
88
- export function Ok<T>(value: T): Result<T> {
89
- return { ok: true, value };
90
- }
91
-
92
- export function Err<E = string>(error: E): Result<never, E> {
93
- return { ok: false, error };
94
- }
95
-
96
- // Service using Result type
97
- export class SafeTauriService {
98
- static async readFile(path: string): Promise<Result<string>> {
99
- try {
100
- const content = await invoke<string>('read_file', { path });
101
- return Ok(content);
102
- } catch (error) {
103
- return Err(String(error));
104
- }
105
- }
106
-
107
- static async writeFile(path: string, content: string): Promise<Result<void>> {
108
- try {
109
- await invoke('write_file', { path, content });
110
- return Ok(undefined);
111
- } catch (error) {
112
- return Err(String(error));
113
- }
114
- }
115
- }
116
- ```
117
-
118
- ## React Integration
119
-
120
- ### Custom Hooks for Commands
121
-
122
- ```typescript
123
- // src/hooks/useTauriCommand.ts
124
- import { useState, useEffect } from 'react';
125
- import { invoke } from '@tauri-apps/api/core';
126
-
127
- export interface CommandState<T> {
128
- data: T | null;
129
- loading: boolean;
130
- error: string | null;
131
- }
132
-
133
- export function useTauriCommand<T>(
134
- command: string,
135
- args?: Record<string, unknown>,
136
- immediate: boolean = true
137
- ): CommandState<T> & { refetch: () => Promise<void> } {
138
- const [state, setState] = useState<CommandState<T>>({
139
- data: null,
140
- loading: immediate,
141
- error: null
142
- });
143
-
144
- const execute = async () => {
145
- setState(prev => ({ ...prev, loading: true, error: null }));
146
-
147
- try {
148
- const data = await invoke<T>(command, args);
149
- setState({ data, loading: false, error: null });
150
- } catch (error) {
151
- setState({ data: null, loading: false, error: String(error) });
152
- }
153
- };
154
-
155
- useEffect(() => {
156
- if (immediate) {
157
- execute();
158
- }
159
- }, [command, JSON.stringify(args)]);
160
-
161
- return { ...state, refetch: execute };
162
- }
163
-
164
- // Usage
165
- function FileList() {
166
- const { data: files, loading, error, refetch } = useTauriCommand<FileMetadata[]>(
167
- 'list_files',
168
- { directory: '/home/user/documents' }
169
- );
170
-
171
- if (loading) return <div>Loading...</div>;
172
- if (error) return <div>Error: {error}</div>;
173
-
174
- return (
175
- <div>
176
- <button onClick={refetch}>Refresh</button>
177
- {files?.map(file => (
178
- <div key={file.name}>{file.name}</div>
179
- ))}
180
- </div>
181
- );
182
- }
183
- ```
184
-
185
- ### Event Hooks
186
-
187
- ```typescript
188
- // src/hooks/useTauriEvent.ts
189
- import { useEffect, useState } from 'react';
190
- import { listen, UnlistenFn } from '@tauri-apps/api/event';
191
-
192
- export function useTauriEvent<T>(event: string): T | null {
193
- const [data, setData] = useState<T | null>(null);
194
-
195
- useEffect(() => {
196
- let unlisten: UnlistenFn;
197
-
198
- listen<T>(event, (e) => {
199
- setData(e.payload);
200
- }).then(fn => {
201
- unlisten = fn;
202
- });
203
-
204
- return () => {
205
- if (unlisten) unlisten();
206
- };
207
- }, [event]);
208
-
209
- return data;
210
- }
211
-
212
- // Usage
213
- function ProgressBar() {
214
- const progress = useTauriEvent<{ current: number; total: number }>('download-progress');
215
-
216
- if (!progress) return null;
217
-
218
- const percentage = (progress.current / progress.total) * 100;
219
-
220
- return (
221
- <div className="progress-bar">
222
- <div style={{ width: `${percentage}%` }} />
223
- <span>{percentage.toFixed(0)}%</span>
224
- </div>
225
- );
226
- }
227
- ```
228
-
229
- ### Bidirectional Event Hook
230
-
231
- ```typescript
232
- // src/hooks/useTauriEventEmitter.ts
233
- import { useCallback, useEffect } from 'react';
234
- import { listen, emit, UnlistenFn } from '@tauri-apps/api/event';
235
-
236
- export function useTauriEventEmitter<T, R>(
237
- emitEvent: string,
238
- listenEvent: string,
239
- handler: (data: R) => void
240
- ) {
241
- useEffect(() => {
242
- let unlisten: UnlistenFn;
243
-
244
- listen<R>(listenEvent, (e) => {
245
- handler(e.payload);
246
- }).then(fn => {
247
- unlisten = fn;
248
- });
249
-
250
- return () => {
251
- if (unlisten) unlisten();
252
- };
253
- }, [listenEvent, handler]);
254
-
255
- const send = useCallback(async (data: T) => {
256
- await emit(emitEvent, data);
257
- }, [emitEvent]);
258
-
259
- return send;
260
- }
261
-
262
- // Usage
263
- function Chat() {
264
- const [messages, setMessages] = useState<string[]>([]);
265
-
266
- const sendMessage = useTauriEventEmitter<string, string>(
267
- 'send-message',
268
- 'receive-message',
269
- (msg) => setMessages(prev => [...prev, msg])
270
- );
271
-
272
- return (
273
- <div>
274
- {messages.map((msg, i) => <div key={i}>{msg}</div>)}
275
- <button onClick={() => sendMessage('Hello!')}>Send</button>
276
- </div>
277
- );
278
- }
279
- ```
280
-
281
- ### Context Provider Pattern
282
-
283
- ```typescript
284
- // src/contexts/TauriContext.tsx
285
- import React, { createContext, useContext, useState, useEffect } from 'react';
286
- import { invoke } from '@tauri-apps/api/core';
287
-
288
- interface AppState {
289
- config: UserConfig | null;
290
- updateConfig: (config: Partial<UserConfig>) => Promise<void>;
291
- }
292
-
293
- const TauriContext = createContext<AppState | undefined>(undefined);
294
-
295
- export function TauriProvider({ children }: { children: React.ReactNode }) {
296
- const [config, setConfig] = useState<UserConfig | null>(null);
297
-
298
- useEffect(() => {
299
- invoke<UserConfig>('get_config').then(setConfig);
300
- }, []);
301
-
302
- const updateConfig = async (newConfig: Partial<UserConfig>) => {
303
- await invoke('update_config', { config: newConfig });
304
- setConfig(prev => ({ ...prev!, ...newConfig }));
305
- };
306
-
307
- return (
308
- <TauriContext.Provider value={{ config, updateConfig }}>
309
- {children}
310
- </TauriContext.Provider>
311
- );
312
- }
313
-
314
- export function useTauri() {
315
- const context = useContext(TauriContext);
316
- if (!context) throw new Error('useTauri must be used within TauriProvider');
317
- return context;
318
- }
319
-
320
- // Usage
321
- function App() {
322
- return (
323
- <TauriProvider>
324
- <SettingsPanel />
325
- </TauriProvider>
326
- );
327
- }
328
-
329
- function SettingsPanel() {
330
- const { config, updateConfig } = useTauri();
331
-
332
- return (
333
- <div>
334
- <label>
335
- <input
336
- type="checkbox"
337
- checked={config?.autoSave}
338
- onChange={(e) => updateConfig({ autoSave: e.target.checked })}
339
- />
340
- Auto Save
341
- </label>
342
- </div>
343
- );
344
- }
345
- ```
346
-
347
- ## Vue 3 Integration
348
-
349
- ### Composition API Composables
350
-
351
- ```typescript
352
- // src/composables/useTauriCommand.ts
353
- import { ref, Ref, onMounted } from 'vue';
354
- import { invoke } from '@tauri-apps/api/core';
355
-
356
- export function useTauriCommand<T>(
357
- command: string,
358
- args?: Record<string, unknown>,
359
- immediate: boolean = true
360
- ) {
361
- const data: Ref<T | null> = ref(null);
362
- const loading = ref(immediate);
363
- const error: Ref<string | null> = ref(null);
364
-
365
- const execute = async () => {
366
- loading.value = true;
367
- error.value = null;
368
-
369
- try {
370
- data.value = await invoke<T>(command, args);
371
- } catch (e) {
372
- error.value = String(e);
373
- } finally {
374
- loading.value = false;
375
- }
376
- };
377
-
378
- if (immediate) {
379
- onMounted(execute);
380
- }
381
-
382
- return { data, loading, error, refetch: execute };
383
- }
384
-
385
- // Usage in component
386
- <script setup lang="ts">
387
- import { useTauriCommand } from '@/composables/useTauriCommand';
388
-
389
- const { data: files, loading, error } = useTauriCommand<FileMetadata[]>(
390
- 'list_files',
391
- { directory: '/home/user' }
392
- );
393
- </script>
394
-
395
- <template>
396
- <div v-if="loading">Loading...</div>
397
- <div v-else-if="error">Error: {{ error }}</div>
398
- <div v-else>
399
- <div v-for="file in files" :key="file.name">
400
- {{ file.name }}
401
- </div>
402
- </div>
403
- </template>
404
- ```
405
-
406
- ### Event Composable
407
-
408
- ```typescript
409
- // src/composables/useTauriEvent.ts
410
- import { ref, Ref, onMounted, onUnmounted } from 'vue';
411
- import { listen, UnlistenFn } from '@tauri-apps/api/event';
412
-
413
- export function useTauriEvent<T>(event: string): Ref<T | null> {
414
- const data: Ref<T | null> = ref(null);
415
- let unlisten: UnlistenFn;
416
-
417
- onMounted(async () => {
418
- unlisten = await listen<T>(event, (e) => {
419
- data.value = e.payload;
420
- });
421
- });
422
-
423
- onUnmounted(() => {
424
- if (unlisten) unlisten();
425
- });
426
-
427
- return data;
428
- }
429
-
430
- // Usage
431
- <script setup lang="ts">
432
- const progress = useTauriEvent<{ current: number; total: number }>('download-progress');
433
- </script>
434
-
435
- <template>
436
- <div v-if="progress">
437
- {{ Math.floor((progress.current / progress.total) * 100) }}%
438
- </div>
439
- </template>
440
- ```
441
-
442
- ### Provide/Inject Pattern
443
-
444
- ```typescript
445
- // src/composables/useTauriApp.ts
446
- import { provide, inject, InjectionKey, Ref, ref, onMounted } from 'vue';
447
- import { invoke } from '@tauri-apps/api/core';
448
-
449
- interface TauriApp {
450
- config: Ref<UserConfig | null>;
451
- updateConfig: (config: Partial<UserConfig>) => Promise<void>;
452
- }
453
-
454
- const TauriAppKey: InjectionKey<TauriApp> = Symbol('TauriApp');
455
-
456
- export function provideTauriApp() {
457
- const config = ref<UserConfig | null>(null);
458
-
459
- onMounted(async () => {
460
- config.value = await invoke<UserConfig>('get_config');
461
- });
462
-
463
- const updateConfig = async (newConfig: Partial<UserConfig>) => {
464
- await invoke('update_config', { config: newConfig });
465
- config.value = { ...config.value!, ...newConfig };
466
- };
467
-
468
- const app: TauriApp = { config, updateConfig };
469
- provide(TauriAppKey, app);
470
- }
471
-
472
- export function useTauriApp(): TauriApp {
473
- const app = inject(TauriAppKey);
474
- if (!app) throw new Error('useTauriApp must be called within TauriApp provider');
475
- return app;
476
- }
477
- ```
478
-
479
- ## Svelte Integration
480
-
481
- ### Svelte Stores
482
-
483
- ```typescript
484
- // src/stores/tauri.ts
485
- import { writable, derived, Readable } from 'svelte/store';
486
- import { invoke } from '@tauri-apps/api/core';
487
- import { listen } from '@tauri-apps/api/event';
488
-
489
- export function createCommandStore<T>(command: string, args?: Record<string, unknown>) {
490
- const { subscribe, set } = writable<{
491
- data: T | null;
492
- loading: boolean;
493
- error: string | null;
494
- }>({
495
- data: null,
496
- loading: true,
497
- error: null
498
- });
499
-
500
- const load = async () => {
501
- set({ data: null, loading: true, error: null });
502
-
503
- try {
504
- const data = await invoke<T>(command, args);
505
- set({ data, loading: false, error: null });
506
- } catch (error) {
507
- set({ data: null, loading: false, error: String(error) });
508
- }
509
- };
510
-
511
- load();
512
-
513
- return {
514
- subscribe,
515
- refetch: load
516
- };
517
- }
518
-
519
- // Usage
520
- <script lang="ts">
521
- import { createCommandStore } from '$lib/stores/tauri';
522
-
523
- const files = createCommandStore<FileMetadata[]>('list_files', {
524
- directory: '/home/user'
525
- });
526
- </script>
527
-
528
- {#if $files.loading}
529
- <div>Loading...</div>
530
- {:else if $files.error}
531
- <div>Error: {$files.error}</div>
532
- {:else}
533
- {#each $files.data ?? [] as file}
534
- <div>{file.name}</div>
535
- {/each}
536
- {/if}
537
- ```
538
-
539
- ### Event Store
540
-
541
- ```typescript
542
- // src/stores/events.ts
543
- import { writable } from 'svelte/store';
544
- import { listen, UnlistenFn } from '@tauri-apps/api/event';
545
-
546
- export function createEventStore<T>(event: string) {
547
- const { subscribe, set } = writable<T | null>(null);
548
-
549
- let unlisten: UnlistenFn;
550
-
551
- listen<T>(event, (e) => {
552
- set(e.payload);
553
- }).then(fn => {
554
- unlisten = fn;
555
- });
556
-
557
- return {
558
- subscribe,
559
- cleanup: () => {
560
- if (unlisten) unlisten();
561
- }
562
- };
563
- }
564
-
565
- // Usage
566
- <script lang="ts">
567
- import { onDestroy } from 'svelte';
568
-
569
- const progress = createEventStore<{ current: number; total: number }>('download-progress');
570
-
571
- onDestroy(() => {
572
- progress.cleanup();
573
- });
574
- </script>
575
-
576
- {#if $progress}
577
- <div>
578
- {Math.floor(($progress.current / $progress.total) * 100)}%
579
- </div>
580
- {/if}
581
- ```
582
-
583
- ## Framework-Agnostic Patterns
584
-
585
- ### Observable Pattern
586
-
587
- ```typescript
588
- // src/utils/observable.ts
589
- export class TauriObservable<T> {
590
- private listeners: Set<(data: T) => void> = new Set();
591
- private value: T | null = null;
592
-
593
- subscribe(listener: (data: T) => void): () => void {
594
- this.listeners.add(listener);
595
- if (this.value !== null) listener(this.value);
596
-
597
- return () => this.listeners.delete(listener);
598
- }
599
-
600
- emit(data: T) {
601
- this.value = data;
602
- this.listeners.forEach(listener => listener(data));
603
- }
604
-
605
- getValue(): T | null {
606
- return this.value;
607
- }
608
- }
609
-
610
- // Command observable
611
- export function createCommandObservable<T>(
612
- command: string,
613
- args?: Record<string, unknown>
614
- ): TauriObservable<T> {
615
- const observable = new TauriObservable<T>();
616
-
617
- invoke<T>(command, args)
618
- .then(data => observable.emit(data))
619
- .catch(err => console.error(err));
620
-
621
- return observable;
622
- }
623
-
624
- // Event observable
625
- export function createEventObservable<T>(event: string): TauriObservable<T> {
626
- const observable = new TauriObservable<T>();
627
-
628
- listen<T>(event, (e) => {
629
- observable.emit(e.payload);
630
- });
631
-
632
- return observable;
633
- }
634
- ```
635
-
636
- ## Error Boundaries
637
-
638
- ### React Error Boundary
639
-
640
- ```typescript
641
- // src/components/TauriErrorBoundary.tsx
642
- import React, { Component, ErrorInfo, ReactNode } from 'react';
643
-
644
- interface Props {
645
- children: ReactNode;
646
- fallback?: (error: Error) => ReactNode;
647
- }
648
-
649
- interface State {
650
- hasError: boolean;
651
- error: Error | null;
652
- }
653
-
654
- export class TauriErrorBoundary extends Component<Props, State> {
655
- state: State = {
656
- hasError: false,
657
- error: null
658
- };
659
-
660
- static getDerivedStateFromError(error: Error): State {
661
- return { hasError: true, error };
662
- }
663
-
664
- componentDidCatch(error: Error, errorInfo: ErrorInfo) {
665
- console.error('Tauri Error:', error, errorInfo);
666
-
667
- // Log to backend
668
- import('@tauri-apps/api/core').then(({ invoke }) => {
669
- invoke('log_error', {
670
- error: error.toString(),
671
- info: errorInfo.componentStack
672
- }).catch(console.error);
673
- });
674
- }
675
-
676
- render() {
677
- if (this.state.hasError && this.state.error) {
678
- if (this.props.fallback) {
679
- return this.props.fallback(this.state.error);
680
- }
681
-
682
- return (
683
- <div className="error-boundary">
684
- <h2>Something went wrong</h2>
685
- <pre>{this.state.error.message}</pre>
686
- </div>
687
- );
688
- }
689
-
690
- return this.props.children;
691
- }
692
- }
693
-
694
- // Usage
695
- <TauriErrorBoundary>
696
- <App />
697
- </TauriErrorBoundary>
698
- ```
699
-
700
- ## Best Practices
701
-
702
- 1. **Type everything** - Full TypeScript types across IPC boundary
703
- 2. **Service layer** - Abstract Tauri commands into typed service
704
- 3. **Framework hooks/composables** - Idiomatic patterns for each framework
705
- 4. **Error boundaries** - Catch and log Tauri errors
706
- 5. **Loading states** - Always handle loading/error states
707
- 6. **Event cleanup** - Unlisten from events on unmount
708
- 7. **Result types** - Use Result<T, E> for explicit error handling
709
- 8. **Context/Provide** - Share Tauri state across component tree
710
- 9. **Observable pattern** - Framework-agnostic state management
711
- 10. **Async safety** - Handle race conditions and cancellation
712
-
713
- ## Common Pitfalls
714
-
715
- ❌ **Not unlistening from events**:
716
- ```typescript
717
- // WRONG - memory leak
718
- useEffect(() => {
719
- listen('my-event', handler);
720
- }, []);
721
-
722
- // CORRECT - cleanup
723
- useEffect(() => {
724
- let unlisten: UnlistenFn;
725
- listen('my-event', handler).then(fn => unlisten = fn);
726
- return () => { if (unlisten) unlisten(); };
727
- }, []);
728
- ```
729
-
730
- ❌ **Missing loading/error states**:
731
- ```typescript
732
- // WRONG - no feedback
733
- const data = await invoke('command');
734
- return <div>{data}</div>;
735
-
736
- // CORRECT - handle all states
737
- const { data, loading, error } = useTauriCommand('command');
738
- if (loading) return <div>Loading...</div>;
739
- if (error) return <div>Error: {error}</div>;
740
- return <div>{data}</div>;
741
- ```
742
-
743
- ❌ **Invoking in render**:
744
- ```typescript
745
- // WRONG - invokes every render
746
- function Component() {
747
- const data = invoke('command'); // DON'T DO THIS
748
- }
749
-
750
- // CORRECT - use hooks/effects
751
- function Component() {
752
- const { data } = useTauriCommand('command');
753
- }
754
- ```
755
-
756
- ## Summary
757
-
758
- - **TypeScript service layer** for type-safe command abstraction
759
- - **React hooks** (useTauriCommand, useTauriEvent) for declarative data
760
- - **Vue composables** with Composition API patterns
761
- - **Svelte stores** for reactive command/event data
762
- - **Framework-agnostic** observable pattern
763
- - **Error boundaries** to catch and log Tauri errors
764
- - **Result types** for explicit error handling
765
- - **Context patterns** for shared Tauri state
766
- - **Event cleanup** to prevent memory leaks
767
- - **Type safety** across entire IPC boundary