claude-mpm 4.20.3__py3-none-any.whl → 4.25.10__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 (454) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +23 -6
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +1783 -34
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/base_agent.json +6 -3
  7. claude_mpm/agents/frontmatter_validator.py +1 -1
  8. claude_mpm/agents/templates/api_qa.json +5 -2
  9. claude_mpm/agents/templates/circuit_breakers.md +108 -2
  10. claude_mpm/agents/templates/documentation.json +33 -6
  11. claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
  12. claude_mpm/agents/templates/php-engineer.json +10 -4
  13. claude_mpm/agents/templates/pm_red_flags.md +89 -19
  14. claude_mpm/agents/templates/project_organizer.json +7 -3
  15. claude_mpm/agents/templates/qa.json +2 -1
  16. claude_mpm/agents/templates/react_engineer.json +1 -0
  17. claude_mpm/agents/templates/research.json +82 -12
  18. claude_mpm/agents/templates/security.json +4 -4
  19. claude_mpm/agents/templates/tauri_engineer.json +274 -0
  20. claude_mpm/agents/templates/ticketing.json +10 -6
  21. claude_mpm/agents/templates/version_control.json +4 -2
  22. claude_mpm/agents/templates/web_qa.json +2 -1
  23. claude_mpm/cli/README.md +253 -0
  24. claude_mpm/cli/__init__.py +11 -1
  25. claude_mpm/cli/commands/aggregate.py +1 -1
  26. claude_mpm/cli/commands/analyze.py +3 -3
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  29. claude_mpm/cli/commands/debug.py +12 -12
  30. claude_mpm/cli/commands/hook_errors.py +277 -0
  31. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  32. claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
  33. claude_mpm/cli/commands/mpm_init/README.md +365 -0
  34. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  35. claude_mpm/cli/commands/mpm_init/core.py +573 -0
  36. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  37. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  38. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  39. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  40. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  41. claude_mpm/cli/commands/mpm_init_handler.py +67 -1
  42. claude_mpm/cli/commands/run.py +124 -128
  43. claude_mpm/cli/commands/skills.py +522 -34
  44. claude_mpm/cli/executor.py +56 -0
  45. claude_mpm/cli/interactive/agent_wizard.py +5 -5
  46. claude_mpm/cli/parsers/base_parser.py +28 -0
  47. claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
  48. claude_mpm/cli/parsers/skills_parser.py +138 -0
  49. claude_mpm/cli/startup.py +111 -8
  50. claude_mpm/cli/startup_display.py +480 -0
  51. claude_mpm/cli/utils.py +1 -1
  52. claude_mpm/cli_module/commands.py +1 -1
  53. claude_mpm/cli_module/refactoring_guide.md +253 -0
  54. claude_mpm/commands/mpm-help.md +3 -0
  55. claude_mpm/commands/mpm-init.md +19 -3
  56. claude_mpm/commands/mpm-resume.md +372 -0
  57. claude_mpm/commands/mpm-tickets.md +56 -7
  58. claude_mpm/commands/mpm.md +1 -0
  59. claude_mpm/config/agent_capabilities.yaml +658 -0
  60. claude_mpm/config/async_logging_config.yaml +145 -0
  61. claude_mpm/constants.py +12 -0
  62. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
  63. claude_mpm/core/api_validator.py +1 -1
  64. claude_mpm/core/claude_runner.py +14 -1
  65. claude_mpm/core/config.py +8 -0
  66. claude_mpm/core/constants.py +1 -1
  67. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  68. claude_mpm/core/hook_error_memory.py +381 -0
  69. claude_mpm/core/hook_manager.py +41 -2
  70. claude_mpm/core/interactive_session.py +48 -3
  71. claude_mpm/core/interfaces.py +56 -1
  72. claude_mpm/core/logger.py +3 -1
  73. claude_mpm/core/oneshot_session.py +39 -0
  74. claude_mpm/d2/.gitignore +22 -0
  75. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
  76. claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
  77. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
  78. claude_mpm/d2/QUICKSTART.md +186 -0
  79. claude_mpm/d2/README.md +232 -0
  80. claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
  81. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
  82. claude_mpm/d2/TESTING.md +288 -0
  83. claude_mpm/d2/index.html +118 -0
  84. claude_mpm/d2/package.json +19 -0
  85. claude_mpm/d2/src/App.svelte +110 -0
  86. claude_mpm/d2/src/components/Header.svelte +153 -0
  87. claude_mpm/d2/src/components/MainContent.svelte +74 -0
  88. claude_mpm/d2/src/components/Sidebar.svelte +85 -0
  89. claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
  90. claude_mpm/d2/src/lib/socketio.js +144 -0
  91. claude_mpm/d2/src/main.js +7 -0
  92. claude_mpm/d2/src/stores/events.js +114 -0
  93. claude_mpm/d2/src/stores/socket.js +108 -0
  94. claude_mpm/d2/src/stores/theme.js +65 -0
  95. claude_mpm/d2/svelte.config.js +12 -0
  96. claude_mpm/d2/vite.config.js +15 -0
  97. claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
  98. claude_mpm/dashboard/BUILD_NUMBER +1 -0
  99. claude_mpm/dashboard/README.md +121 -0
  100. claude_mpm/dashboard/VERSION +1 -0
  101. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
  102. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
  103. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
  104. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
  105. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
  106. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
  107. claude_mpm/dashboard/react/entries/events.tsx +165 -0
  108. claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
  109. claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
  110. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
  111. claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
  112. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
  113. claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
  114. claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
  115. claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
  116. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
  117. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
  118. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
  119. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
  120. claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
  121. claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
  122. claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
  123. claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
  124. claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
  125. claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
  126. claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
  127. claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
  128. claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
  129. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
  130. claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
  131. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
  132. claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
  133. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
  134. claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
  135. claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
  136. claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
  137. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
  138. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
  139. claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
  140. claude_mpm/dashboard/static/built/connection-manager.js +76 -76
  141. claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
  142. claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
  143. claude_mpm/dashboard/static/built/react/events.js.map +1 -0
  144. claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
  145. claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
  146. claude_mpm/dashboard/static/built/shared/logger.js +16 -16
  147. claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
  148. claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
  149. claude_mpm/dashboard/static/css/activity.css +69 -69
  150. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  151. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  152. claude_mpm/dashboard/static/index.html +22 -22
  153. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
  154. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  155. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  156. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  157. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  158. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  159. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  160. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  161. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  162. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  163. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  164. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  165. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  166. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  167. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  168. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  169. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  170. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  171. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  172. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  173. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  174. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  175. claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
  176. claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
  177. claude_mpm/dashboard/static/js/shared/logger.js +16 -16
  178. claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
  179. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  180. claude_mpm/dashboard/static/navigation-test-results.md +118 -0
  181. claude_mpm/dashboard/static/production/main.html +21 -21
  182. claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
  183. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
  184. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
  185. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
  186. claude_mpm/dashboard/templates/code_simple.html +23 -23
  187. claude_mpm/dashboard/templates/index.html +18 -18
  188. claude_mpm/hooks/README.md +143 -0
  189. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  190. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  191. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  192. claude_mpm/hooks/templates/README.md +180 -0
  193. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  194. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  195. claude_mpm/hooks/templates/settings.json.example +147 -0
  196. claude_mpm/schemas/agent_schema.json +596 -0
  197. claude_mpm/schemas/frontmatter_schema.json +165 -0
  198. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  199. claude_mpm/scripts/start_activity_logging.py +3 -1
  200. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  201. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  202. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  203. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  204. claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
  205. claude_mpm/services/agents/local_template_manager.py +3 -1
  206. claude_mpm/services/cli/session_pause_manager.py +504 -0
  207. claude_mpm/services/cli/session_resume_helper.py +36 -16
  208. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  209. claude_mpm/services/core/base.py +26 -11
  210. claude_mpm/services/core/interfaces.py +56 -1
  211. claude_mpm/services/core/models/agent_config.py +3 -0
  212. claude_mpm/services/core/models/process.py +4 -0
  213. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  214. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  215. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  216. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  217. claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
  218. claude_mpm/services/diagnostics/models.py +21 -0
  219. claude_mpm/services/event_bus/README.md +244 -0
  220. claude_mpm/services/event_bus/direct_relay.py +3 -3
  221. claude_mpm/services/event_bus/event_bus.py +36 -3
  222. claude_mpm/services/event_bus/relay.py +23 -7
  223. claude_mpm/services/events/README.md +303 -0
  224. claude_mpm/services/events/consumers/logging.py +1 -2
  225. claude_mpm/services/framework_claude_md_generator/README.md +119 -0
  226. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  227. claude_mpm/services/local_ops/__init__.py +2 -0
  228. claude_mpm/services/local_ops/process_manager.py +1 -1
  229. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  230. claude_mpm/services/mcp_gateway/README.md +185 -0
  231. claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
  232. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  233. claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
  234. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  235. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  236. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
  237. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  238. claude_mpm/services/memory/failure_tracker.py +19 -4
  239. claude_mpm/services/memory/optimizer.py +1 -1
  240. claude_mpm/services/model/model_router.py +8 -9
  241. claude_mpm/services/monitor/daemon.py +1 -1
  242. claude_mpm/services/monitor/server.py +2 -2
  243. claude_mpm/services/native_agent_converter.py +356 -0
  244. claude_mpm/services/port_manager.py +1 -1
  245. claude_mpm/services/project/documentation_manager.py +2 -1
  246. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  247. claude_mpm/services/runner_configuration_service.py +1 -0
  248. claude_mpm/services/self_upgrade_service.py +165 -7
  249. claude_mpm/services/skills_config.py +547 -0
  250. claude_mpm/services/skills_deployer.py +955 -0
  251. claude_mpm/services/socketio/handlers/connection.py +1 -1
  252. claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
  253. claude_mpm/services/socketio/handlers/git.py +2 -2
  254. claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
  255. claude_mpm/services/static/.gitkeep +2 -0
  256. claude_mpm/services/system_instructions_service.py +1 -3
  257. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  258. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  259. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  260. claude_mpm/services/version_control/VERSION +1 -0
  261. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  262. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  263. claude_mpm/skills/__init__.py +3 -3
  264. claude_mpm/skills/agent_skills_injector.py +42 -49
  265. claude_mpm/skills/bundled/.gitkeep +2 -0
  266. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +4 -0
  267. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +108 -114
  268. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  269. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  270. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  271. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  272. claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
  273. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +46 -41
  274. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  275. claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
  276. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +36 -73
  277. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  278. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  279. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +100 -125
  280. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
  281. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  282. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  283. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  284. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  285. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +28 -72
  286. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +11 -0
  287. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  288. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  289. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +272 -0
  290. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
  291. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
  292. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
  293. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
  294. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
  295. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
  296. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
  297. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
  298. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
  299. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  300. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
  301. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +13 -1
  302. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
  303. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
  304. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  305. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
  306. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +11 -0
  307. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
  308. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +109 -277
  309. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  310. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  311. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +17 -10
  312. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +92 -39
  313. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
  314. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
  315. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
  316. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +135 -155
  317. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  318. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  319. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  320. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  321. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  322. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +13 -12
  323. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +5 -3
  324. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +19 -12
  325. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  326. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  327. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  328. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  329. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  330. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  331. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  332. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  333. claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
  334. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  335. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  336. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  337. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  338. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  339. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  340. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  341. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
  342. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
  343. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
  344. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
  345. claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
  346. claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
  347. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
  348. claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
  349. claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
  350. claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
  351. claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
  352. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +21 -25
  353. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
  354. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  355. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
  356. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
  357. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
  358. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
  359. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
  360. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +86 -250
  361. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  362. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  363. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  364. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  365. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
  366. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +145 -57
  367. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  368. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +6 -6
  369. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +13 -9
  370. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +8 -8
  371. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  372. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  373. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +37 -15
  374. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  375. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  376. claude_mpm/skills/skills_registry.py +44 -48
  377. claude_mpm/skills/skills_service.py +117 -108
  378. claude_mpm/templates/questions/EXAMPLES.md +501 -0
  379. claude_mpm/templates/questions/__init__.py +43 -0
  380. claude_mpm/templates/questions/base.py +193 -0
  381. claude_mpm/templates/questions/pr_strategy.py +314 -0
  382. claude_mpm/templates/questions/project_init.py +388 -0
  383. claude_mpm/templates/questions/ticket_mgmt.py +397 -0
  384. claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
  385. claude_mpm/tools/__main__.py +8 -8
  386. claude_mpm/tools/code_tree_analyzer/README.md +64 -0
  387. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  388. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  389. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  390. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  391. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  392. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  393. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  394. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  395. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  396. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  397. claude_mpm/utils/agent_dependency_loader.py +3 -3
  398. claude_mpm/utils/dependency_cache.py +3 -1
  399. claude_mpm/utils/gitignore.py +241 -0
  400. claude_mpm/utils/log_cleanup.py +3 -3
  401. claude_mpm/utils/robust_installer.py +3 -5
  402. claude_mpm/utils/structured_questions.py +619 -0
  403. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/METADATA +218 -31
  404. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +409 -246
  405. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  406. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  407. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  408. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  409. claude_mpm/cli/commands/mpm_init.py +0 -2093
  410. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  411. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  412. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  413. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  414. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  415. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  416. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  417. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  418. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  419. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  420. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  421. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  422. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  423. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  424. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  425. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  426. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  427. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  428. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  429. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  430. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  431. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  432. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  433. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  434. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  435. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  436. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  437. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  438. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  439. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  440. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  441. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  442. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  443. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  444. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  445. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  446. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  447. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  448. claude_mpm/skills/bundled/debugging/verification-before-completion/references/common-failures.md +0 -213
  449. claude_mpm/tools/code_tree_analyzer.py +0 -1825
  450. /claude_mpm/skills/bundled/collaboration/requesting-code-review/{code-reviewer.md → references/code-reviewer-template.md} +0 -0
  451. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
  452. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
  453. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
  454. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,742 @@
1
+ # Development Workflow Reference
2
+
3
+ ## Extension Development Setup
4
+
5
+ ### Using ext-template
6
+
7
+ The official ext-template provides the recommended structure for EspoCRM extensions.
8
+
9
+ ```bash
10
+ # Clone the template
11
+ git clone https://github.com/espocrm/ext-template.git my-extension
12
+ cd my-extension
13
+
14
+ # Install dependencies
15
+ composer install
16
+ npm install
17
+ ```
18
+
19
+ ### Extension Directory Structure (EspoCRM 7.4+)
20
+
21
+ ```
22
+ my-extension/
23
+ ├── src/
24
+ │ ├── files/
25
+ │ │ └── custom/Espo/Modules/MyModule/
26
+ │ │ ├── Resources/
27
+ │ │ │ ├── metadata/
28
+ │ │ │ │ ├── entityDefs/
29
+ │ │ │ │ ├── clientDefs/
30
+ │ │ │ │ └── scopes/
31
+ │ │ │ └── layouts/
32
+ │ │ ├── Services/
33
+ │ │ ├── Controllers/
34
+ │ │ ├── Repositories/
35
+ │ │ ├── Hooks/
36
+ │ │ └── Entities/
37
+ │ └── scripts/
38
+ ├── tests/
39
+ ├── package.json
40
+ └── manifest.json
41
+ ```
42
+
43
+ ### Manifest File
44
+
45
+ ```json
46
+ {
47
+ "name": "My Extension",
48
+ "version": "1.0.0",
49
+ "acceptableVersions": [">=7.4.0"],
50
+ "author": "Your Name",
51
+ "description": "Extension description",
52
+ "license": "MIT",
53
+ "releaseDate": "2024-01-01",
54
+ "skipBackup": true
55
+ }
56
+ ```
57
+
58
+ ### Building Extension
59
+
60
+ ```bash
61
+ # Build installable package
62
+ npm run build
63
+
64
+ # Output: build/MyExtension-1.0.0.zip
65
+ ```
66
+
67
+ ## Creating Custom Entities
68
+
69
+ ### Step 1: Entity Definition
70
+
71
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/metadata/entityDefs/MyEntity.json`:
72
+
73
+ ```json
74
+ {
75
+ "fields": {
76
+ "name": {
77
+ "type": "varchar",
78
+ "required": true,
79
+ "maxLength": 255,
80
+ "trim": true,
81
+ "view": "views/fields/varchar"
82
+ },
83
+ "description": {
84
+ "type": "text",
85
+ "rows": 4
86
+ },
87
+ "status": {
88
+ "type": "enum",
89
+ "options": ["New", "In Progress", "Complete", "Cancelled"],
90
+ "default": "New",
91
+ "required": true,
92
+ "audited": true,
93
+ "isSorted": true
94
+ },
95
+ "priority": {
96
+ "type": "enum",
97
+ "options": ["Low", "Normal", "High", "Urgent"],
98
+ "default": "Normal",
99
+ "audited": true
100
+ },
101
+ "dueDate": {
102
+ "type": "date",
103
+ "audited": true
104
+ },
105
+ "assignedUser": {
106
+ "type": "link"
107
+ },
108
+ "account": {
109
+ "type": "link"
110
+ },
111
+ "contacts": {
112
+ "type": "linkMultiple"
113
+ }
114
+ },
115
+ "links": {
116
+ "assignedUser": {
117
+ "type": "belongsTo",
118
+ "entity": "User",
119
+ "foreign": "myEntities"
120
+ },
121
+ "account": {
122
+ "type": "belongsTo",
123
+ "entity": "Account",
124
+ "foreign": "myEntities"
125
+ },
126
+ "contacts": {
127
+ "type": "hasMany",
128
+ "entity": "Contact",
129
+ "foreign": "myEntities",
130
+ "layoutRelationshipsDisabled": true
131
+ },
132
+ "teams": {
133
+ "type": "hasMany",
134
+ "entity": "Team",
135
+ "relationName": "EntityTeam",
136
+ "layoutRelationshipsDisabled": true
137
+ }
138
+ },
139
+ "collection": {
140
+ "orderBy": "createdAt",
141
+ "order": "desc"
142
+ },
143
+ "indexes": {
144
+ "name": {
145
+ "columns": ["name", "deleted"]
146
+ },
147
+ "assignedUser": {
148
+ "columns": ["assignedUserId", "deleted"]
149
+ }
150
+ }
151
+ }
152
+ ```
153
+
154
+ ### Step 2: Scope Definition
155
+
156
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/metadata/scopes/MyEntity.json`:
157
+
158
+ ```json
159
+ {
160
+ "entity": true,
161
+ "object": true,
162
+ "layouts": true,
163
+ "tab": true,
164
+ "acl": true,
165
+ "aclActionList": [
166
+ "create",
167
+ "read",
168
+ "edit",
169
+ "delete",
170
+ "stream"
171
+ ],
172
+ "aclLevelList": [
173
+ "all",
174
+ "team",
175
+ "own",
176
+ "no"
177
+ ],
178
+ "aclPortal": true,
179
+ "aclPortalLevelList": [
180
+ "all",
181
+ "account",
182
+ "contact",
183
+ "own",
184
+ "no"
185
+ ],
186
+ "customizable": true,
187
+ "type": "Base",
188
+ "module": "MyModule",
189
+ "stream": true,
190
+ "activities": true,
191
+ "historyDisabled": false,
192
+ "importable": true,
193
+ "notifications": true,
194
+ "activityStatusList": ["Planned", "Held", "Not Held"]
195
+ }
196
+ ```
197
+
198
+ ### Step 3: Client Definitions
199
+
200
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/metadata/clientDefs/MyEntity.json`:
201
+
202
+ ```json
203
+ {
204
+ "controller": "controllers/record",
205
+ "iconClass": "fas fa-tasks",
206
+ "color": "#6FA8D6",
207
+ "createDisabled": false,
208
+ "dynamicLogic": {
209
+ "fields": {
210
+ "dueDate": {
211
+ "required": {
212
+ "conditionGroup": [
213
+ {
214
+ "type": "equals",
215
+ "attribute": "status",
216
+ "value": "In Progress"
217
+ }
218
+ ]
219
+ }
220
+ }
221
+ }
222
+ },
223
+ "filterList": [
224
+ "active",
225
+ "completed"
226
+ ],
227
+ "boolFilterList": [
228
+ "onlyMy"
229
+ ],
230
+ "defaultFilterData": {
231
+ "primary": "active"
232
+ },
233
+ "sidePanels": {
234
+ "detail": [
235
+ {
236
+ "name": "activities",
237
+ "label": "Activities",
238
+ "view": "crm:views/record/panels/activities",
239
+ "aclScope": "Activities"
240
+ }
241
+ ]
242
+ }
243
+ }
244
+ ```
245
+
246
+ ### Step 4: Language Translations
247
+
248
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/i18n/en_US/MyEntity.json`:
249
+
250
+ ```json
251
+ {
252
+ "fields": {
253
+ "name": "Name",
254
+ "description": "Description",
255
+ "status": "Status",
256
+ "priority": "Priority",
257
+ "dueDate": "Due Date",
258
+ "assignedUser": "Assigned To",
259
+ "account": "Account",
260
+ "contacts": "Contacts"
261
+ },
262
+ "links": {
263
+ "assignedUser": "Assigned To",
264
+ "account": "Account",
265
+ "contacts": "Contacts"
266
+ },
267
+ "options": {
268
+ "status": {
269
+ "New": "New",
270
+ "In Progress": "In Progress",
271
+ "Complete": "Complete",
272
+ "Cancelled": "Cancelled"
273
+ },
274
+ "priority": {
275
+ "Low": "Low",
276
+ "Normal": "Normal",
277
+ "High": "High",
278
+ "Urgent": "Urgent"
279
+ }
280
+ },
281
+ "labels": {
282
+ "Create MyEntity": "Create MyEntity"
283
+ },
284
+ "presetFilters": {
285
+ "active": "Active",
286
+ "completed": "Completed"
287
+ },
288
+ "boolFilters": {
289
+ "onlyMy": "Only My"
290
+ }
291
+ }
292
+ ```
293
+
294
+ ### Step 5: Service Layer
295
+
296
+ Create `src/files/custom/Espo/Modules/MyModule/Services/MyEntity.php`:
297
+
298
+ ```php
299
+ <?php
300
+ namespace Espo\Modules\MyModule\Services;
301
+
302
+ use Espo\Services\Record;
303
+ use Espo\ORM\Entity;
304
+
305
+ class MyEntity extends Record
306
+ {
307
+ protected function beforeCreateEntity(Entity $entity, array $data): void
308
+ {
309
+ parent::beforeCreateEntity($entity, $data);
310
+
311
+ // Set default assigned user to creator if not specified
312
+ if (!$entity->get('assignedUserId')) {
313
+ $entity->set('assignedUserId', $this->user->getId());
314
+ }
315
+ }
316
+
317
+ protected function beforeUpdateEntity(Entity $entity, array $data): void
318
+ {
319
+ parent::beforeUpdateEntity($entity, $data);
320
+
321
+ // Auto-complete when status set to Complete
322
+ if ($entity->isAttributeChanged('status') && $entity->get('status') === 'Complete') {
323
+ $entity->set('completedAt', date('Y-m-d H:i:s'));
324
+ }
325
+ }
326
+ }
327
+ ```
328
+
329
+ ### Step 6: Rebuild Cache
330
+
331
+ ```bash
332
+ bin/command rebuild
333
+ ```
334
+
335
+ ## Creating Custom Fields
336
+
337
+ ### Custom Field Type Definition
338
+
339
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/metadata/fields/myFieldType.json`:
340
+
341
+ ```json
342
+ {
343
+ "params": [
344
+ {
345
+ "name": "required",
346
+ "type": "bool",
347
+ "default": false
348
+ },
349
+ {
350
+ "name": "maxLength",
351
+ "type": "int"
352
+ },
353
+ {
354
+ "name": "customParam",
355
+ "type": "varchar"
356
+ }
357
+ ],
358
+ "view": "custom:views/fields/my-field-type",
359
+ "personalData": false
360
+ }
361
+ ```
362
+
363
+ ### Custom Field Backend
364
+
365
+ Create `src/files/custom/Espo/Modules/MyModule/Classes/FieldType/MyFieldTypeType.php`:
366
+
367
+ ```php
368
+ <?php
369
+ namespace Espo\Modules\MyModule\Classes\FieldType;
370
+
371
+ use Espo\ORM\Entity;
372
+ use Espo\ORM\Type\AttributeType;
373
+ use Espo\Core\Field\FieldType;
374
+
375
+ class MyFieldTypeType implements FieldType
376
+ {
377
+ public function getAttributeParamList(): array
378
+ {
379
+ return [
380
+ AttributeType::VARCHAR,
381
+ ];
382
+ }
383
+
384
+ public function getActualAttributeParamList(Entity $entity, string $field): array
385
+ {
386
+ return [
387
+ AttributeType::VARCHAR,
388
+ ];
389
+ }
390
+ }
391
+ ```
392
+
393
+ ### Custom Field Frontend
394
+
395
+ Create `client/custom/src/views/fields/my-field-type.js`:
396
+
397
+ ```javascript
398
+ define('custom:views/fields/my-field-type', ['views/fields/varchar'], function (Dep) {
399
+
400
+ return Dep.extend({
401
+
402
+ setup: function () {
403
+ Dep.prototype.setup.call(this);
404
+
405
+ // Custom setup logic
406
+ this.customParam = this.params.customParam || '';
407
+ },
408
+
409
+ afterRender: function () {
410
+ Dep.prototype.afterRender.call(this);
411
+
412
+ // Custom rendering logic
413
+ },
414
+
415
+ validateRequired: function () {
416
+ if (this.params.required) {
417
+ if (!this.model.get(this.name)) {
418
+ var msg = this.translate('fieldIsRequired', 'messages')
419
+ .replace('{field}', this.getLabelText());
420
+ this.showValidationMessage(msg);
421
+ return true;
422
+ }
423
+ }
424
+ },
425
+
426
+ fetch: function () {
427
+ var data = {};
428
+ data[this.name] = this.$element.val() || null;
429
+ return data;
430
+ }
431
+ });
432
+ });
433
+ ```
434
+
435
+ ## Custom API Endpoints
436
+
437
+ ### Step 1: Define Route
438
+
439
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/metadata/api.json`:
440
+
441
+ ```json
442
+ {
443
+ "routes": [
444
+ {
445
+ "route": "/MyEntity/:id/customAction",
446
+ "method": "post",
447
+ "controller": "MyModule:MyEntity",
448
+ "action": "customAction"
449
+ }
450
+ ]
451
+ }
452
+ ```
453
+
454
+ ### Step 2: Create Controller
455
+
456
+ Create `src/files/custom/Espo/Modules/MyModule/Controllers/MyEntity.php`:
457
+
458
+ ```php
459
+ <?php
460
+ namespace Espo\Modules\MyModule\Controllers;
461
+
462
+ use Espo\Core\Controllers\Record;
463
+ use Espo\Core\Api\Request;
464
+ use Espo\Core\Api\Response;
465
+ use Espo\Core\Exceptions\BadRequest;
466
+ use Espo\Core\Exceptions\Forbidden;
467
+ use stdClass;
468
+
469
+ class MyEntity extends Record
470
+ {
471
+ public function postActionCustomAction(Request $request, Response $response): stdClass
472
+ {
473
+ $id = $request->getRouteParam('id');
474
+
475
+ if (!$id) {
476
+ throw new BadRequest();
477
+ }
478
+
479
+ $data = $request->getParsedBody();
480
+
481
+ if (!$this->acl->check($this->name, 'edit')) {
482
+ throw new Forbidden();
483
+ }
484
+
485
+ // Delegate to service layer
486
+ $service = $this->getRecordService();
487
+ $result = $service->customAction($id, $data);
488
+
489
+ return $result->getValueMap();
490
+ }
491
+ }
492
+ ```
493
+
494
+ ### Step 3: Implement Service Method
495
+
496
+ ```php
497
+ <?php
498
+ namespace Espo\Modules\MyModule\Services;
499
+
500
+ use Espo\Services\Record;
501
+ use Espo\Core\Exceptions\NotFound;
502
+ use stdClass;
503
+
504
+ class MyEntity extends Record
505
+ {
506
+ public function customAction(string $id, stdClass $data): object
507
+ {
508
+ $entity = $this->getEntity($id);
509
+
510
+ if (!$entity) {
511
+ throw new NotFound();
512
+ }
513
+
514
+ // Business logic
515
+ $entity->set('status', $data->status ?? 'In Progress');
516
+ $entity->set('processedAt', date('Y-m-d H:i:s'));
517
+
518
+ $this->entityManager->saveEntity($entity);
519
+
520
+ return $entity;
521
+ }
522
+ }
523
+ ```
524
+
525
+ ### Step 4: Call from Frontend
526
+
527
+ ```javascript
528
+ this.ajaxPostRequest('MyEntity/' + id + '/customAction', {
529
+ status: 'Complete'
530
+ }).then(response => {
531
+ console.log('Action completed', response);
532
+ this.model.set(response);
533
+ });
534
+ ```
535
+
536
+ ## Custom Repositories
537
+
538
+ ### Creating Custom Repository
539
+
540
+ Create `src/files/custom/Espo/Modules/MyModule/Repositories/MyEntity.php`:
541
+
542
+ ```php
543
+ <?php
544
+ namespace Espo\Modules\MyModule\Repositories;
545
+
546
+ use Espo\Core\Repositories\Database;
547
+ use Espo\ORM\Entity;
548
+
549
+ class MyEntity extends Database
550
+ {
551
+ protected function beforeSave(Entity $entity, array $options = []): void
552
+ {
553
+ parent::beforeSave($entity, $options);
554
+
555
+ // Repository-level validation or data transformation
556
+ if ($entity->isNew()) {
557
+ $entity->set('customIdentifier', $this->generateIdentifier());
558
+ }
559
+ }
560
+
561
+ private function generateIdentifier(): string
562
+ {
563
+ // Generate unique identifier
564
+ $prefix = 'ME-';
565
+ $number = $this->getNewNumber();
566
+ return $prefix . str_pad($number, 6, '0', STR_PAD_LEFT);
567
+ }
568
+
569
+ private function getNewNumber(): int
570
+ {
571
+ $query = $this->entityManager
572
+ ->getQueryBuilder()
573
+ ->select()
574
+ ->from('MyEntity')
575
+ ->select('COUNT(*) as count')
576
+ ->build();
577
+
578
+ $sth = $this->entityManager->getQueryExecutor()->execute($query);
579
+ $row = $sth->fetch();
580
+
581
+ return ($row['count'] ?? 0) + 1;
582
+ }
583
+
584
+ public function findActive(): \Espo\ORM\Collection
585
+ {
586
+ return $this->where([
587
+ 'status!=' => ['Complete', 'Cancelled']
588
+ ])->find();
589
+ }
590
+ }
591
+ ```
592
+
593
+ ## Layouts
594
+
595
+ ### List Layout
596
+
597
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/layouts/MyEntity/list.json`:
598
+
599
+ ```json
600
+ [
601
+ {
602
+ "name": "name",
603
+ "width": "30"
604
+ },
605
+ {
606
+ "name": "status",
607
+ "width": "15"
608
+ },
609
+ {
610
+ "name": "priority",
611
+ "width": "15"
612
+ },
613
+ {
614
+ "name": "assignedUser",
615
+ "width": "15"
616
+ },
617
+ {
618
+ "name": "dueDate",
619
+ "width": "15"
620
+ },
621
+ {
622
+ "name": "createdAt",
623
+ "width": "10"
624
+ }
625
+ ]
626
+ ```
627
+
628
+ ### Detail Layout
629
+
630
+ Create `src/files/custom/Espo/Modules/MyModule/Resources/layouts/MyEntity/detail.json`:
631
+
632
+ ```json
633
+ [
634
+ {
635
+ "label": "Overview",
636
+ "rows": [
637
+ [
638
+ {"name": "name"},
639
+ {"name": "status"}
640
+ ],
641
+ [
642
+ {"name": "assignedUser"},
643
+ {"name": "priority"}
644
+ ],
645
+ [
646
+ {"name": "account"},
647
+ {"name": "dueDate"}
648
+ ],
649
+ [
650
+ {"name": "description", "fullWidth": true}
651
+ ]
652
+ ]
653
+ },
654
+ {
655
+ "label": "Contacts",
656
+ "rows": [
657
+ [
658
+ {"name": "contacts", "fullWidth": true}
659
+ ]
660
+ ]
661
+ }
662
+ ]
663
+ ```
664
+
665
+ ## Development Best Practices
666
+
667
+ ### Cache Rebuild Workflow
668
+
669
+ ```bash
670
+ # After any metadata changes
671
+ bin/command rebuild
672
+
673
+ # Clear cache only (faster, but may miss some changes)
674
+ bin/command clear-cache
675
+
676
+ # Hard rebuild (if issues persist)
677
+ rm -rf data/cache/*
678
+ bin/command rebuild
679
+ ```
680
+
681
+ ### Testing Extension Installation
682
+
683
+ ```bash
684
+ # Build extension
685
+ npm run build
686
+
687
+ # Install in test EspoCRM instance
688
+ # Administration > Extensions > Upload
689
+ # Upload build/MyExtension-1.0.0.zip
690
+
691
+ # After changes, rebuild extension and reinstall
692
+ npm run build
693
+ # Uninstall old version via Administration > Extensions
694
+ # Install new version
695
+ ```
696
+
697
+ ### Version Compatibility
698
+
699
+ ```php
700
+ // Check EspoCRM version in code
701
+ $version = $this->config->get('version');
702
+
703
+ if (version_compare($version, '8.0.0', '>=')) {
704
+ // EspoCRM 8.0+ features
705
+ }
706
+
707
+ // Use version-specific metadata
708
+ // For EspoCRM 7.x
709
+ custom/Espo/Modules/MyModule/Resources/metadata/entityDefs/MyEntity.json
710
+
711
+ // For EspoCRM 8.x+
712
+ custom/Espo/Modules/MyModule/Resources/metadata/entityDefs/MyEntity/MyEntity.json
713
+ ```
714
+
715
+ ### Debugging Development Issues
716
+
717
+ ```bash
718
+ # Enable debug mode
719
+ # data/config.php
720
+ 'logger' => [
721
+ 'level' => 'DEBUG',
722
+ ],
723
+
724
+ # Check logs
725
+ tail -f data/logs/espo-$(date +%Y-%m-%d).log
726
+
727
+ # Check for PHP errors
728
+ tail -f /var/log/apache2/error.log # or nginx error log
729
+ ```
730
+
731
+ ### Module Dependencies
732
+
733
+ ```json
734
+ // In manifest.json
735
+ {
736
+ "dependencies": {
737
+ "Advanced Pack": {
738
+ "version": ">=2.14.0"
739
+ }
740
+ }
741
+ }
742
+ ```