claude-mpm 4.21.3__py3-none-any.whl → 5.0.2__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 (484) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +632 -334
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent.json +6 -3
  9. claude_mpm/agents/frontmatter_validator.py +1 -1
  10. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +370 -3
  11. claude_mpm/agents/templates/context-management-examples.md +544 -0
  12. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +89 -19
  13. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  14. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  15. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  16. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  17. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  18. claude_mpm/cli/__init__.py +38 -2
  19. claude_mpm/cli/commands/agent_source.py +774 -0
  20. claude_mpm/cli/commands/agent_state_manager.py +125 -20
  21. claude_mpm/cli/commands/agents.py +684 -13
  22. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  23. claude_mpm/cli/commands/agents_discover.py +338 -0
  24. claude_mpm/cli/commands/aggregate.py +1 -1
  25. claude_mpm/cli/commands/analyze.py +3 -3
  26. claude_mpm/cli/commands/auto_configure.py +2 -6
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/config.py +7 -4
  29. claude_mpm/cli/commands/configure.py +478 -44
  30. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  31. claude_mpm/cli/commands/configure_navigation.py +63 -46
  32. claude_mpm/cli/commands/debug.py +12 -12
  33. claude_mpm/cli/commands/doctor.py +10 -2
  34. claude_mpm/cli/commands/hook_errors.py +277 -0
  35. claude_mpm/cli/commands/local_deploy.py +1 -4
  36. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  37. claude_mpm/cli/commands/mpm_init/core.py +50 -2
  38. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  39. claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
  40. claude_mpm/cli/commands/run.py +124 -128
  41. claude_mpm/cli/commands/skill_source.py +694 -0
  42. claude_mpm/cli/commands/skills.py +435 -1
  43. claude_mpm/cli/executor.py +78 -3
  44. claude_mpm/cli/interactive/agent_wizard.py +919 -41
  45. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  46. claude_mpm/cli/parsers/agents_parser.py +173 -4
  47. claude_mpm/cli/parsers/base_parser.py +49 -0
  48. claude_mpm/cli/parsers/config_parser.py +96 -43
  49. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  50. claude_mpm/cli/parsers/skills_parser.py +138 -0
  51. claude_mpm/cli/parsers/source_parser.py +138 -0
  52. claude_mpm/cli/startup.py +499 -84
  53. claude_mpm/cli/startup_display.py +480 -0
  54. claude_mpm/cli/utils.py +1 -1
  55. claude_mpm/cli_module/commands.py +1 -1
  56. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  57. claude_mpm/commands/mpm-agents-detect.md +9 -0
  58. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  59. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  60. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  61. claude_mpm/commands/mpm-doctor.md +9 -0
  62. claude_mpm/commands/mpm-help.md +11 -2
  63. claude_mpm/commands/mpm-init.md +27 -2
  64. claude_mpm/commands/mpm-monitor.md +9 -0
  65. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  66. claude_mpm/commands/mpm-status.md +9 -0
  67. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  68. claude_mpm/commands/mpm-ticket-view.md +552 -0
  69. claude_mpm/commands/mpm-version.md +9 -0
  70. claude_mpm/commands/mpm.md +10 -0
  71. claude_mpm/config/agent_presets.py +258 -0
  72. claude_mpm/config/agent_sources.py +325 -0
  73. claude_mpm/config/skill_sources.py +590 -0
  74. claude_mpm/constants.py +12 -0
  75. claude_mpm/core/api_validator.py +1 -1
  76. claude_mpm/core/claude_runner.py +17 -10
  77. claude_mpm/core/config.py +24 -0
  78. claude_mpm/core/constants.py +1 -1
  79. claude_mpm/core/framework/__init__.py +3 -16
  80. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  81. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  82. claude_mpm/core/hook_error_memory.py +381 -0
  83. claude_mpm/core/hook_manager.py +41 -2
  84. claude_mpm/core/interactive_session.py +112 -5
  85. claude_mpm/core/logger.py +3 -1
  86. claude_mpm/core/oneshot_session.py +94 -4
  87. claude_mpm/dashboard/static/css/activity.css +69 -69
  88. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  89. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  90. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  91. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  92. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  93. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  94. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  95. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  96. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  97. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  98. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  99. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  100. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  101. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  102. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  103. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  104. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  105. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  106. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  107. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  108. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  109. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  110. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  111. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  112. claude_mpm/dashboard/templates/code_simple.html +23 -23
  113. claude_mpm/dashboard/templates/index.html +18 -18
  114. claude_mpm/experimental/cli_enhancements.py +1 -5
  115. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  116. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  117. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  118. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  119. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  120. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  121. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  122. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  123. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  124. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  125. claude_mpm/models/git_repository.py +198 -0
  126. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  127. claude_mpm/scripts/start_activity_logging.py +3 -1
  128. claude_mpm/services/agents/agent_builder.py +45 -9
  129. claude_mpm/services/agents/agent_preset_service.py +238 -0
  130. claude_mpm/services/agents/agent_selection_service.py +484 -0
  131. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  132. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  133. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  134. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  135. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  136. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  137. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  138. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  139. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  140. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  141. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  142. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  143. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  144. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  145. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  146. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  147. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  148. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  149. claude_mpm/services/agents/git_source_manager.py +629 -0
  150. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  151. claude_mpm/services/agents/local_template_manager.py +50 -10
  152. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  153. claude_mpm/services/agents/sources/__init__.py +13 -0
  154. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  155. claude_mpm/services/agents/sources/git_source_sync_service.py +1055 -0
  156. claude_mpm/services/agents/startup_sync.py +239 -0
  157. claude_mpm/services/agents/toolchain_detector.py +474 -0
  158. claude_mpm/services/cli/session_pause_manager.py +1 -1
  159. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  160. claude_mpm/services/command_deployment_service.py +92 -1
  161. claude_mpm/services/core/interfaces/__init__.py +1 -3
  162. claude_mpm/services/core/interfaces/health.py +1 -4
  163. claude_mpm/services/core/models/__init__.py +2 -11
  164. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  165. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  166. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  167. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  168. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  169. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  170. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  171. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  172. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  173. claude_mpm/services/event_bus/direct_relay.py +3 -3
  174. claude_mpm/services/event_bus/event_bus.py +36 -3
  175. claude_mpm/services/events/consumers/logging.py +1 -2
  176. claude_mpm/services/git/__init__.py +21 -0
  177. claude_mpm/services/git/git_operations_service.py +494 -0
  178. claude_mpm/services/github/__init__.py +21 -0
  179. claude_mpm/services/github/github_cli_service.py +397 -0
  180. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  181. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  182. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  183. claude_mpm/services/instructions/__init__.py +9 -0
  184. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  185. claude_mpm/services/local_ops/__init__.py +3 -13
  186. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  187. claude_mpm/services/local_ops/health_manager.py +1 -4
  188. claude_mpm/services/local_ops/process_manager.py +1 -1
  189. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  190. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  191. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  192. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  193. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  194. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  195. claude_mpm/services/memory/optimizer.py +1 -1
  196. claude_mpm/services/model/model_router.py +8 -9
  197. claude_mpm/services/monitor/daemon.py +1 -1
  198. claude_mpm/services/monitor/server.py +2 -2
  199. claude_mpm/services/native_agent_converter.py +356 -0
  200. claude_mpm/services/port_manager.py +1 -1
  201. claude_mpm/services/pr/__init__.py +14 -0
  202. claude_mpm/services/pr/pr_template_service.py +329 -0
  203. claude_mpm/services/project/documentation_manager.py +2 -1
  204. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  205. claude_mpm/services/runner_configuration_service.py +1 -0
  206. claude_mpm/services/self_upgrade_service.py +165 -7
  207. claude_mpm/services/skills/__init__.py +18 -0
  208. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  209. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  210. claude_mpm/services/skills_config.py +547 -0
  211. claude_mpm/services/skills_deployer.py +955 -0
  212. claude_mpm/services/socketio/handlers/connection.py +1 -1
  213. claude_mpm/services/socketio/handlers/git.py +2 -2
  214. claude_mpm/services/socketio/server/core.py +1 -4
  215. claude_mpm/services/socketio/server/main.py +1 -3
  216. claude_mpm/services/system_instructions_service.py +1 -3
  217. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  218. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  219. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  220. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  221. claude_mpm/services/unified/unified_deployment.py +1 -5
  222. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  223. claude_mpm/services/visualization/__init__.py +1 -5
  224. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  225. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  226. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  227. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  228. claude_mpm/skills/skills_registry.py +0 -1
  229. claude_mpm/templates/questions/__init__.py +38 -0
  230. claude_mpm/templates/questions/base.py +193 -0
  231. claude_mpm/templates/questions/pr_strategy.py +311 -0
  232. claude_mpm/templates/questions/project_init.py +385 -0
  233. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  234. claude_mpm/tools/__main__.py +8 -8
  235. claude_mpm/tools/code_tree_analyzer/analysis.py +1 -1
  236. claude_mpm/utils/agent_dependency_loader.py +80 -13
  237. claude_mpm/utils/dependency_cache.py +3 -1
  238. claude_mpm/utils/gitignore.py +241 -0
  239. claude_mpm/utils/log_cleanup.py +3 -3
  240. claude_mpm/utils/progress.py +383 -0
  241. claude_mpm/utils/robust_installer.py +3 -5
  242. claude_mpm/utils/structured_questions.py +619 -0
  243. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/METADATA +429 -59
  244. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/RECORD +252 -425
  245. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  246. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  247. claude_mpm/agents/templates/agent-manager.json +0 -273
  248. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  249. claude_mpm/agents/templates/api_qa.json +0 -180
  250. claude_mpm/agents/templates/clerk-ops.json +0 -235
  251. claude_mpm/agents/templates/code_analyzer.json +0 -101
  252. claude_mpm/agents/templates/content-agent.json +0 -358
  253. claude_mpm/agents/templates/dart_engineer.json +0 -307
  254. claude_mpm/agents/templates/data_engineer.json +0 -225
  255. claude_mpm/agents/templates/documentation.json +0 -211
  256. claude_mpm/agents/templates/engineer.json +0 -210
  257. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  258. claude_mpm/agents/templates/golang_engineer.json +0 -270
  259. claude_mpm/agents/templates/imagemagick.json +0 -264
  260. claude_mpm/agents/templates/java_engineer.json +0 -346
  261. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  262. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  263. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  264. claude_mpm/agents/templates/memory_manager.json +0 -158
  265. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  266. claude_mpm/agents/templates/ops.json +0 -185
  267. claude_mpm/agents/templates/php-engineer.json +0 -287
  268. claude_mpm/agents/templates/product_owner.json +0 -338
  269. claude_mpm/agents/templates/project_organizer.json +0 -140
  270. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  271. claude_mpm/agents/templates/python_engineer.json +0 -387
  272. claude_mpm/agents/templates/qa.json +0 -242
  273. claude_mpm/agents/templates/react_engineer.json +0 -238
  274. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  275. claude_mpm/agents/templates/research.json +0 -188
  276. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  277. claude_mpm/agents/templates/rust_engineer.json +0 -275
  278. claude_mpm/agents/templates/security.json +0 -202
  279. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  280. claude_mpm/agents/templates/ticketing.json +0 -177
  281. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  282. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  283. claude_mpm/agents/templates/version_control.json +0 -157
  284. claude_mpm/agents/templates/web_qa.json +0 -399
  285. claude_mpm/agents/templates/web_ui.json +0 -189
  286. claude_mpm/commands/mpm-tickets.md +0 -102
  287. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  288. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  289. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  290. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  291. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  292. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  293. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  294. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  295. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  296. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  297. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  298. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  299. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  300. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  301. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  302. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  303. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  304. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  305. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  306. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  307. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  308. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  309. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  310. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  311. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  312. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  313. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  314. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  315. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  316. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  317. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  318. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  319. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  320. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  321. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  322. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  323. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  324. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  325. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  326. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  327. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  328. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  329. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  330. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  331. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  332. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  333. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  334. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  335. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  336. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  337. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  338. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  339. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  340. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  341. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  342. claude_mpm/dashboard/static/built/react/events.js +0 -30
  343. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  344. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  345. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  346. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  347. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  348. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  349. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  350. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  351. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  352. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  353. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  354. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  355. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  356. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  357. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  358. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  359. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  360. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  361. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  362. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  363. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  364. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  365. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  366. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  367. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  368. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  369. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  370. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  371. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  372. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  373. claude_mpm/dashboard/static/events.html +0 -607
  374. claude_mpm/dashboard/static/index.html +0 -635
  375. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  376. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  377. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  378. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  379. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  380. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  381. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  382. claude_mpm/dashboard/static/legacy/files.html +0 -747
  383. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  384. claude_mpm/dashboard/static/monitors.html +0 -431
  385. claude_mpm/dashboard/static/production/events.html +0 -659
  386. claude_mpm/dashboard/static/production/main.html +0 -698
  387. claude_mpm/dashboard/static/production/monitors.html +0 -483
  388. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  389. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  390. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  391. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  392. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  393. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  394. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  395. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  396. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  397. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  398. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  399. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  400. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  401. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  402. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  403. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  404. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  405. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  406. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  407. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  408. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  409. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  410. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  411. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  412. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  413. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  414. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  415. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  416. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  417. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  418. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  419. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  420. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  421. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  422. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  423. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  424. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  425. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  426. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  427. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  428. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  429. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  430. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  431. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  435. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  436. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  437. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  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/rust/desktop-applications/SKILL.md +0 -226
  452. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  458. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  459. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  460. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  461. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  462. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  463. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  464. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  465. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  466. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  467. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  468. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  469. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  470. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  471. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  472. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  473. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  474. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  475. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  476. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  477. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  478. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  479. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  480. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  481. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/WHEEL +0 -0
  482. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/entry_points.txt +0 -0
  483. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/licenses/LICENSE +0 -0
  484. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/top_level.txt +0 -0
@@ -1,770 +0,0 @@
1
- # Tauri Framework
2
-
3
- Complete guide to building desktop applications with Tauri 2.x - the modern alternative to Electron with web UI + Rust backend.
4
-
5
- ## Architecture Overview
6
-
7
- ### What is Tauri?
8
-
9
- Tauri is a framework for building desktop applications using web technologies for the frontend (HTML, CSS, JavaScript) and Rust for the backend. Unlike Electron which bundles Chromium and Node.js (~100MB+), Tauri uses the OS's native webview (WebKit on macOS, WebView2 on Windows, WebKitGTK on Linux) resulting in 3-5MB bundles.
10
-
11
- **Core Architecture:**
12
- ```
13
- ┌─────────────────────────────────────────┐
14
- │ Frontend (Web) │
15
- │ React/Vue/Svelte/Vanilla │
16
- │ ├─ UI Rendering │
17
- │ ├─ User Interactions │
18
- │ └─ invoke() calls to backend │
19
- └──────────────┬──────────────────────────┘
20
- │ IPC (JSON)
21
- ┌──────────────▼──────────────────────────┐
22
- │ Tauri Core (Rust) │
23
- │ ├─ Command Handlers │
24
- │ ├─ Event System │
25
- │ ├─ State Management │
26
- │ └─ Plugin System │
27
- └──────────────┬──────────────────────────┘
28
-
29
- ┌──────────────▼──────────────────────────┐
30
- │ Native OS APIs │
31
- │ ├─ File System │
32
- │ ├─ Shell/Process │
33
- │ ├─ HTTP Client │
34
- │ ├─ System Tray │
35
- │ └─ Notifications │
36
- └─────────────────────────────────────────┘
37
- ```
38
-
39
- ### Project Structure
40
-
41
- ```
42
- my-tauri-app/
43
- ├─ src-tauri/ # Rust backend
44
- │ ├─ src/
45
- │ │ ├─ main.rs # Entry point, command registration
46
- │ │ ├─ commands/ # Command modules
47
- │ │ ├─ state/ # Application state
48
- │ │ └─ lib.rs # Optional library code
49
- │ ├─ Cargo.toml # Rust dependencies
50
- │ ├─ tauri.conf.json # Tauri configuration
51
- │ ├─ icons/ # App icons
52
- │ └─ capabilities/ # Security capabilities (v2)
53
- ├─ src/ # Frontend source
54
- │ ├─ App.tsx # Main React/Vue component
55
- │ ├─ components/
56
- │ ├─ styles/
57
- │ └─ main.tsx # Frontend entry
58
- ├─ package.json # Node dependencies
59
- └─ vite.config.ts # Vite configuration
60
- ```
61
-
62
- ## Setup and Installation
63
-
64
- ### Prerequisites
65
-
66
- ```bash
67
- # Rust toolchain (rustup.rs)
68
- curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
69
-
70
- # Node.js (for frontend tooling)
71
- # Install via nvm, fnm, or nodejs.org
72
-
73
- # Platform-specific requirements:
74
- # Windows: WebView2, Visual Studio Build Tools
75
- # macOS: Xcode Command Line Tools
76
- # Linux: webkit2gtk, build-essential
77
- ```
78
-
79
- ### Create New Tauri Project
80
-
81
- ```bash
82
- # Install Tauri CLI
83
- cargo install tauri-cli --version "^2.0.0"
84
-
85
- # Create project with wizard
86
- cargo create-tauri-app
87
-
88
- # Or with specific frontend:
89
- npm create tauri-app@latest
90
- # Select: Package manager (npm/yarn/pnpm)
91
- # Frontend framework (React/Vue/Svelte/Vanilla)
92
- # TypeScript (recommended: Yes)
93
- ```
94
-
95
- ### Development Workflow
96
-
97
- ```bash
98
- # Start development server (hot reload)
99
- cargo tauri dev
100
- # Opens app window + watches for changes
101
- # Frontend: Vite HMR
102
- # Backend: Cargo watch (rebuild on .rs changes)
103
-
104
- # Build for production
105
- cargo tauri build
106
- # Creates optimized bundle in src-tauri/target/release/bundle/
107
-
108
- # Run frontend only (testing UI)
109
- npm run dev
110
- ```
111
-
112
- ## IPC Communication
113
-
114
- ### Commands (Frontend → Backend)
115
-
116
- Commands are Rust functions exposed to the frontend via `#[tauri::command]`.
117
-
118
- **Basic Command:**
119
- ```rust
120
- // src-tauri/src/main.rs
121
- #[tauri::command]
122
- fn greet(name: &str) -> String {
123
- format!("Hello, {}!", name)
124
- }
125
-
126
- fn main() {
127
- tauri::Builder::default()
128
- .invoke_handler(tauri::generate_handler![greet])
129
- .run(tauri::generate_context!())
130
- .expect("error while running tauri application");
131
- }
132
- ```
133
-
134
- **Frontend Usage:**
135
- ```typescript
136
- // src/App.tsx
137
- import { invoke } from '@tauri-apps/api/core';
138
-
139
- async function handleGreet() {
140
- const message = await invoke<string>('greet', { name: 'World' });
141
- console.log(message); // "Hello, World!"
142
- }
143
- ```
144
-
145
- ### Advanced Commands with State
146
-
147
- ```rust
148
- use tauri::State;
149
- use std::sync::Mutex;
150
-
151
- struct AppState {
152
- counter: Mutex<i32>,
153
- }
154
-
155
- #[tauri::command]
156
- fn increment_counter(state: State<AppState>) -> i32 {
157
- let mut counter = state.counter.lock().unwrap();
158
- *counter += 1;
159
- *counter
160
- }
161
-
162
- #[tauri::command]
163
- fn get_counter(state: State<AppState>) -> i32 {
164
- *state.counter.lock().unwrap()
165
- }
166
-
167
- fn main() {
168
- tauri::Builder::default()
169
- .manage(AppState {
170
- counter: Mutex::new(0),
171
- })
172
- .invoke_handler(tauri::generate_handler![
173
- increment_counter,
174
- get_counter
175
- ])
176
- .run(tauri::generate_context!())
177
- .expect("error while running tauri application");
178
- }
179
- ```
180
-
181
- **Frontend:**
182
- ```typescript
183
- import { invoke } from '@tauri-apps/api/core';
184
-
185
- const count = await invoke<number>('increment_counter');
186
- const current = await invoke<number>('get_counter');
187
- ```
188
-
189
- ### Async Commands with Tokio
190
-
191
- ```rust
192
- use tokio::time::{sleep, Duration};
193
-
194
- #[tauri::command]
195
- async fn fetch_data(url: String) -> Result<String, String> {
196
- let client = reqwest::Client::new();
197
- let response = client
198
- .get(&url)
199
- .send()
200
- .await
201
- .map_err(|e| e.to_string())?;
202
-
203
- response.text().await.map_err(|e| e.to_string())
204
- }
205
-
206
- #[tauri::command]
207
- async fn long_running_task() -> Result<String, String> {
208
- sleep(Duration::from_secs(5)).await;
209
- Ok("Task completed".to_string())
210
- }
211
- ```
212
-
213
- ### Error Handling
214
-
215
- ```rust
216
- use serde::{Serialize, Deserialize};
217
-
218
- #[derive(Debug, Serialize, Deserialize)]
219
- struct ApiError {
220
- message: String,
221
- code: u32,
222
- }
223
-
224
- impl std::fmt::Display for ApiError {
225
- fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
226
- write!(f, "{}", self.message)
227
- }
228
- }
229
-
230
- #[tauri::command]
231
- fn risky_operation(value: i32) -> Result<String, ApiError> {
232
- if value < 0 {
233
- return Err(ApiError {
234
- message: "Value must be positive".to_string(),
235
- code: 400,
236
- });
237
- }
238
- Ok(format!("Success: {}", value))
239
- }
240
- ```
241
-
242
- **Frontend Error Handling:**
243
- ```typescript
244
- try {
245
- const result = await invoke<string>('risky_operation', { value: -1 });
246
- } catch (error) {
247
- console.error('Command failed:', error);
248
- // error is serialized ApiError
249
- }
250
- ```
251
-
252
- ### Events (Backend → Frontend)
253
-
254
- Events enable pushing data from backend to frontend.
255
-
256
- **Backend Emit:**
257
- ```rust
258
- use tauri::{Emitter, Manager};
259
-
260
- #[tauri::command]
261
- async fn start_monitoring(app: tauri::AppHandle) {
262
- tokio::spawn(async move {
263
- loop {
264
- tokio::time::sleep(Duration::from_secs(1)).await;
265
- app.emit("status-update", "Running").unwrap();
266
- }
267
- });
268
- }
269
- ```
270
-
271
- **Frontend Listen:**
272
- ```typescript
273
- import { listen } from '@tauri-apps/api/event';
274
-
275
- const unlisten = await listen<string>('status-update', (event) => {
276
- console.log('Status:', event.payload);
277
- });
278
-
279
- // Later: cleanup
280
- unlisten();
281
- ```
282
-
283
- ## Native API Access
284
-
285
- ### File System
286
-
287
- ```rust
288
- use tauri::api::dialog::blocking::FileDialogBuilder;
289
- use std::fs;
290
-
291
- #[tauri::command]
292
- fn open_file_dialog() -> Option<String> {
293
- FileDialogBuilder::new().pick_file()
294
- .map(|path| path.to_string_lossy().to_string())
295
- }
296
-
297
- #[tauri::command]
298
- fn read_file_content(path: String) -> Result<String, String> {
299
- fs::read_to_string(path).map_err(|e| e.to_string())
300
- }
301
-
302
- #[tauri::command]
303
- fn write_file_content(path: String, content: String) -> Result<(), String> {
304
- fs::write(path, content).map_err(|e| e.to_string())
305
- }
306
- ```
307
-
308
- **Frontend:**
309
- ```typescript
310
- import { invoke } from '@tauri-apps/api/core';
311
-
312
- async function openFile() {
313
- const path = await invoke<string | null>('open_file_dialog');
314
- if (path) {
315
- const content = await invoke<string>('read_file_content', { path });
316
- console.log(content);
317
- }
318
- }
319
- ```
320
-
321
- ### System Tray
322
-
323
- ```rust
324
- use tauri::{
325
- menu::{Menu, MenuItem},
326
- tray::TrayIconBuilder,
327
- Manager,
328
- };
329
-
330
- fn main() {
331
- tauri::Builder::default()
332
- .setup(|app| {
333
- let quit = MenuItem::with_id(app, "quit", "Quit", true, None::<&str>)?;
334
- let menu = Menu::with_items(app, &[&quit])?;
335
-
336
- let _tray = TrayIconBuilder::new()
337
- .menu(&menu)
338
- .on_menu_event(|app, event| match event.id.as_ref() {
339
- "quit" => {
340
- app.exit(0);
341
- }
342
- _ => {}
343
- })
344
- .build(app)?;
345
-
346
- Ok(())
347
- })
348
- .run(tauri::generate_context!())
349
- .expect("error while running tauri application");
350
- }
351
- ```
352
-
353
- ### Notifications
354
-
355
- ```rust
356
- use tauri::Notification;
357
-
358
- #[tauri::command]
359
- fn send_notification(app: tauri::AppHandle, message: String) -> Result<(), String> {
360
- Notification::new(&app.config().identifier)
361
- .title("My App")
362
- .body(message)
363
- .show()
364
- .map_err(|e| e.to_string())
365
- }
366
- ```
367
-
368
- ### Shell/Process Execution
369
-
370
- ```rust
371
- use tauri::api::process::{Command, CommandEvent};
372
-
373
- #[tauri::command]
374
- async fn run_command(program: String, args: Vec<String>) -> Result<String, String> {
375
- let (mut rx, _child) = Command::new(program)
376
- .args(args)
377
- .spawn()
378
- .map_err(|e| e.to_string())?;
379
-
380
- let mut output = String::new();
381
- while let Some(event) = rx.recv().await {
382
- match event {
383
- CommandEvent::Stdout(line) => output.push_str(&line),
384
- CommandEvent::Stderr(line) => output.push_str(&line),
385
- CommandEvent::Terminated(_) => break,
386
- _ => {}
387
- }
388
- }
389
- Ok(output)
390
- }
391
- ```
392
-
393
- ## Configuration
394
-
395
- ### tauri.conf.json
396
-
397
- ```json
398
- {
399
- "$schema": "../node_modules/@tauri-apps/cli/schema.json",
400
- "productName": "My App",
401
- "version": "1.0.0",
402
- "identifier": "com.mycompany.myapp",
403
- "build": {
404
- "beforeDevCommand": "npm run dev",
405
- "beforeBuildCommand": "npm run build",
406
- "devUrl": "http://localhost:5173",
407
- "frontendDist": "../dist"
408
- },
409
- "app": {
410
- "windows": [
411
- {
412
- "title": "My App",
413
- "width": 1200,
414
- "height": 800,
415
- "resizable": true,
416
- "fullscreen": false,
417
- "minWidth": 800,
418
- "minHeight": 600
419
- }
420
- ],
421
- "security": {
422
- "csp": "default-src 'self'; img-src 'self' https: data:;"
423
- }
424
- },
425
- "bundle": {
426
- "active": true,
427
- "targets": "all",
428
- "icon": [
429
- "icons/32x32.png",
430
- "icons/128x128.png",
431
- "icons/icon.icns",
432
- "icons/icon.ico"
433
- ],
434
- "macOS": {
435
- "minimumSystemVersion": "10.13"
436
- },
437
- "windows": {
438
- "webviewInstallMode": {
439
- "type": "downloadBootstrapper"
440
- }
441
- }
442
- }
443
- }
444
- ```
445
-
446
- ### Security Configuration
447
-
448
- **Content Security Policy (CSP):**
449
- ```json
450
- {
451
- "app": {
452
- "security": {
453
- "csp": "default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline'; img-src 'self' https: data:; connect-src 'self' https://api.myapp.com"
454
- }
455
- }
456
- }
457
- ```
458
-
459
- **Capabilities (Tauri v2):**
460
- ```json
461
- // src-tauri/capabilities/default.json
462
- {
463
- "identifier": "default",
464
- "description": "Default capabilities",
465
- "windows": ["main"],
466
- "permissions": [
467
- "core:default",
468
- "fs:allow-read-text-file",
469
- "fs:allow-write-text-file",
470
- "dialog:allow-open",
471
- "dialog:allow-save",
472
- "shell:allow-execute"
473
- ]
474
- }
475
- ```
476
-
477
- ## Advanced Patterns
478
-
479
- ### Window Management
480
-
481
- ```rust
482
- use tauri::{Manager, WebviewUrl, WebviewWindowBuilder};
483
-
484
- #[tauri::command]
485
- async fn open_new_window(app: tauri::AppHandle) -> Result<(), String> {
486
- WebviewWindowBuilder::new(
487
- &app,
488
- "new-window",
489
- WebviewUrl::App("index.html".into())
490
- )
491
- .title("New Window")
492
- .inner_size(800.0, 600.0)
493
- .build()
494
- .map_err(|e| e.to_string())?;
495
-
496
- Ok(())
497
- }
498
-
499
- #[tauri::command]
500
- fn close_window(window: tauri::Window) -> Result<(), String> {
501
- window.close().map_err(|e| e.to_string())
502
- }
503
- ```
504
-
505
- ### Custom Protocol
506
-
507
- ```rust
508
- use tauri::{http::ResponseBuilder, Manager};
509
-
510
- fn main() {
511
- tauri::Builder::default()
512
- .setup(|app| {
513
- app.handle().plugin(
514
- tauri_plugin_localhost::Builder::new()
515
- .build(),
516
- )?;
517
- Ok(())
518
- })
519
- .register_uri_scheme_protocol("myapp", |_app, request| {
520
- // Handle custom myapp:// protocol
521
- ResponseBuilder::new()
522
- .status(200)
523
- .body(b"Custom protocol response".to_vec())
524
- .map_err(Into::into)
525
- })
526
- .run(tauri::generate_context!())
527
- .expect("error while running tauri application");
528
- }
529
- ```
530
-
531
- ### Plugin Development
532
-
533
- ```rust
534
- use tauri::{plugin::Plugin, Runtime};
535
-
536
- pub struct MyPlugin<R: Runtime> {
537
- _marker: std::marker::PhantomData<R>,
538
- }
539
-
540
- impl<R: Runtime> Plugin<R> for MyPlugin<R> {
541
- fn name(&self) -> &'static str {
542
- "my-plugin"
543
- }
544
-
545
- fn initialize(&mut self, app: &tauri::AppHandle<R>, _config: serde_json::Value) -> tauri::plugin::Result<()> {
546
- // Initialize plugin
547
- Ok(())
548
- }
549
- }
550
-
551
- // Usage in main.rs
552
- fn main() {
553
- tauri::Builder::default()
554
- .plugin(MyPlugin { _marker: std::marker::PhantomData })
555
- .run(tauri::generate_context!())
556
- .expect("error while running tauri application");
557
- }
558
- ```
559
-
560
- ## Performance Optimization
561
-
562
- ### Bundle Size Reduction
563
-
564
- **Cargo.toml optimizations:**
565
- ```toml
566
- [profile.release]
567
- opt-level = "z" # Optimize for size
568
- lto = true # Link-time optimization
569
- codegen-units = 1 # Better optimization
570
- panic = "abort" # Remove panic unwinding code
571
- strip = true # Strip symbols
572
- ```
573
-
574
- ### Lazy Loading
575
-
576
- ```typescript
577
- // Frontend: Code splitting
578
- const HeavyComponent = lazy(() => import('./HeavyComponent'));
579
-
580
- // Backend: Lazy state initialization
581
- use once_cell::sync::Lazy;
582
- static EXPENSIVE_RESOURCE: Lazy<ExpensiveType> = Lazy::new(|| {
583
- // Initialize only when first accessed
584
- ExpensiveType::new()
585
- });
586
- ```
587
-
588
- ### Debouncing IPC Calls
589
-
590
- ```typescript
591
- import { debounce } from 'lodash';
592
-
593
- const debouncedSearch = debounce(async (query: string) => {
594
- const results = await invoke('search', { query });
595
- setResults(results);
596
- }, 300);
597
- ```
598
-
599
- ## Build and Distribution
600
-
601
- ### Build Commands
602
-
603
- ```bash
604
- # Development build
605
- cargo tauri dev
606
-
607
- # Production build (current platform)
608
- cargo tauri build
609
-
610
- # Build with debug info
611
- cargo tauri build --debug
612
-
613
- # Specific bundle type
614
- cargo tauri build --bundles deb,appimage # Linux
615
- cargo tauri build --bundles dmg,app # macOS
616
- cargo tauri build --bundles msi,nsis # Windows
617
- ```
618
-
619
- ### Code Signing
620
-
621
- **macOS:**
622
- ```bash
623
- # Sign app
624
- codesign --deep --force --verify --verbose \
625
- --sign "Developer ID Application: Your Name" \
626
- target/release/bundle/macos/MyApp.app
627
-
628
- # Notarize
629
- xcrun notarytool submit target/release/bundle/dmg/MyApp.dmg \
630
- --apple-id "your@email.com" \
631
- --password "app-specific-password" \
632
- --team-id "TEAMID"
633
- ```
634
-
635
- **Windows:**
636
- ```powershell
637
- # Sign with signtool.exe
638
- signtool sign /tr http://timestamp.digicert.com /td sha256 `
639
- /fd sha256 /a "target\release\MyApp.exe"
640
- ```
641
-
642
- ### Auto-Updates
643
-
644
- ```rust
645
- // Install tauri-plugin-updater
646
- use tauri_plugin_updater::UpdaterExt;
647
-
648
- fn main() {
649
- tauri::Builder::default()
650
- .plugin(tauri_plugin_updater::init())
651
- .setup(|app| {
652
- let handle = app.handle().clone();
653
- tauri::async_runtime::spawn(async move {
654
- let update = handle.updater().check().await;
655
- // Handle update
656
- });
657
- Ok(())
658
- })
659
- .run(tauri::generate_context!())
660
- .expect("error while running tauri application");
661
- }
662
- ```
663
-
664
- ## Production Examples
665
-
666
- ### File Manager Command
667
- ```rust
668
- use serde::{Deserialize, Serialize};
669
- use std::fs;
670
- use std::path::PathBuf;
671
-
672
- #[derive(Serialize, Deserialize)]
673
- struct FileEntry {
674
- name: String,
675
- path: String,
676
- is_dir: bool,
677
- size: u64,
678
- }
679
-
680
- #[tauri::command]
681
- fn list_directory(path: String) -> Result<Vec<FileEntry>, String> {
682
- let dir_path = PathBuf::from(path);
683
-
684
- if !dir_path.exists() {
685
- return Err("Directory does not exist".to_string());
686
- }
687
-
688
- let mut entries = Vec::new();
689
-
690
- for entry in fs::read_dir(dir_path).map_err(|e| e.to_string())? {
691
- let entry = entry.map_err(|e| e.to_string())?;
692
- let metadata = entry.metadata().map_err(|e| e.to_string())?;
693
-
694
- entries.push(FileEntry {
695
- name: entry.file_name().to_string_lossy().to_string(),
696
- path: entry.path().to_string_lossy().to_string(),
697
- is_dir: metadata.is_dir(),
698
- size: metadata.len(),
699
- });
700
- }
701
-
702
- Ok(entries)
703
- }
704
- ```
705
-
706
- ### Database Integration
707
- ```rust
708
- use sqlx::{SqlitePool, FromRow};
709
- use tauri::State;
710
-
711
- #[derive(FromRow, Serialize)]
712
- struct User {
713
- id: i64,
714
- name: String,
715
- email: String,
716
- }
717
-
718
- struct DbState {
719
- pool: SqlitePool,
720
- }
721
-
722
- #[tauri::command]
723
- async fn get_users(state: State<'_, DbState>) -> Result<Vec<User>, String> {
724
- sqlx::query_as::<_, User>("SELECT id, name, email FROM users")
725
- .fetch_all(&state.pool)
726
- .await
727
- .map_err(|e| e.to_string())
728
- }
729
-
730
- #[tokio::main]
731
- async fn main() {
732
- let pool = SqlitePool::connect("sqlite://app.db")
733
- .await
734
- .expect("Failed to connect to database");
735
-
736
- tauri::Builder::default()
737
- .manage(DbState { pool })
738
- .invoke_handler(tauri::generate_handler![get_users])
739
- .run(tauri::generate_context!())
740
- .expect("error while running tauri application");
741
- }
742
- ```
743
-
744
- ## Debugging
745
-
746
- ```bash
747
- # Enable Rust backtraces
748
- RUST_BACKTRACE=1 cargo tauri dev
749
-
750
- # Open DevTools
751
- # macOS/Linux: Cmd/Ctrl + Shift + I
752
- # Or programmatically:
753
- ```
754
-
755
- ```rust
756
- #[cfg(debug_assertions)]
757
- window.open_devtools();
758
- ```
759
-
760
- **Console logging from Rust:**
761
- ```rust
762
- println!("Debug: {:?}", value); // Appears in terminal
763
- ```
764
-
765
- **Frontend console:**
766
- ```typescript
767
- console.log('Frontend log'); // Appears in DevTools
768
- ```
769
-
770
- This comprehensive guide covers Tauri fundamentals through advanced patterns. Combine with architecture-patterns.md for structure, state-management.md for complex state, and platform-integration.md for OS-specific features.