claude-mpm 4.24.0__py3-none-any.whl → 5.0.9__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (502) 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 +721 -911
  5. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  6. claude_mpm/agents/WORKFLOW.md +4 -4
  7. claude_mpm/agents/__init__.py +6 -0
  8. claude_mpm/agents/agent_loader.py +1 -4
  9. claude_mpm/agents/base_agent.json +6 -3
  10. claude_mpm/agents/base_agent_loader.py +10 -35
  11. claude_mpm/agents/frontmatter_validator.py +1 -1
  12. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +370 -3
  13. claude_mpm/agents/templates/context-management-examples.md +544 -0
  14. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +48 -0
  15. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  16. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  17. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  18. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  19. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  20. claude_mpm/cli/__init__.py +38 -2
  21. claude_mpm/cli/commands/__init__.py +2 -0
  22. claude_mpm/cli/commands/agent_source.py +774 -0
  23. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  24. claude_mpm/cli/commands/agents.py +959 -36
  25. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  26. claude_mpm/cli/commands/agents_discover.py +338 -0
  27. claude_mpm/cli/commands/aggregate.py +1 -1
  28. claude_mpm/cli/commands/analyze.py +3 -3
  29. claude_mpm/cli/commands/auto_configure.py +2 -6
  30. claude_mpm/cli/commands/config.py +7 -4
  31. claude_mpm/cli/commands/configure.py +769 -45
  32. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  33. claude_mpm/cli/commands/configure_navigation.py +63 -46
  34. claude_mpm/cli/commands/debug.py +12 -12
  35. claude_mpm/cli/commands/doctor.py +10 -2
  36. claude_mpm/cli/commands/hook_errors.py +277 -0
  37. claude_mpm/cli/commands/local_deploy.py +1 -4
  38. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  39. claude_mpm/cli/commands/mpm_init/core.py +49 -1
  40. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  41. claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
  42. claude_mpm/cli/commands/postmortem.py +401 -0
  43. claude_mpm/cli/commands/run.py +123 -165
  44. claude_mpm/cli/commands/skill_source.py +694 -0
  45. claude_mpm/cli/commands/skills.py +757 -20
  46. claude_mpm/cli/executor.py +78 -3
  47. claude_mpm/cli/interactive/agent_wizard.py +955 -45
  48. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  49. claude_mpm/cli/parsers/agents_parser.py +256 -4
  50. claude_mpm/cli/parsers/base_parser.py +53 -0
  51. claude_mpm/cli/parsers/config_parser.py +96 -43
  52. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  53. claude_mpm/cli/parsers/skills_parser.py +145 -0
  54. claude_mpm/cli/parsers/source_parser.py +138 -0
  55. claude_mpm/cli/startup.py +538 -106
  56. claude_mpm/cli/startup_display.py +480 -0
  57. claude_mpm/cli/utils.py +1 -1
  58. claude_mpm/cli_module/commands.py +1 -1
  59. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  60. claude_mpm/commands/mpm-agents-detect.md +9 -0
  61. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  62. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  63. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  64. claude_mpm/commands/mpm-doctor.md +9 -0
  65. claude_mpm/commands/mpm-help.md +14 -2
  66. claude_mpm/commands/mpm-init.md +27 -2
  67. claude_mpm/commands/mpm-monitor.md +9 -0
  68. claude_mpm/commands/mpm-postmortem.md +123 -0
  69. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  70. claude_mpm/commands/mpm-status.md +9 -0
  71. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  72. claude_mpm/commands/mpm-ticket-view.md +552 -0
  73. claude_mpm/commands/mpm-version.md +9 -0
  74. claude_mpm/commands/mpm.md +10 -0
  75. claude_mpm/config/agent_presets.py +488 -0
  76. claude_mpm/config/agent_sources.py +325 -0
  77. claude_mpm/config/skill_presets.py +392 -0
  78. claude_mpm/config/skill_sources.py +590 -0
  79. claude_mpm/constants.py +13 -0
  80. claude_mpm/core/claude_runner.py +5 -34
  81. claude_mpm/core/config.py +16 -0
  82. claude_mpm/core/constants.py +1 -1
  83. claude_mpm/core/framework/__init__.py +3 -16
  84. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  85. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  86. claude_mpm/core/hook_error_memory.py +381 -0
  87. claude_mpm/core/hook_manager.py +41 -2
  88. claude_mpm/core/interactive_session.py +91 -10
  89. claude_mpm/core/logger.py +3 -1
  90. claude_mpm/core/oneshot_session.py +71 -8
  91. claude_mpm/core/protocols/__init__.py +23 -0
  92. claude_mpm/core/protocols/runner_protocol.py +103 -0
  93. claude_mpm/core/protocols/session_protocol.py +131 -0
  94. claude_mpm/core/shared/singleton_manager.py +11 -4
  95. claude_mpm/core/system_context.py +38 -0
  96. claude_mpm/dashboard/static/css/activity.css +69 -69
  97. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  98. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  99. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  100. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  101. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  102. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  103. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  104. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  105. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  106. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  107. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  108. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  109. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  110. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  111. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  112. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  113. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  114. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  115. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  116. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  117. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  118. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  119. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  120. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  121. claude_mpm/dashboard/templates/code_simple.html +23 -23
  122. claude_mpm/dashboard/templates/index.html +18 -18
  123. claude_mpm/experimental/cli_enhancements.py +1 -5
  124. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  125. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  126. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  127. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  128. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  129. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  130. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  131. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  132. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  133. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  134. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  135. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  136. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  137. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  138. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  139. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  140. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  141. claude_mpm/models/git_repository.py +198 -0
  142. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  143. claude_mpm/scripts/start_activity_logging.py +3 -1
  144. claude_mpm/services/agents/agent_builder.py +45 -9
  145. claude_mpm/services/agents/agent_preset_service.py +238 -0
  146. claude_mpm/services/agents/agent_selection_service.py +484 -0
  147. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  148. claude_mpm/services/agents/cache_git_manager.py +621 -0
  149. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  150. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  151. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  152. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  153. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  154. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  155. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  156. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  157. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  158. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  159. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  160. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  161. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  162. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  163. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  164. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  165. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  166. claude_mpm/services/agents/git_source_manager.py +629 -0
  167. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  168. claude_mpm/services/agents/local_template_manager.py +50 -10
  169. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  170. claude_mpm/services/agents/sources/__init__.py +13 -0
  171. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  172. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  173. claude_mpm/services/agents/startup_sync.py +239 -0
  174. claude_mpm/services/agents/toolchain_detector.py +474 -0
  175. claude_mpm/services/analysis/__init__.py +25 -0
  176. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  177. claude_mpm/services/analysis/postmortem_service.py +765 -0
  178. claude_mpm/services/cli/session_pause_manager.py +1 -1
  179. claude_mpm/services/command_deployment_service.py +200 -6
  180. claude_mpm/services/core/base.py +7 -2
  181. claude_mpm/services/core/interfaces/__init__.py +1 -3
  182. claude_mpm/services/core/interfaces/health.py +1 -4
  183. claude_mpm/services/core/models/__init__.py +2 -11
  184. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  185. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  186. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  187. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  188. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  189. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  190. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  191. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  192. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  193. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  194. claude_mpm/services/event_bus/direct_relay.py +3 -3
  195. claude_mpm/services/events/consumers/logging.py +1 -2
  196. claude_mpm/services/git/__init__.py +21 -0
  197. claude_mpm/services/git/git_operations_service.py +494 -0
  198. claude_mpm/services/github/__init__.py +21 -0
  199. claude_mpm/services/github/github_cli_service.py +397 -0
  200. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  201. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  202. claude_mpm/services/instructions/__init__.py +9 -0
  203. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  204. claude_mpm/services/local_ops/__init__.py +3 -13
  205. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  206. claude_mpm/services/local_ops/health_manager.py +1 -4
  207. claude_mpm/services/local_ops/resource_monitor.py +1 -1
  208. claude_mpm/services/mcp_config_manager.py +75 -145
  209. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  210. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  211. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  212. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  213. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  214. claude_mpm/services/mcp_service_verifier.py +6 -3
  215. claude_mpm/services/model/model_router.py +1 -2
  216. claude_mpm/services/monitor/daemon.py +29 -9
  217. claude_mpm/services/monitor/daemon_manager.py +96 -19
  218. claude_mpm/services/monitor/server.py +2 -2
  219. claude_mpm/services/port_manager.py +1 -1
  220. claude_mpm/services/pr/__init__.py +14 -0
  221. claude_mpm/services/pr/pr_template_service.py +329 -0
  222. claude_mpm/services/project/documentation_manager.py +2 -1
  223. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  224. claude_mpm/services/runner_configuration_service.py +16 -3
  225. claude_mpm/services/session_management_service.py +16 -4
  226. claude_mpm/services/skills/__init__.py +18 -0
  227. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  228. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  229. claude_mpm/services/skills_config.py +547 -0
  230. claude_mpm/services/skills_deployer.py +955 -0
  231. claude_mpm/services/socketio/handlers/connection.py +1 -1
  232. claude_mpm/services/socketio/handlers/git.py +1 -1
  233. claude_mpm/services/socketio/server/core.py +1 -4
  234. claude_mpm/services/socketio/server/main.py +1 -3
  235. claude_mpm/services/system_instructions_service.py +1 -3
  236. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  237. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  238. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  239. claude_mpm/services/unified/unified_deployment.py +1 -5
  240. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  241. claude_mpm/services/visualization/__init__.py +1 -5
  242. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  243. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  244. claude_mpm/skills/skills_registry.py +0 -1
  245. claude_mpm/templates/questions/__init__.py +38 -0
  246. claude_mpm/templates/questions/base.py +193 -0
  247. claude_mpm/templates/questions/pr_strategy.py +311 -0
  248. claude_mpm/templates/questions/project_init.py +385 -0
  249. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  250. claude_mpm/tools/__main__.py +8 -8
  251. claude_mpm/utils/agent_dependency_loader.py +77 -10
  252. claude_mpm/utils/agent_filters.py +288 -0
  253. claude_mpm/utils/dependency_cache.py +3 -1
  254. claude_mpm/utils/gitignore.py +241 -0
  255. claude_mpm/utils/migration.py +372 -0
  256. claude_mpm/utils/progress.py +387 -0
  257. claude_mpm/utils/robust_installer.py +2 -4
  258. claude_mpm/utils/structured_questions.py +619 -0
  259. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/METADATA +396 -43
  260. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/RECORD +268 -422
  261. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  262. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  263. claude_mpm/agents/templates/agent-manager.json +0 -273
  264. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  265. claude_mpm/agents/templates/api_qa.json +0 -183
  266. claude_mpm/agents/templates/clerk-ops.json +0 -235
  267. claude_mpm/agents/templates/code_analyzer.json +0 -101
  268. claude_mpm/agents/templates/content-agent.json +0 -358
  269. claude_mpm/agents/templates/dart_engineer.json +0 -307
  270. claude_mpm/agents/templates/data_engineer.json +0 -225
  271. claude_mpm/agents/templates/documentation.json +0 -238
  272. claude_mpm/agents/templates/engineer.json +0 -210
  273. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  274. claude_mpm/agents/templates/golang_engineer.json +0 -270
  275. claude_mpm/agents/templates/imagemagick.json +0 -264
  276. claude_mpm/agents/templates/java_engineer.json +0 -346
  277. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  278. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  279. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  280. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  281. claude_mpm/agents/templates/memory_manager.json +0 -158
  282. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  283. claude_mpm/agents/templates/ops.json +0 -185
  284. claude_mpm/agents/templates/php-engineer.json +0 -287
  285. claude_mpm/agents/templates/product_owner.json +0 -338
  286. claude_mpm/agents/templates/project_organizer.json +0 -144
  287. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  288. claude_mpm/agents/templates/python_engineer.json +0 -387
  289. claude_mpm/agents/templates/qa.json +0 -243
  290. claude_mpm/agents/templates/react_engineer.json +0 -239
  291. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  292. claude_mpm/agents/templates/research.json +0 -188
  293. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  294. claude_mpm/agents/templates/rust_engineer.json +0 -275
  295. claude_mpm/agents/templates/security.json +0 -202
  296. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  297. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  298. claude_mpm/agents/templates/ticketing.json +0 -178
  299. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  300. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  301. claude_mpm/agents/templates/version_control.json +0 -159
  302. claude_mpm/agents/templates/web_qa.json +0 -400
  303. claude_mpm/agents/templates/web_ui.json +0 -189
  304. claude_mpm/commands/mpm-tickets.md +0 -151
  305. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  306. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  307. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  308. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  309. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  310. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  311. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  312. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  313. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  314. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  315. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  316. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  317. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  318. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  319. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  320. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  321. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  322. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  323. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  324. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  325. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  326. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  327. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  328. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  329. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  330. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  331. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  332. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  333. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  334. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  335. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  336. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  337. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  338. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  339. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  340. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  341. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  342. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  343. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  344. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  345. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  346. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  347. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  348. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  349. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  350. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  351. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  352. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  353. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  354. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  355. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  356. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  357. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  358. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  359. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  360. claude_mpm/dashboard/static/built/react/events.js +0 -30
  361. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  362. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  363. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  364. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  365. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  366. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  367. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  368. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  369. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  370. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  371. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  372. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  373. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  374. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  375. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  376. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  377. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  378. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  379. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  380. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  381. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  382. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  383. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  384. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  385. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  386. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  387. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  388. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  389. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  390. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  391. claude_mpm/dashboard/static/events.html +0 -607
  392. claude_mpm/dashboard/static/index.html +0 -635
  393. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  394. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  395. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  396. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  397. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  398. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  399. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  400. claude_mpm/dashboard/static/legacy/files.html +0 -747
  401. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  402. claude_mpm/dashboard/static/monitors.html +0 -431
  403. claude_mpm/dashboard/static/production/events.html +0 -659
  404. claude_mpm/dashboard/static/production/main.html +0 -698
  405. claude_mpm/dashboard/static/production/monitors.html +0 -483
  406. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  407. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  408. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  409. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  410. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  411. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  412. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  413. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  414. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  415. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  416. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  417. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  418. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  419. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  420. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  421. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  422. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  423. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  424. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  425. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  426. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  427. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  428. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  429. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  430. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  431. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  432. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  433. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  434. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  435. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  436. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  437. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  438. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  439. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  440. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  441. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  442. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  443. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  444. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  445. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  446. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  447. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  448. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  449. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  450. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  451. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  452. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  453. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  454. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  455. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  456. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  457. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  458. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  459. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  460. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  461. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  462. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  463. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  464. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  465. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  466. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  467. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  468. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  469. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  470. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  471. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  472. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  473. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  474. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  475. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  476. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  477. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  478. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  479. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  480. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  481. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  482. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  483. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  484. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  485. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  486. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  487. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  488. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  489. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  490. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  491. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  492. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  493. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  494. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  495. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  496. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  497. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  498. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  499. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/WHEEL +0 -0
  500. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/entry_points.txt +0 -0
  501. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.dist-info}/licenses/LICENSE +0 -0
  502. {claude_mpm-4.24.0.dist-info → claude_mpm-5.0.9.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.