claude-mpm 4.21.0__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 (497) 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 +14 -2
  63. claude_mpm/commands/mpm-init.md +27 -2
  64. claude_mpm/commands/mpm-monitor.md +9 -0
  65. claude_mpm/commands/mpm-session-resume.md +381 -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 +11 -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/base.py +26 -11
  162. claude_mpm/services/core/interfaces/__init__.py +1 -3
  163. claude_mpm/services/core/interfaces/health.py +1 -4
  164. claude_mpm/services/core/models/__init__.py +2 -11
  165. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  166. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  167. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  168. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  169. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  170. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  171. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  172. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  173. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  174. claude_mpm/services/event_bus/direct_relay.py +3 -3
  175. claude_mpm/services/event_bus/event_bus.py +36 -3
  176. claude_mpm/services/event_bus/relay.py +23 -7
  177. claude_mpm/services/events/consumers/logging.py +1 -2
  178. claude_mpm/services/git/__init__.py +21 -0
  179. claude_mpm/services/git/git_operations_service.py +494 -0
  180. claude_mpm/services/github/__init__.py +21 -0
  181. claude_mpm/services/github/github_cli_service.py +397 -0
  182. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  183. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  184. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  185. claude_mpm/services/instructions/__init__.py +9 -0
  186. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  187. claude_mpm/services/local_ops/__init__.py +3 -13
  188. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  189. claude_mpm/services/local_ops/health_manager.py +1 -4
  190. claude_mpm/services/local_ops/process_manager.py +1 -1
  191. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  192. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  193. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  194. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  195. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  196. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  197. claude_mpm/services/memory/failure_tracker.py +19 -4
  198. claude_mpm/services/memory/optimizer.py +1 -1
  199. claude_mpm/services/model/model_router.py +8 -9
  200. claude_mpm/services/monitor/daemon.py +1 -1
  201. claude_mpm/services/monitor/server.py +2 -2
  202. claude_mpm/services/native_agent_converter.py +356 -0
  203. claude_mpm/services/port_manager.py +1 -1
  204. claude_mpm/services/pr/__init__.py +14 -0
  205. claude_mpm/services/pr/pr_template_service.py +329 -0
  206. claude_mpm/services/project/documentation_manager.py +2 -1
  207. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  208. claude_mpm/services/runner_configuration_service.py +1 -0
  209. claude_mpm/services/self_upgrade_service.py +165 -7
  210. claude_mpm/services/skills/__init__.py +18 -0
  211. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  212. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  213. claude_mpm/services/skills_config.py +547 -0
  214. claude_mpm/services/skills_deployer.py +955 -0
  215. claude_mpm/services/socketio/handlers/connection.py +1 -1
  216. claude_mpm/services/socketio/handlers/git.py +2 -2
  217. claude_mpm/services/socketio/server/core.py +1 -4
  218. claude_mpm/services/socketio/server/main.py +1 -3
  219. claude_mpm/services/system_instructions_service.py +1 -3
  220. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  221. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  222. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  223. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  224. claude_mpm/services/unified/unified_deployment.py +1 -5
  225. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  226. claude_mpm/services/visualization/__init__.py +1 -5
  227. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  228. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  229. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  230. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  231. claude_mpm/skills/skills_registry.py +0 -1
  232. claude_mpm/templates/questions/__init__.py +38 -0
  233. claude_mpm/templates/questions/base.py +193 -0
  234. claude_mpm/templates/questions/pr_strategy.py +311 -0
  235. claude_mpm/templates/questions/project_init.py +385 -0
  236. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  237. claude_mpm/tools/__main__.py +8 -8
  238. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  239. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  240. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  241. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  242. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  243. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  244. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  245. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  246. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  247. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  248. claude_mpm/utils/agent_dependency_loader.py +80 -13
  249. claude_mpm/utils/dependency_cache.py +3 -1
  250. claude_mpm/utils/gitignore.py +241 -0
  251. claude_mpm/utils/log_cleanup.py +3 -3
  252. claude_mpm/utils/progress.py +383 -0
  253. claude_mpm/utils/robust_installer.py +3 -5
  254. claude_mpm/utils/structured_questions.py +619 -0
  255. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/METADATA +429 -59
  256. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/RECORD +264 -427
  257. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  258. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  259. claude_mpm/agents/templates/agent-manager.json +0 -273
  260. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  261. claude_mpm/agents/templates/api_qa.json +0 -180
  262. claude_mpm/agents/templates/clerk-ops.json +0 -235
  263. claude_mpm/agents/templates/code_analyzer.json +0 -101
  264. claude_mpm/agents/templates/content-agent.json +0 -358
  265. claude_mpm/agents/templates/dart_engineer.json +0 -307
  266. claude_mpm/agents/templates/data_engineer.json +0 -225
  267. claude_mpm/agents/templates/documentation.json +0 -211
  268. claude_mpm/agents/templates/engineer.json +0 -210
  269. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  270. claude_mpm/agents/templates/golang_engineer.json +0 -270
  271. claude_mpm/agents/templates/imagemagick.json +0 -264
  272. claude_mpm/agents/templates/java_engineer.json +0 -346
  273. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  274. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  275. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  276. claude_mpm/agents/templates/memory_manager.json +0 -158
  277. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  278. claude_mpm/agents/templates/ops.json +0 -185
  279. claude_mpm/agents/templates/php-engineer.json +0 -287
  280. claude_mpm/agents/templates/product_owner.json +0 -338
  281. claude_mpm/agents/templates/project_organizer.json +0 -140
  282. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  283. claude_mpm/agents/templates/python_engineer.json +0 -387
  284. claude_mpm/agents/templates/qa.json +0 -242
  285. claude_mpm/agents/templates/react_engineer.json +0 -238
  286. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  287. claude_mpm/agents/templates/research.json +0 -188
  288. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  289. claude_mpm/agents/templates/rust_engineer.json +0 -275
  290. claude_mpm/agents/templates/security.json +0 -202
  291. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  292. claude_mpm/agents/templates/ticketing.json +0 -177
  293. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  294. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  295. claude_mpm/agents/templates/version_control.json +0 -157
  296. claude_mpm/agents/templates/web_qa.json +0 -399
  297. claude_mpm/agents/templates/web_ui.json +0 -189
  298. claude_mpm/commands/mpm-tickets.md +0 -102
  299. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  300. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  301. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  302. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  303. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  304. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  305. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  306. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  307. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  308. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  309. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  310. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  311. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  312. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  313. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  314. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  315. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  316. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  317. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  318. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  319. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  320. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  321. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  322. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  323. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  324. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  325. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  326. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  327. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  328. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  329. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  330. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  331. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  332. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  333. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  334. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  335. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  336. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  337. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  338. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  339. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  340. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  341. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  342. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  343. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  344. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  345. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  346. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  347. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  348. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  349. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  350. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  351. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  352. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  353. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  354. claude_mpm/dashboard/static/built/react/events.js +0 -30
  355. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  356. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  357. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  358. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  359. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  360. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  361. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  362. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  363. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  364. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  365. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  366. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  367. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  368. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  369. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  370. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  371. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  372. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  373. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  374. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  375. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  376. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  377. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  378. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  379. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  380. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  381. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  382. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  383. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  384. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  385. claude_mpm/dashboard/static/events.html +0 -607
  386. claude_mpm/dashboard/static/index.html +0 -635
  387. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  388. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  389. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  390. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  391. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  392. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  393. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  394. claude_mpm/dashboard/static/legacy/files.html +0 -747
  395. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  396. claude_mpm/dashboard/static/monitors.html +0 -431
  397. claude_mpm/dashboard/static/production/events.html +0 -659
  398. claude_mpm/dashboard/static/production/main.html +0 -698
  399. claude_mpm/dashboard/static/production/monitors.html +0 -483
  400. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  401. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  402. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  403. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  404. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  405. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  406. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  407. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  408. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  409. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  410. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  411. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  412. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  413. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  414. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  415. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  416. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  417. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  418. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  419. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  420. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  421. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  422. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  423. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  424. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  425. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  426. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  427. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  428. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  429. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  430. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  431. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  432. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  433. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  434. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  435. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  436. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  437. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  438. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  439. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  440. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  441. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  442. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  443. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  444. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  445. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  446. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  447. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  448. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  449. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  450. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  451. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  452. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  453. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  454. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  455. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  456. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  457. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  458. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  459. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  460. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  461. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  462. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  463. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  464. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  465. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  466. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  467. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  468. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  469. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  470. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  471. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  472. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  473. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  474. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  475. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  476. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  477. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  478. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  479. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  480. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  481. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  482. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  483. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  484. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  485. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  486. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  487. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  488. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  489. claude_mpm/tools/code_tree_analyzer.py +0 -1825
  490. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  491. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  492. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  493. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  494. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/WHEEL +0 -0
  495. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/entry_points.txt +0 -0
  496. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/licenses/LICENSE +0 -0
  497. {claude_mpm-4.21.0.dist-info → claude_mpm-5.0.2.dist-info}/top_level.txt +0 -0
@@ -1,775 +0,0 @@
1
- # Platform Integration
2
-
3
- Comprehensive guide to integrating with native platform features across Windows, macOS, and Linux in Rust desktop applications.
4
-
5
- ## File System Access
6
-
7
- ### File Dialogs
8
-
9
- ```rust
10
- use tauri::api::dialog::{FileDialogBuilder, MessageDialogBuilder, MessageDialogKind};
11
-
12
- #[tauri::command]
13
- async fn open_file_dialog() -> Result<Option<String>, String> {
14
- let path = FileDialogBuilder::new()
15
- .add_filter("Text Files", &["txt", "md"])
16
- .add_filter("All Files", &["*"])
17
- .set_title("Select a file")
18
- .pick_file();
19
-
20
- Ok(path.map(|p| p.to_string_lossy().to_string()))
21
- }
22
-
23
- #[tauri::command]
24
- async fn open_folder_dialog() -> Result<Option<String>, String> {
25
- let path = FileDialogBuilder::new()
26
- .set_title("Select a folder")
27
- .pick_folder();
28
-
29
- Ok(path.map(|p| p.to_string_lossy().to_string()))
30
- }
31
-
32
- #[tauri::command]
33
- async fn save_file_dialog() -> Result<Option<String>, String> {
34
- let path = FileDialogBuilder::new()
35
- .add_filter("JSON Files", &["json"])
36
- .set_file_name("untitled.json")
37
- .save_file();
38
-
39
- Ok(path.map(|p| p.to_string_lossy().to_string()))
40
- }
41
-
42
- #[tauri::command]
43
- async fn show_message(title: String, message: String) -> Result<(), String> {
44
- MessageDialogBuilder::new(title, message)
45
- .kind(MessageDialogKind::Info)
46
- .show();
47
-
48
- Ok(())
49
- }
50
-
51
- #[tauri::command]
52
- async fn confirm_dialog(title: String, message: String) -> Result<bool, String> {
53
- let confirmed = MessageDialogBuilder::new(title, message)
54
- .kind(MessageDialogKind::Warning)
55
- .buttons(tauri::api::dialog::MessageDialogButtons::OkCancel)
56
- .show();
57
-
58
- Ok(confirmed)
59
- }
60
- ```
61
-
62
- ### Safe File System Operations
63
-
64
- ```rust
65
- use std::path::{Path, PathBuf};
66
- use std::fs;
67
-
68
- // Validate file paths to prevent directory traversal
69
- fn validate_path(path: &str, base_dir: &Path) -> Result<PathBuf, String> {
70
- let path = Path::new(path);
71
-
72
- // Canonicalize to resolve .. and symlinks
73
- let canonical = path
74
- .canonicalize()
75
- .map_err(|_| "Invalid path".to_string())?;
76
-
77
- // Ensure path is within base directory
78
- if !canonical.starts_with(base_dir) {
79
- return Err("Path outside allowed directory".to_string());
80
- }
81
-
82
- Ok(canonical)
83
- }
84
-
85
- #[tauri::command]
86
- async fn read_file_safe(app: tauri::AppHandle, relative_path: String) -> Result<String, String> {
87
- let app_dir = app
88
- .path()
89
- .app_data_dir()
90
- .map_err(|e| e.to_string())?;
91
-
92
- let file_path = validate_path(&relative_path, &app_dir)?;
93
-
94
- fs::read_to_string(file_path).map_err(|e| e.to_string())
95
- }
96
-
97
- #[tauri::command]
98
- async fn write_file_safe(
99
- app: tauri::AppHandle,
100
- relative_path: String,
101
- content: String,
102
- ) -> Result<(), String> {
103
- let app_dir = app
104
- .path()
105
- .app_data_dir()
106
- .map_err(|e| e.to_string())?;
107
-
108
- // Ensure directory exists
109
- fs::create_dir_all(&app_dir).map_err(|e| e.to_string())?;
110
-
111
- let file_path = app_dir.join(&relative_path);
112
-
113
- // Security check
114
- let canonical = file_path
115
- .canonicalize()
116
- .or_else(|_| {
117
- // File doesn't exist yet, validate parent
118
- file_path
119
- .parent()
120
- .ok_or("Invalid path")?
121
- .canonicalize()
122
- .map(|p| p.join(file_path.file_name().unwrap()))
123
- })
124
- .map_err(|_| "Invalid path".to_string())?;
125
-
126
- if !canonical.starts_with(&app_dir) {
127
- return Err("Path outside allowed directory".to_string());
128
- }
129
-
130
- fs::write(canonical, content).map_err(|e| e.to_string())
131
- }
132
- ```
133
-
134
- ### File Watching
135
-
136
- ```rust
137
- use notify::{Watcher, RecursiveMode, Event};
138
- use std::sync::mpsc::channel;
139
- use std::time::Duration;
140
-
141
- struct FileWatcher {
142
- watcher: notify::RecommendedWatcher,
143
- }
144
-
145
- impl FileWatcher {
146
- fn new(app_handle: tauri::AppHandle) -> Result<Self, String> {
147
- let (tx, rx) = channel();
148
-
149
- let mut watcher = notify::recommended_watcher(tx)
150
- .map_err(|e| e.to_string())?;
151
-
152
- // Spawn task to handle events
153
- tokio::spawn(async move {
154
- while let Ok(event) = rx.recv() {
155
- if let Ok(Event { kind, paths, .. }) = event {
156
- let _ = app_handle.emit("file-changed", FileChangeEvent {
157
- kind: format!("{:?}", kind),
158
- paths: paths.iter().map(|p| p.to_string_lossy().to_string()).collect(),
159
- });
160
- }
161
- }
162
- });
163
-
164
- Ok(Self { watcher })
165
- }
166
-
167
- fn watch(&mut self, path: &str) -> Result<(), String> {
168
- self.watcher
169
- .watch(Path::new(path), RecursiveMode::Recursive)
170
- .map_err(|e| e.to_string())
171
- }
172
-
173
- fn unwatch(&mut self, path: &str) -> Result<(), String> {
174
- self.watcher
175
- .unwatch(Path::new(path))
176
- .map_err(|e| e.to_string())
177
- }
178
- }
179
-
180
- #[derive(Clone, serde::Serialize)]
181
- struct FileChangeEvent {
182
- kind: String,
183
- paths: Vec<String>,
184
- }
185
-
186
- #[tauri::command]
187
- fn watch_directory(
188
- watcher: tauri::State<FileWatcher>,
189
- path: String,
190
- ) -> Result<(), String> {
191
- watcher.inner().lock().unwrap().watch(&path)
192
- }
193
- ```
194
-
195
- ## System Tray Integration
196
-
197
- ### Cross-Platform System Tray
198
-
199
- ```rust
200
- use tauri::{
201
- menu::{Menu, MenuItem, Submenu},
202
- tray::{TrayIconBuilder, TrayIconEvent},
203
- Manager, Runtime,
204
- };
205
-
206
- fn create_tray<R: Runtime>(app: &tauri::AppHandle<R>) -> Result<(), Box<dyn std::error::Error>> {
207
- // Create menu items
208
- let show_item = MenuItem::with_id(app, "show", "Show Window", true, None::<&str>)?;
209
- let hide_item = MenuItem::with_id(app, "hide", "Hide Window", true, None::<&str>)?;
210
- let quit_item = MenuItem::with_id(app, "quit", "Quit", true, None::<&str>)?;
211
-
212
- // Create submenu
213
- let settings_menu = Submenu::with_items(
214
- app,
215
- "Settings",
216
- true,
217
- &[
218
- &MenuItem::with_id(app, "preferences", "Preferences", true, None::<&str>)?,
219
- &MenuItem::with_id(app, "about", "About", true, None::<&str>)?,
220
- ],
221
- )?;
222
-
223
- // Create menu
224
- let menu = Menu::with_items(app, &[&show_item, &hide_item, &settings_menu, &quit_item])?;
225
-
226
- // Build tray icon
227
- let _tray = TrayIconBuilder::new()
228
- .icon(app.default_window_icon().unwrap().clone())
229
- .menu(&menu)
230
- .tooltip("My Application")
231
- .on_menu_event(|app, event| match event.id.as_ref() {
232
- "show" => {
233
- if let Some(window) = app.get_webview_window("main") {
234
- let _ = window.show();
235
- let _ = window.set_focus();
236
- }
237
- }
238
- "hide" => {
239
- if let Some(window) = app.get_webview_window("main") {
240
- let _ = window.hide();
241
- }
242
- }
243
- "quit" => {
244
- app.exit(0);
245
- }
246
- "preferences" => {
247
- // Open preferences window
248
- println!("Open preferences");
249
- }
250
- "about" => {
251
- // Show about dialog
252
- println!("Show about dialog");
253
- }
254
- _ => {}
255
- })
256
- .on_tray_icon_event(|tray, event| {
257
- if let TrayIconEvent::Click { .. } = event {
258
- // Handle tray icon click
259
- let app = tray.app_handle();
260
- if let Some(window) = app.get_webview_window("main") {
261
- if window.is_visible().unwrap_or(false) {
262
- let _ = window.hide();
263
- } else {
264
- let _ = window.show();
265
- let _ = window.set_focus();
266
- }
267
- }
268
- }
269
- })
270
- .build(app)?;
271
-
272
- Ok(())
273
- }
274
-
275
- fn main() {
276
- tauri::Builder::default()
277
- .setup(|app| {
278
- create_tray(app.handle())?;
279
- Ok(())
280
- })
281
- .run(tauri::generate_context!())
282
- .expect("error while running tauri application");
283
- }
284
- ```
285
-
286
- ### Dynamic Tray Menu Updates
287
-
288
- ```rust
289
- use std::sync::Mutex;
290
-
291
- struct TrayState {
292
- is_recording: Mutex<bool>,
293
- }
294
-
295
- #[tauri::command]
296
- fn toggle_recording(
297
- app: tauri::AppHandle,
298
- state: tauri::State<TrayState>,
299
- ) -> Result<(), String> {
300
- let mut is_recording = state.is_recording.lock().unwrap();
301
- *is_recording = !*is_recording;
302
-
303
- // Update tray menu
304
- let tray = app.tray_by_id("main").ok_or("Tray not found")?;
305
-
306
- let menu_item = tray
307
- .get_item("toggle_recording")
308
- .ok_or("Menu item not found")?;
309
-
310
- menu_item
311
- .set_text(if *is_recording {
312
- "Stop Recording"
313
- } else {
314
- "Start Recording"
315
- })
316
- .map_err(|e| e.to_string())?;
317
-
318
- Ok(())
319
- }
320
- ```
321
-
322
- ## Native Notifications
323
-
324
- ### Cross-Platform Notifications
325
-
326
- ```rust
327
- use tauri::Notification;
328
-
329
- #[tauri::command]
330
- fn send_notification(
331
- app: tauri::AppHandle,
332
- title: String,
333
- body: String,
334
- ) -> Result<(), String> {
335
- Notification::new(&app.config().identifier)
336
- .title(title)
337
- .body(body)
338
- .icon("icon")
339
- .show()
340
- .map_err(|e| e.to_string())
341
- }
342
-
343
- #[tauri::command]
344
- fn send_notification_with_action(
345
- app: tauri::AppHandle,
346
- title: String,
347
- body: String,
348
- ) -> Result<(), String> {
349
- // Note: Actions are platform-dependent
350
- #[cfg(target_os = "macos")]
351
- {
352
- Notification::new(&app.config().identifier)
353
- .title(title)
354
- .body(body)
355
- .sound("default")
356
- .show()
357
- .map_err(|e| e.to_string())
358
- }
359
-
360
- #[cfg(not(target_os = "macos"))]
361
- {
362
- Notification::new(&app.config().identifier)
363
- .title(title)
364
- .body(body)
365
- .show()
366
- .map_err(|e| e.to_string())
367
- }
368
- }
369
- ```
370
-
371
- ### Notification with User Interaction
372
-
373
- ```rust
374
- use tauri::{Emitter, Manager};
375
-
376
- #[tauri::command]
377
- async fn send_interactive_notification(
378
- app: tauri::AppHandle,
379
- title: String,
380
- body: String,
381
- ) -> Result<(), String> {
382
- // Send notification
383
- Notification::new(&app.config().identifier)
384
- .title(&title)
385
- .body(&body)
386
- .show()
387
- .map_err(|e| e.to_string())?;
388
-
389
- // Listen for notification clicks (platform-dependent)
390
- // This is a simplified example; real implementation needs platform-specific code
391
-
392
- Ok(())
393
- }
394
- ```
395
-
396
- ## Auto-Updates
397
-
398
- ### Tauri Updater Integration
399
-
400
- ```rust
401
- use tauri_plugin_updater::UpdaterExt;
402
-
403
- #[tauri::command]
404
- async fn check_for_updates(app: tauri::AppHandle) -> Result<Option<String>, String> {
405
- let update = app
406
- .updater()
407
- .check()
408
- .await
409
- .map_err(|e| e.to_string())?;
410
-
411
- if let Some(update) = update {
412
- Ok(Some(format!(
413
- "Update available: {} (current: {})",
414
- update.version,
415
- update.current_version
416
- )))
417
- } else {
418
- Ok(None)
419
- }
420
- }
421
-
422
- #[tauri::command]
423
- async fn install_update(app: tauri::AppHandle) -> Result<(), String> {
424
- let update = app
425
- .updater()
426
- .check()
427
- .await
428
- .map_err(|e| e.to_string())?;
429
-
430
- if let Some(update) = update {
431
- // Download and install
432
- update
433
- .download_and_install(
434
- |chunk_length, content_length| {
435
- println!(
436
- "Downloaded {} of {:?}",
437
- chunk_length,
438
- content_length
439
- );
440
- },
441
- || {
442
- println!("Download finished");
443
- },
444
- )
445
- .await
446
- .map_err(|e| e.to_string())?;
447
-
448
- // Restart app
449
- app.restart();
450
- }
451
-
452
- Ok(())
453
- }
454
-
455
- // Setup auto-update check
456
- fn main() {
457
- tauri::Builder::default()
458
- .plugin(tauri_plugin_updater::Builder::new().build())
459
- .setup(|app| {
460
- let handle = app.handle().clone();
461
-
462
- // Check for updates on startup
463
- tauri::async_runtime::spawn(async move {
464
- tokio::time::sleep(tokio::time::Duration::from_secs(5)).await;
465
-
466
- if let Ok(Some(update)) = handle.updater().check().await {
467
- println!("Update available: {}", update.version);
468
-
469
- // Emit event to frontend
470
- let _ = handle.emit("update-available", &update.version);
471
- }
472
- });
473
-
474
- Ok(())
475
- })
476
- .run(tauri::generate_context!())
477
- .expect("error while running tauri application");
478
- }
479
- ```
480
-
481
- ## Deep Linking / Custom URL Schemes
482
-
483
- ### Register URL Scheme
484
-
485
- **tauri.conf.json:**
486
- ```json
487
- {
488
- "bundle": {
489
- "macOS": {
490
- "associatedDomains": ["myapp://"],
491
- "category": "public.app-category.developer-tools"
492
- },
493
- "windows": {
494
- "webviewInstallMode": {
495
- "type": "downloadBootstrapper"
496
- },
497
- "protocols": [
498
- {
499
- "name": "myapp",
500
- "schemes": ["myapp"]
501
- }
502
- ]
503
- }
504
- }
505
- }
506
- ```
507
-
508
- ### Handle Deep Links
509
-
510
- ```rust
511
- use tauri::{Emitter, Manager};
512
-
513
- fn main() {
514
- tauri::Builder::default()
515
- .setup(|app| {
516
- // Register URL handler
517
- app.listen_any("deep-link://", |event| {
518
- println!("Received deep link: {:?}", event.payload());
519
- });
520
-
521
- Ok(())
522
- })
523
- .plugin(tauri_plugin_deep_link::init())
524
- .run(tauri::generate_context!())
525
- .expect("error while running tauri application");
526
- }
527
-
528
- #[tauri::command]
529
- fn handle_url(app: tauri::AppHandle, url: String) -> Result<(), String> {
530
- println!("Handling URL: {}", url);
531
-
532
- // Parse URL and navigate
533
- if url.starts_with("myapp://open/") {
534
- let file = url.strip_prefix("myapp://open/").unwrap();
535
- app.emit("open-file", file).map_err(|e| e.to_string())?;
536
- }
537
-
538
- Ok(())
539
- }
540
- ```
541
-
542
- ## Platform-Specific Features
543
-
544
- ### Windows
545
-
546
- ```rust
547
- #[cfg(target_os = "windows")]
548
- mod windows {
549
- use winapi::um::winuser::{MessageBoxW, MB_OK};
550
- use std::ffi::OsStr;
551
- use std::os::windows::ffi::OsStrExt;
552
-
553
- pub fn show_native_message_box(title: &str, message: &str) {
554
- let title_wide: Vec<u16> = OsStr::new(title)
555
- .encode_wide()
556
- .chain(std::iter::once(0))
557
- .collect();
558
-
559
- let message_wide: Vec<u16> = OsStr::new(message)
560
- .encode_wide()
561
- .chain(std::iter::once(0))
562
- .collect();
563
-
564
- unsafe {
565
- MessageBoxW(
566
- std::ptr::null_mut(),
567
- message_wide.as_ptr(),
568
- title_wide.as_ptr(),
569
- MB_OK,
570
- );
571
- }
572
- }
573
-
574
- // Windows Registry access
575
- use winreg::enums::*;
576
- use winreg::RegKey;
577
-
578
- pub fn read_registry_value(key_path: &str, value_name: &str) -> Option<String> {
579
- let hklm = RegKey::predef(HKEY_CURRENT_USER);
580
- let key = hklm.open_subkey(key_path).ok()?;
581
- key.get_value(value_name).ok()
582
- }
583
-
584
- pub fn write_registry_value(
585
- key_path: &str,
586
- value_name: &str,
587
- value: &str,
588
- ) -> Result<(), std::io::Error> {
589
- let hklm = RegKey::predef(HKEY_CURRENT_USER);
590
- let (key, _) = hklm.create_subkey(key_path)?;
591
- key.set_value(value_name, &value)?;
592
- Ok(())
593
- }
594
- }
595
-
596
- #[tauri::command]
597
- #[cfg(target_os = "windows")]
598
- fn windows_specific_feature() -> Result<String, String> {
599
- windows::show_native_message_box("Title", "Message");
600
-
601
- let value = windows::read_registry_value(
602
- "Software\\MyApp",
603
- "Setting1",
604
- )
605
- .unwrap_or_default();
606
-
607
- Ok(value)
608
- }
609
- ```
610
-
611
- ### macOS
612
-
613
- ```rust
614
- #[cfg(target_os = "macos")]
615
- mod macos {
616
- use cocoa::base::nil;
617
- use cocoa::foundation::NSString;
618
- use objc::{class, msg_send, sel, sel_impl};
619
-
620
- pub fn set_dock_badge(label: &str) {
621
- unsafe {
622
- let app = cocoa::appkit::NSApp();
623
- let dock_tile: cocoa::base::id = msg_send![app, dockTile];
624
-
625
- let badge_label = NSString::alloc(nil).init_str(label);
626
- let _: () = msg_send![dock_tile, setBadgeLabel: badge_label];
627
- }
628
- }
629
-
630
- pub fn clear_dock_badge() {
631
- unsafe {
632
- let app = cocoa::appkit::NSApp();
633
- let dock_tile: cocoa::base::id = msg_send![app, dockTile];
634
- let _: () = msg_send![dock_tile, setBadgeLabel: nil];
635
- }
636
- }
637
-
638
- // Access macOS services
639
- use std::process::Command;
640
-
641
- pub fn trigger_notification_center(title: &str, message: &str) {
642
- let script = format!(
643
- r#"display notification "{}" with title "{}""#,
644
- message, title
645
- );
646
-
647
- Command::new("osascript")
648
- .arg("-e")
649
- .arg(script)
650
- .output()
651
- .ok();
652
- }
653
- }
654
-
655
- #[tauri::command]
656
- #[cfg(target_os = "macos")]
657
- fn macos_specific_feature(badge: String) -> Result<(), String> {
658
- macos::set_dock_badge(&badge);
659
- Ok(())
660
- }
661
-
662
- #[tauri::command]
663
- #[cfg(target_os = "macos")]
664
- fn clear_badge() -> Result<(), String> {
665
- macos::clear_dock_badge();
666
- Ok(())
667
- }
668
- ```
669
-
670
- ### Linux
671
-
672
- ```rust
673
- #[cfg(target_os = "linux")]
674
- mod linux {
675
- use std::process::Command;
676
-
677
- pub fn send_desktop_notification(title: &str, message: &str) -> Result<(), String> {
678
- Command::new("notify-send")
679
- .arg(title)
680
- .arg(message)
681
- .output()
682
- .map_err(|e| e.to_string())?;
683
-
684
- Ok(())
685
- }
686
-
687
- // D-Bus integration
688
- use dbus::blocking::Connection;
689
- use std::time::Duration;
690
-
691
- pub fn get_desktop_environment() -> Result<String, Box<dyn std::error::Error>> {
692
- let conn = Connection::new_session()?;
693
- let proxy = conn.with_proxy(
694
- "org.freedesktop.portal.Desktop",
695
- "/org/freedesktop/portal/desktop",
696
- Duration::from_millis(5000),
697
- );
698
-
699
- // Query desktop environment
700
- // This is a simplified example
701
- Ok("Unknown".to_string())
702
- }
703
- }
704
-
705
- #[tauri::command]
706
- #[cfg(target_os = "linux")]
707
- fn linux_specific_feature(title: String, message: String) -> Result<(), String> {
708
- linux::send_desktop_notification(&title, &message)
709
- }
710
- ```
711
-
712
- ## Permissions and Security
713
-
714
- ### Scope Configuration
715
-
716
- ```rust
717
- use tauri::Manager;
718
-
719
- fn main() {
720
- tauri::Builder::default()
721
- .setup(|app| {
722
- // Configure file system scope
723
- let scope = app.fs_scope();
724
-
725
- // Allow access to specific directories
726
- let app_data_dir = app.path().app_data_dir()?;
727
- scope.allow_directory(&app_data_dir, true)?;
728
-
729
- let documents_dir = app.path().document_dir()?;
730
- scope.allow_directory(&documents_dir, false)?;
731
-
732
- Ok(())
733
- })
734
- .run(tauri::generate_context!())
735
- .expect("error while running tauri application");
736
- }
737
- ```
738
-
739
- ### Runtime Permission Checks
740
-
741
- ```rust
742
- use tauri::Manager;
743
-
744
- #[tauri::command]
745
- fn read_file_with_permission(
746
- app: tauri::AppHandle,
747
- path: String,
748
- ) -> Result<String, String> {
749
- let scope = app.fs_scope();
750
-
751
- // Check if path is allowed
752
- if !scope.is_allowed(&path) {
753
- return Err("Access denied: path not in scope".to_string());
754
- }
755
-
756
- std::fs::read_to_string(&path).map_err(|e| e.to_string())
757
- }
758
-
759
- #[tauri::command]
760
- fn request_file_access(
761
- app: tauri::AppHandle,
762
- path: String,
763
- ) -> Result<(), String> {
764
- let scope = app.fs_scope();
765
-
766
- // Request access (user must approve via dialog)
767
- scope
768
- .allow_file(&path)
769
- .map_err(|e| e.to_string())?;
770
-
771
- Ok(())
772
- }
773
- ```
774
-
775
- These platform integration patterns enable full access to native OS features while maintaining cross-platform compatibility and security.