@devo-bmad-custom/agent-orchestration 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (714) hide show
  1. package/bin/bmad.js +36 -0
  2. package/lib/cli.js +137 -0
  3. package/lib/filter.js +73 -0
  4. package/lib/installer.js +787 -0
  5. package/package.json +30 -0
  6. package/src/.agents/skills/audit-website/README.md +20 -0
  7. package/src/.agents/skills/audit-website/SKILL.md +470 -0
  8. package/src/.agents/skills/audit-website/agents/openai.yaml +6 -0
  9. package/src/.agents/skills/audit-website/assets/icon-small.svg +41 -0
  10. package/src/.agents/skills/audit-website/references/OUTPUT-FORMAT.md +250 -0
  11. package/src/.agents/skills/clean-code-standards/SKILL.md +105 -0
  12. package/src/.agents/skills/excalidraw-dark-standard/SKILL.md +282 -0
  13. package/src/.agents/skills/excalidraw-diagram-generator/SKILL.md +613 -0
  14. package/src/.agents/skills/excalidraw-diagram-generator/references/element-types.md +497 -0
  15. package/src/.agents/skills/excalidraw-diagram-generator/references/excalidraw-schema.md +350 -0
  16. package/src/.agents/skills/excalidraw-diagram-generator/scripts/README.md +193 -0
  17. package/src/.agents/skills/excalidraw-diagram-generator/scripts/add-arrow.py +312 -0
  18. package/src/.agents/skills/excalidraw-diagram-generator/scripts/add-icon-to-diagram.py +404 -0
  19. package/src/.agents/skills/excalidraw-diagram-generator/scripts/split-excalidraw-library.py +183 -0
  20. package/src/.agents/skills/excalidraw-diagram-generator/templates/business-flow-swimlane-template.excalidraw +334 -0
  21. package/src/.agents/skills/excalidraw-diagram-generator/templates/class-diagram-template.excalidraw +558 -0
  22. package/src/.agents/skills/excalidraw-diagram-generator/templates/data-flow-diagram-template.excalidraw +279 -0
  23. package/src/.agents/skills/excalidraw-diagram-generator/templates/er-diagram-template.excalidraw +662 -0
  24. package/src/.agents/skills/excalidraw-diagram-generator/templates/flowchart-template.excalidraw +179 -0
  25. package/src/.agents/skills/excalidraw-diagram-generator/templates/mindmap-template.excalidraw +244 -0
  26. package/src/.agents/skills/excalidraw-diagram-generator/templates/relationship-template.excalidraw +145 -0
  27. package/src/.agents/skills/excalidraw-diagram-generator/templates/sequence-diagram-template.excalidraw +509 -0
  28. package/src/.agents/skills/frontend-responsive-design-standards/SKILL.md +434 -0
  29. package/src/.agents/skills/java-fundamentals/SKILL.md +116 -0
  30. package/src/.agents/skills/java-performance/SKILL.md +119 -0
  31. package/src/.agents/skills/next-best-practices/SKILL.md +153 -0
  32. package/src/.agents/skills/next-best-practices/async-patterns.md +87 -0
  33. package/src/.agents/skills/next-best-practices/bundling.md +180 -0
  34. package/src/.agents/skills/next-best-practices/data-patterns.md +297 -0
  35. package/src/.agents/skills/next-best-practices/debug-tricks.md +105 -0
  36. package/src/.agents/skills/next-best-practices/directives.md +73 -0
  37. package/src/.agents/skills/next-best-practices/error-handling.md +227 -0
  38. package/src/.agents/skills/next-best-practices/file-conventions.md +140 -0
  39. package/src/.agents/skills/next-best-practices/font.md +245 -0
  40. package/src/.agents/skills/next-best-practices/functions.md +108 -0
  41. package/src/.agents/skills/next-best-practices/hydration-error.md +91 -0
  42. package/src/.agents/skills/next-best-practices/image.md +173 -0
  43. package/src/.agents/skills/next-best-practices/metadata.md +301 -0
  44. package/src/.agents/skills/next-best-practices/parallel-routes.md +287 -0
  45. package/src/.agents/skills/next-best-practices/route-handlers.md +146 -0
  46. package/src/.agents/skills/next-best-practices/rsc-boundaries.md +159 -0
  47. package/src/.agents/skills/next-best-practices/runtime-selection.md +39 -0
  48. package/src/.agents/skills/next-best-practices/scripts.md +141 -0
  49. package/src/.agents/skills/next-best-practices/self-hosting.md +371 -0
  50. package/src/.agents/skills/next-best-practices/suspense-boundaries.md +67 -0
  51. package/src/.agents/skills/nextjs-app-router-patterns/SKILL.md +537 -0
  52. package/src/.agents/skills/postgresql-optimization/SKILL.md +404 -0
  53. package/src/.agents/skills/python-backend/SKILL.md +153 -0
  54. package/src/.agents/skills/python-fundamentals/SKILL.md +234 -0
  55. package/src/.agents/skills/python-performance/SKILL.md +404 -0
  56. package/src/.agents/skills/react-expert/SKILL.md +335 -0
  57. package/src/.agents/skills/redis-best-practices/SKILL.md +438 -0
  58. package/src/.agents/skills/security-best-practices/SKILL.md +288 -0
  59. package/src/.agents/skills/security-review/LICENSE +22 -0
  60. package/src/.agents/skills/security-review/SKILL.md +312 -0
  61. package/src/.agents/skills/security-review/infrastructure/docker.md +432 -0
  62. package/src/.agents/skills/security-review/languages/javascript.md +388 -0
  63. package/src/.agents/skills/security-review/languages/python.md +363 -0
  64. package/src/.agents/skills/security-review/references/api-security.md +519 -0
  65. package/src/.agents/skills/security-review/references/authentication.md +353 -0
  66. package/src/.agents/skills/security-review/references/authorization.md +372 -0
  67. package/src/.agents/skills/security-review/references/business-logic.md +443 -0
  68. package/src/.agents/skills/security-review/references/cryptography.md +329 -0
  69. package/src/.agents/skills/security-review/references/csrf.md +398 -0
  70. package/src/.agents/skills/security-review/references/data-protection.md +378 -0
  71. package/src/.agents/skills/security-review/references/deserialization.md +410 -0
  72. package/src/.agents/skills/security-review/references/error-handling.md +436 -0
  73. package/src/.agents/skills/security-review/references/file-security.md +457 -0
  74. package/src/.agents/skills/security-review/references/injection.md +259 -0
  75. package/src/.agents/skills/security-review/references/logging.md +433 -0
  76. package/src/.agents/skills/security-review/references/misconfiguration.md +435 -0
  77. package/src/.agents/skills/security-review/references/modern-threats.md +475 -0
  78. package/src/.agents/skills/security-review/references/ssrf.md +415 -0
  79. package/src/.agents/skills/security-review/references/supply-chain.md +405 -0
  80. package/src/.agents/skills/security-review/references/xss.md +336 -0
  81. package/src/.agents/skills/subagent-driven-development/SKILL.md +275 -0
  82. package/src/.agents/skills/subagent-driven-development/code-quality-reviewer-prompt.md +26 -0
  83. package/src/.agents/skills/subagent-driven-development/implementer-prompt.md +113 -0
  84. package/src/.agents/skills/subagent-driven-development/spec-reviewer-prompt.md +61 -0
  85. package/src/.agents/skills/systematic-debugging/CREATION-LOG.md +119 -0
  86. package/src/.agents/skills/systematic-debugging/SKILL.md +296 -0
  87. package/src/.agents/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
  88. package/src/.agents/skills/systematic-debugging/condition-based-waiting.md +115 -0
  89. package/src/.agents/skills/systematic-debugging/defense-in-depth.md +122 -0
  90. package/src/.agents/skills/systematic-debugging/find-polluter.sh +63 -0
  91. package/src/.agents/skills/systematic-debugging/root-cause-tracing.md +169 -0
  92. package/src/.agents/skills/systematic-debugging/test-academic.md +14 -0
  93. package/src/.agents/skills/systematic-debugging/test-pressure-1.md +58 -0
  94. package/src/.agents/skills/systematic-debugging/test-pressure-2.md +68 -0
  95. package/src/.agents/skills/systematic-debugging/test-pressure-3.md +69 -0
  96. package/src/.agents/skills/typescript-best-practices/SKILL.md +373 -0
  97. package/src/.agents/skills/ui-ux-pro-custom/SKILL.md +348 -0
  98. package/src/.agents/skills/ui-ux-pro-custom/data/charts.csv +26 -0
  99. package/src/.agents/skills/ui-ux-pro-custom/data/colors.csv +97 -0
  100. package/src/.agents/skills/ui-ux-pro-custom/data/icons.csv +101 -0
  101. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/SKILL.md +106 -0
  102. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/accessibility.md +475 -0
  103. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/animation.md +466 -0
  104. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/composition-locals.md +231 -0
  105. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/deprecated-patterns.md +323 -0
  106. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/lists-scrolling.md +400 -0
  107. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/modifiers.md +331 -0
  108. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/navigation.md +416 -0
  109. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/performance.md +446 -0
  110. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/side-effects.md +516 -0
  111. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/source-code/foundation-source.md +13327 -0
  112. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/source-code/material3-source.md +19097 -0
  113. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/source-code/navigation-source.md +2947 -0
  114. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/source-code/runtime-source.md +11316 -0
  115. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/source-code/ui-source.md +7896 -0
  116. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/state-management.md +377 -0
  117. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/styles-experimental.md +470 -0
  118. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/theming-material3.md +349 -0
  119. package/src/.agents/skills/ui-ux-pro-custom/data/jetpack-compose-expert-skill/references/view-composition.md +595 -0
  120. package/src/.agents/skills/ui-ux-pro-custom/data/landing.csv +31 -0
  121. package/src/.agents/skills/ui-ux-pro-custom/data/mobile-ui-layout.md +654 -0
  122. package/src/.agents/skills/ui-ux-pro-custom/data/products.csv +97 -0
  123. package/src/.agents/skills/ui-ux-pro-custom/data/react-performance.csv +45 -0
  124. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/astro.csv +54 -0
  125. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/flutter.csv +53 -0
  126. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/html-tailwind.csv +56 -0
  127. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/jetpack-compose.csv +53 -0
  128. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/nextjs.csv +53 -0
  129. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/nuxt-ui.csv +51 -0
  130. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/nuxtjs.csv +59 -0
  131. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/react-native.csv +56 -0
  132. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/react.csv +54 -0
  133. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/shadcn.csv +61 -0
  134. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/svelte.csv +54 -0
  135. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/swiftui.csv +51 -0
  136. package/src/.agents/skills/ui-ux-pro-custom/data/stacks/vue.csv +50 -0
  137. package/src/.agents/skills/ui-ux-pro-custom/data/styles.csv +68 -0
  138. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/alarmkit/SKILL.md +438 -0
  139. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/alarmkit/references/alarmkit-patterns.md +584 -0
  140. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-clips/SKILL.md +436 -0
  141. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-intents/SKILL.md +489 -0
  142. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-intents/references/appintents-advanced.md +1076 -0
  143. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-store-review/SKILL.md +340 -0
  144. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-store-review/references/privacy-manifest.md +90 -0
  145. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/app-store-review/references/review-checklists.md +106 -0
  146. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/apple-on-device-ai/SKILL.md +500 -0
  147. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/apple-on-device-ai/references/coreml-conversion.md +425 -0
  148. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/apple-on-device-ai/references/coreml-optimization.md +344 -0
  149. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/apple-on-device-ai/references/foundation-models.md +508 -0
  150. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/apple-on-device-ai/references/mlx-swift.md +285 -0
  151. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/authentication/SKILL.md +496 -0
  152. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/authentication/references/keychain-biometric.md +211 -0
  153. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/background-processing/SKILL.md +499 -0
  154. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/background-processing/references/background-task-patterns.md +390 -0
  155. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/callkit-voip/SKILL.md +461 -0
  156. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/callkit-voip/references/callkit-patterns.md +425 -0
  157. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/cloudkit-sync/SKILL.md +492 -0
  158. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/cloudkit-sync/references/cloudkit-patterns.md +461 -0
  159. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/codable-patterns/SKILL.md +467 -0
  160. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/contacts-framework/SKILL.md +425 -0
  161. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/contacts-framework/references/contacts-patterns.md +409 -0
  162. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-bluetooth/SKILL.md +491 -0
  163. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-bluetooth/references/ble-patterns.md +435 -0
  164. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-motion/SKILL.md +388 -0
  165. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-motion/references/motion-patterns.md +405 -0
  166. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-nfc/SKILL.md +495 -0
  167. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/core-nfc/references/nfc-patterns.md +420 -0
  168. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/coreml/SKILL.md +459 -0
  169. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/coreml/references/coreml-swift-integration.md +765 -0
  170. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/debugging-instruments/SKILL.md +422 -0
  171. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/debugging-instruments/references/instruments-guide.md +387 -0
  172. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/debugging-instruments/references/lldb-patterns.md +298 -0
  173. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/device-integrity/SKILL.md +477 -0
  174. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/energykit/SKILL.md +460 -0
  175. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/energykit/references/energykit-patterns.md +541 -0
  176. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/eventkit-calendar/SKILL.md +483 -0
  177. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/eventkit-calendar/references/eventkit-patterns.md +326 -0
  178. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/healthkit/SKILL.md +498 -0
  179. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/healthkit/references/healthkit-patterns.md +602 -0
  180. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/homekit-matter/SKILL.md +496 -0
  181. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/homekit-matter/references/matter-commissioning.md +455 -0
  182. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-accessibility/SKILL.md +301 -0
  183. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-accessibility/references/a11y-patterns.md +140 -0
  184. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-localization/SKILL.md +418 -0
  185. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-localization/references/formatstyle-locale.md +627 -0
  186. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-localization/references/string-catalogs.md +462 -0
  187. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-networking/SKILL.md +441 -0
  188. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-networking/references/background-websocket.md +862 -0
  189. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-networking/references/lightweight-clients.md +93 -0
  190. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-networking/references/network-framework.md +563 -0
  191. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-networking/references/urlsession-patterns.md +1116 -0
  192. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-security/SKILL.md +496 -0
  193. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-security/references/app-review-guidelines.md +174 -0
  194. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-security/references/cryptokit-advanced.md +297 -0
  195. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-security/references/file-storage-patterns.md +354 -0
  196. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/ios-security/references/privacy-manifest.md +117 -0
  197. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/live-activities/SKILL.md +500 -0
  198. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/live-activities/references/live-activity-patterns.md +868 -0
  199. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/mapkit-location/SKILL.md +485 -0
  200. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/mapkit-location/references/corelocation-patterns.md +730 -0
  201. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/mapkit-location/references/mapkit-patterns.md +748 -0
  202. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/metrickit-diagnostics/SKILL.md +479 -0
  203. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/musickit-audio/SKILL.md +395 -0
  204. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/musickit-audio/references/musickit-patterns.md +363 -0
  205. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/natural-language/SKILL.md +412 -0
  206. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/natural-language/references/translation-patterns.md +311 -0
  207. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/passkit-wallet/SKILL.md +398 -0
  208. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/passkit-wallet/references/wallet-passes.md +254 -0
  209. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/pencilkit-drawing/SKILL.md +387 -0
  210. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/pencilkit-drawing/references/paperkit-integration.md +376 -0
  211. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/pencilkit-drawing/references/pencilkit-patterns.md +302 -0
  212. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/permissionkit/SKILL.md +446 -0
  213. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/permissionkit/references/permissionkit-patterns.md +435 -0
  214. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/photos-camera-media/SKILL.md +501 -0
  215. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/photos-camera-media/references/av-playback.md +701 -0
  216. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/photos-camera-media/references/camera-capture.md +774 -0
  217. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/photos-camera-media/references/image-loading-caching.md +869 -0
  218. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/photos-camera-media/references/photospicker-patterns.md +597 -0
  219. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/push-notifications/SKILL.md +501 -0
  220. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/push-notifications/references/notification-patterns.md +677 -0
  221. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/push-notifications/references/rich-notifications.md +745 -0
  222. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/realitykit-ar/SKILL.md +479 -0
  223. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/realitykit-ar/references/realitykit-patterns.md +480 -0
  224. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/shareplay-activities/SKILL.md +483 -0
  225. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/shareplay-activities/references/shareplay-patterns.md +544 -0
  226. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/speech-recognition/SKILL.md +485 -0
  227. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/storekit/SKILL.md +478 -0
  228. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/storekit/references/app-review-guidelines.md +58 -0
  229. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/storekit/references/storekit-advanced.md +755 -0
  230. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-charts/SKILL.md +487 -0
  231. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-charts/references/charts-patterns.md +895 -0
  232. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-concurrency/SKILL.md +408 -0
  233. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-concurrency/references/approachable-concurrency.md +80 -0
  234. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-concurrency/references/swift-6-2-concurrency.md +233 -0
  235. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-concurrency/references/swiftui-concurrency.md +187 -0
  236. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-concurrency/references/synchronization-primitives.md +341 -0
  237. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-language/SKILL.md +498 -0
  238. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-language/references/swift-patterns-extended.md +505 -0
  239. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-testing/SKILL.md +467 -0
  240. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swift-testing/references/testing-patterns.md +504 -0
  241. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftdata/SKILL.md +334 -0
  242. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftdata/references/core-data-coexistence.md +504 -0
  243. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftdata/references/swiftdata-advanced.md +975 -0
  244. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftdata/references/swiftdata-queries.md +675 -0
  245. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-animation/SKILL.md +481 -0
  246. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-animation/references/animation-advanced.md +804 -0
  247. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-animation/references/core-animation-bridge.md +553 -0
  248. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-gestures/SKILL.md +450 -0
  249. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-gestures/references/gesture-patterns.md +425 -0
  250. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-layout-components/SKILL.md +336 -0
  251. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-layout-components/references/form.md +97 -0
  252. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-layout-components/references/grids.md +69 -0
  253. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-layout-components/references/list.md +99 -0
  254. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-layout-components/references/scrollview.md +147 -0
  255. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-liquid-glass/SKILL.md +325 -0
  256. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-liquid-glass/references/liquid-glass.md +387 -0
  257. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-navigation/SKILL.md +262 -0
  258. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-navigation/references/deeplinks.md +207 -0
  259. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-navigation/references/navigationstack.md +177 -0
  260. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-navigation/references/sheets.md +169 -0
  261. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-navigation/references/tabview.md +178 -0
  262. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-patterns/SKILL.md +381 -0
  263. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-patterns/references/architecture-patterns.md +486 -0
  264. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-patterns/references/deprecated-migration.md +1097 -0
  265. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-patterns/references/design-polish.md +780 -0
  266. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-patterns/references/platform-and-sharing.md +696 -0
  267. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-performance/SKILL.md +491 -0
  268. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-performance/references/demystify-swiftui-performance-wwdc23.md +46 -0
  269. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-performance/references/optimizing-swiftui-performance-instruments.md +29 -0
  270. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-performance/references/understanding-hangs-in-your-app.md +33 -0
  271. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-performance/references/understanding-improving-swiftui-performance.md +52 -0
  272. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-uikit-interop/SKILL.md +428 -0
  273. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-uikit-interop/references/hosting-migration.md +534 -0
  274. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/swiftui-uikit-interop/references/representable-recipes.md +1133 -0
  275. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/tipkit/SKILL.md +494 -0
  276. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/tipkit/references/tipkit-patterns.md +782 -0
  277. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/vision-framework/SKILL.md +475 -0
  278. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/vision-framework/references/vision-requests.md +736 -0
  279. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/vision-framework/references/visionkit-scanner.md +738 -0
  280. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/weatherkit/SKILL.md +410 -0
  281. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/weatherkit/references/weatherkit-patterns.md +567 -0
  282. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/widgetkit/SKILL.md +497 -0
  283. package/src/.agents/skills/ui-ux-pro-custom/data/swift-ios-skills/widgetkit/references/widgetkit-advanced.md +871 -0
  284. package/src/.agents/skills/ui-ux-pro-custom/data/typography.csv +58 -0
  285. package/src/.agents/skills/ui-ux-pro-custom/data/ui-reasoning.csv +101 -0
  286. package/src/.agents/skills/ui-ux-pro-custom/data/ux-guidelines.csv +100 -0
  287. package/src/.agents/skills/ui-ux-pro-custom/data/web-interface.csv +31 -0
  288. package/src/.agents/skills/ui-ux-pro-custom/scripts/core.py +253 -0
  289. package/src/.agents/skills/ui-ux-pro-custom/scripts/design_system.py +1067 -0
  290. package/src/.agents/skills/ui-ux-pro-custom/scripts/search.py +114 -0
  291. package/src/.agents/skills/ux-audit/SKILL.md +151 -0
  292. package/src/.agents/skills/websocket-engineer/SKILL.md +168 -0
  293. package/src/.agents/skills/websocket-engineer/references/alternatives.md +391 -0
  294. package/src/.agents/skills/websocket-engineer/references/patterns.md +400 -0
  295. package/src/.agents/skills/websocket-engineer/references/protocol.md +195 -0
  296. package/src/.agents/skills/websocket-engineer/references/scaling.md +333 -0
  297. package/src/.agents/skills/websocket-engineer/references/security.md +474 -0
  298. package/src/.agents/skills/writing-skills/SKILL.md +655 -0
  299. package/src/.agents/skills/writing-skills/anthropic-best-practices.md +1150 -0
  300. package/src/.agents/skills/writing-skills/examples/CLAUDE_MD_TESTING.md +189 -0
  301. package/src/.agents/skills/writing-skills/graphviz-conventions.dot +172 -0
  302. package/src/.agents/skills/writing-skills/persuasion-principles.md +187 -0
  303. package/src/.agents/skills/writing-skills/render-graphs.js +168 -0
  304. package/src/.agents/skills/writing-skills/testing-skills-with-subagents.md +384 -0
  305. package/src/.claude/commands/bmad-track-compact.md +19 -0
  306. package/src/.claude/commands/bmad-track-extended.md +19 -0
  307. package/src/.claude/commands/bmad-track-large.md +19 -0
  308. package/src/.claude/commands/bmad-track-medium.md +19 -0
  309. package/src/.claude/commands/bmad-track-nano.md +19 -0
  310. package/src/.claude/commands/bmad-track-rv.md +18 -0
  311. package/src/.claude/commands/bmad-track-small.md +19 -0
  312. package/src/_memory/config.yaml +11 -0
  313. package/src/_memory/master-orchestrator-sidecar/docs-index.md +3 -0
  314. package/src/_memory/master-orchestrator-sidecar/instructions.md +2566 -0
  315. package/src/_memory/master-orchestrator-sidecar/memories.md +8 -0
  316. package/src/_memory/master-orchestrator-sidecar/session-state.md +15 -0
  317. package/src/_memory/master-orchestrator-sidecar/triage-history.md +3 -0
  318. package/src/_memory/master-orchestrator-sidecar/workflows-overview.html +1230 -0
  319. package/src/_memory/skills/excalidraw/SKILL.md +78 -0
  320. package/src/_memory/skills/excalidraw/diagram-patterns.md +53 -0
  321. package/src/_memory/skills/nimbalyst-tracking/SKILL.md +103 -0
  322. package/src/_memory/skills/writing-skills/SKILL.md +655 -0
  323. package/src/bmb/agents/agent-builder.md +59 -0
  324. package/src/bmb/agents/module-builder.md +60 -0
  325. package/src/bmb/agents/workflow-builder.md +61 -0
  326. package/src/bmb/config.yaml +12 -0
  327. package/src/bmb/module-help.csv +13 -0
  328. package/src/bmb/workflows/agent/data/agent-architecture.md +258 -0
  329. package/src/bmb/workflows/agent/data/agent-compilation.md +185 -0
  330. package/src/bmb/workflows/agent/data/agent-menu-patterns.md +189 -0
  331. package/src/bmb/workflows/agent/data/agent-metadata.md +133 -0
  332. package/src/bmb/workflows/agent/data/agent-validation.md +111 -0
  333. package/src/bmb/workflows/agent/data/brainstorm-context.md +96 -0
  334. package/src/bmb/workflows/agent/data/communication-presets.csv +61 -0
  335. package/src/bmb/workflows/agent/data/critical-actions.md +75 -0
  336. package/src/bmb/workflows/agent/data/persona-properties.md +252 -0
  337. package/src/bmb/workflows/agent/data/principles-crafting.md +142 -0
  338. package/src/bmb/workflows/agent/data/reference/module-examples/architect.md +68 -0
  339. package/src/bmb/workflows/agent/data/reference/with-sidecar/journal-keeper/journal-keeper-sidecar/entries/yy-mm-dd-entry-template.md +17 -0
  340. package/src/bmb/workflows/agent/data/understanding-agent-types.md +126 -0
  341. package/src/bmb/workflows/agent/steps-c/step-01-brainstorm.md +129 -0
  342. package/src/bmb/workflows/agent/steps-c/step-02-discovery.md +170 -0
  343. package/src/bmb/workflows/agent/steps-c/step-03-sidecar-metadata.md +309 -0
  344. package/src/bmb/workflows/agent/steps-c/step-04-persona.md +213 -0
  345. package/src/bmb/workflows/agent/steps-c/step-05-commands-menu.md +179 -0
  346. package/src/bmb/workflows/agent/steps-c/step-06-activation.md +278 -0
  347. package/src/bmb/workflows/agent/steps-c/step-07-build-agent.md +316 -0
  348. package/src/bmb/workflows/agent/steps-c/step-08-celebrate.md +247 -0
  349. package/src/bmb/workflows/agent/steps-e/e-01-load-existing.md +221 -0
  350. package/src/bmb/workflows/agent/steps-e/e-02-discover-edits.md +195 -0
  351. package/src/bmb/workflows/agent/steps-e/e-03-placeholder.md +1 -0
  352. package/src/bmb/workflows/agent/steps-e/e-04-sidecar-metadata.md +126 -0
  353. package/src/bmb/workflows/agent/steps-e/e-05-persona.md +135 -0
  354. package/src/bmb/workflows/agent/steps-e/e-06-commands-menu.md +123 -0
  355. package/src/bmb/workflows/agent/steps-e/e-07-activation.md +124 -0
  356. package/src/bmb/workflows/agent/steps-e/e-08-edit-agent.md +197 -0
  357. package/src/bmb/workflows/agent/steps-e/e-09-celebrate.md +155 -0
  358. package/src/bmb/workflows/agent/steps-v/v-01-load-review.md +137 -0
  359. package/src/bmb/workflows/agent/steps-v/v-02a-validate-metadata.md +116 -0
  360. package/src/bmb/workflows/agent/steps-v/v-02b-validate-persona.md +124 -0
  361. package/src/bmb/workflows/agent/steps-v/v-02c-validate-menu.md +127 -0
  362. package/src/bmb/workflows/agent/steps-v/v-02d-validate-structure.md +134 -0
  363. package/src/bmb/workflows/agent/steps-v/v-02e-validate-sidecar.md +134 -0
  364. package/src/bmb/workflows/agent/steps-v/v-03-summary.md +104 -0
  365. package/src/bmb/workflows/agent/templates/agent-plan.template.md +5 -0
  366. package/src/bmb/workflows/agent/templates/agent-template.md +89 -0
  367. package/src/bmb/workflows/agent/workflow-create-agent.md +72 -0
  368. package/src/bmb/workflows/agent/workflow-edit-agent.md +75 -0
  369. package/src/bmb/workflows/agent/workflow-validate-agent.md +73 -0
  370. package/src/bmb/workflows/module/data/agent-architecture.md +179 -0
  371. package/src/bmb/workflows/module/data/agent-spec-template.md +79 -0
  372. package/src/bmb/workflows/module/data/module-standards.md +263 -0
  373. package/src/bmb/workflows/module/data/module-yaml-conventions.md +392 -0
  374. package/src/bmb/workflows/module/module-help-generate.md +254 -0
  375. package/src/bmb/workflows/module/steps-b/step-01-welcome.md +148 -0
  376. package/src/bmb/workflows/module/steps-b/step-02-spark.md +141 -0
  377. package/src/bmb/workflows/module/steps-b/step-03-module-type.md +149 -0
  378. package/src/bmb/workflows/module/steps-b/step-04-vision.md +83 -0
  379. package/src/bmb/workflows/module/steps-b/step-05-identity.md +97 -0
  380. package/src/bmb/workflows/module/steps-b/step-06-users.md +86 -0
  381. package/src/bmb/workflows/module/steps-b/step-07-value.md +76 -0
  382. package/src/bmb/workflows/module/steps-b/step-08-agents.md +97 -0
  383. package/src/bmb/workflows/module/steps-b/step-09-workflows.md +83 -0
  384. package/src/bmb/workflows/module/steps-b/step-10-tools.md +91 -0
  385. package/src/bmb/workflows/module/steps-b/step-11-scenarios.md +84 -0
  386. package/src/bmb/workflows/module/steps-b/step-12-creative.md +95 -0
  387. package/src/bmb/workflows/module/steps-b/step-13-review.md +105 -0
  388. package/src/bmb/workflows/module/steps-b/step-14-finalize.md +117 -0
  389. package/src/bmb/workflows/module/steps-c/step-01-load-brief.md +179 -0
  390. package/src/bmb/workflows/module/steps-c/step-01b-continue.md +82 -0
  391. package/src/bmb/workflows/module/steps-c/step-02-structure.md +105 -0
  392. package/src/bmb/workflows/module/steps-c/step-03-config.md +119 -0
  393. package/src/bmb/workflows/module/steps-c/step-04-agents.md +168 -0
  394. package/src/bmb/workflows/module/steps-c/step-05-workflows.md +184 -0
  395. package/src/bmb/workflows/module/steps-c/step-06-docs.md +401 -0
  396. package/src/bmb/workflows/module/steps-c/step-07-complete.md +152 -0
  397. package/src/bmb/workflows/module/steps-e/step-01-load-target.md +81 -0
  398. package/src/bmb/workflows/module/steps-e/step-02-select-edit.md +77 -0
  399. package/src/bmb/workflows/module/steps-e/step-03-apply-edit.md +77 -0
  400. package/src/bmb/workflows/module/steps-e/step-04-review.md +80 -0
  401. package/src/bmb/workflows/module/steps-e/step-05-confirm.md +75 -0
  402. package/src/bmb/workflows/module/steps-v/step-01-load-target.md +96 -0
  403. package/src/bmb/workflows/module/steps-v/step-02-file-structure.md +93 -0
  404. package/src/bmb/workflows/module/steps-v/step-03-module-yaml.md +99 -0
  405. package/src/bmb/workflows/module/steps-v/step-04-agent-specs.md +152 -0
  406. package/src/bmb/workflows/module/steps-v/step-05-workflow-specs.md +152 -0
  407. package/src/bmb/workflows/module/steps-v/step-06-documentation.md +143 -0
  408. package/src/bmb/workflows/module/steps-v/step-07-installation.md +102 -0
  409. package/src/bmb/workflows/module/steps-v/step-08-report.md +197 -0
  410. package/src/bmb/workflows/module/templates/brief-template.md +154 -0
  411. package/src/bmb/workflows/module/templates/workflow-spec-template.md +96 -0
  412. package/src/bmb/workflows/module/workflow-create-module-brief.md +71 -0
  413. package/src/bmb/workflows/module/workflow-create-module.md +86 -0
  414. package/src/bmb/workflows/module/workflow-edit-module.md +66 -0
  415. package/src/bmb/workflows/module/workflow-validate-module.md +66 -0
  416. package/src/bmb/workflows/workflow/data/architecture.md +150 -0
  417. package/src/bmb/workflows/workflow/data/common-workflow-tools.csv +19 -0
  418. package/src/bmb/workflows/workflow/data/csv-data-file-standards.md +53 -0
  419. package/src/bmb/workflows/workflow/data/frontmatter-standards.md +184 -0
  420. package/src/bmb/workflows/workflow/data/input-discovery-standards.md +191 -0
  421. package/src/bmb/workflows/workflow/data/intent-vs-prescriptive-spectrum.md +44 -0
  422. package/src/bmb/workflows/workflow/data/menu-handling-standards.md +133 -0
  423. package/src/bmb/workflows/workflow/data/output-format-standards.md +135 -0
  424. package/src/bmb/workflows/workflow/data/step-file-rules.md +235 -0
  425. package/src/bmb/workflows/workflow/data/step-type-patterns.md +257 -0
  426. package/src/bmb/workflows/workflow/data/subprocess-optimization-patterns.md +188 -0
  427. package/src/bmb/workflows/workflow/data/trimodal-workflow-structure.md +164 -0
  428. package/src/bmb/workflows/workflow/data/workflow-chaining-standards.md +222 -0
  429. package/src/bmb/workflows/workflow/data/workflow-examples.md +232 -0
  430. package/src/bmb/workflows/workflow/data/workflow-type-criteria.md +134 -0
  431. package/src/bmb/workflows/workflow/steps-c/step-00-conversion.md +263 -0
  432. package/src/bmb/workflows/workflow/steps-c/step-01-discovery.md +194 -0
  433. package/src/bmb/workflows/workflow/steps-c/step-01b-continuation.md +3 -0
  434. package/src/bmb/workflows/workflow/steps-c/step-02-classification.md +270 -0
  435. package/src/bmb/workflows/workflow/steps-c/step-03-requirements.md +283 -0
  436. package/src/bmb/workflows/workflow/steps-c/step-04-tools.md +282 -0
  437. package/src/bmb/workflows/workflow/steps-c/step-05-plan-review.md +243 -0
  438. package/src/bmb/workflows/workflow/steps-c/step-06-design.md +330 -0
  439. package/src/bmb/workflows/workflow/steps-c/step-07-foundation.md +239 -0
  440. package/src/bmb/workflows/workflow/steps-c/step-08-build-step-01.md +379 -0
  441. package/src/bmb/workflows/workflow/steps-c/step-09-build-next-step.md +350 -0
  442. package/src/bmb/workflows/workflow/steps-c/step-10-confirmation.md +322 -0
  443. package/src/bmb/workflows/workflow/steps-c/step-11-completion.md +191 -0
  444. package/src/bmb/workflows/workflow/steps-e/step-e-01-assess-workflow.md +237 -0
  445. package/src/bmb/workflows/workflow/steps-e/step-e-02-discover-edits.md +251 -0
  446. package/src/bmb/workflows/workflow/steps-e/step-e-03-fix-validation.md +254 -0
  447. package/src/bmb/workflows/workflow/steps-e/step-e-04-direct-edit.md +277 -0
  448. package/src/bmb/workflows/workflow/steps-e/step-e-05-apply-edit.md +154 -0
  449. package/src/bmb/workflows/workflow/steps-e/step-e-06-validate-after.md +190 -0
  450. package/src/bmb/workflows/workflow/steps-e/step-e-07-complete.md +206 -0
  451. package/src/bmb/workflows/workflow/steps-v/step-01-validate-max-mode.md +109 -0
  452. package/src/bmb/workflows/workflow/steps-v/step-01-validate.md +221 -0
  453. package/src/bmb/workflows/workflow/steps-v/step-01b-structure.md +152 -0
  454. package/src/bmb/workflows/workflow/steps-v/step-02-frontmatter-validation.md +199 -0
  455. package/src/bmb/workflows/workflow/steps-v/step-02b-path-violations.md +265 -0
  456. package/src/bmb/workflows/workflow/steps-v/step-03-menu-validation.md +164 -0
  457. package/src/bmb/workflows/workflow/steps-v/step-04-step-type-validation.md +211 -0
  458. package/src/bmb/workflows/workflow/steps-v/step-05-output-format-validation.md +200 -0
  459. package/src/bmb/workflows/workflow/steps-v/step-06-validation-design-check.md +195 -0
  460. package/src/bmb/workflows/workflow/steps-v/step-07-instruction-style-check.md +209 -0
  461. package/src/bmb/workflows/workflow/steps-v/step-08-collaborative-experience-check.md +199 -0
  462. package/src/bmb/workflows/workflow/steps-v/step-08b-subprocess-optimization.md +179 -0
  463. package/src/bmb/workflows/workflow/steps-v/step-09-cohesive-review.md +186 -0
  464. package/src/bmb/workflows/workflow/steps-v/step-10-report-complete.md +154 -0
  465. package/src/bmb/workflows/workflow/steps-v/step-11-plan-validation.md +237 -0
  466. package/src/bmb/workflows/workflow/templates/minimal-output-template.md +11 -0
  467. package/src/bmb/workflows/workflow/templates/step-01-init-continuable-template.md +241 -0
  468. package/src/bmb/workflows/workflow/templates/step-1b-template.md +224 -0
  469. package/src/bmb/workflows/workflow/templates/step-template.md +294 -0
  470. package/src/bmb/workflows/workflow/templates/workflow-template.md +102 -0
  471. package/src/bmb/workflows/workflow/workflow-create-workflow.md +79 -0
  472. package/src/bmb/workflows/workflow/workflow-edit-workflow.md +65 -0
  473. package/src/bmb/workflows/workflow/workflow-rework-workflow.md +65 -0
  474. package/src/bmb/workflows/workflow/workflow-validate-max-parallel-workflow.md +66 -0
  475. package/src/bmb/workflows/workflow/workflow-validate-workflow.md +65 -0
  476. package/src/bmm/agents/analyst.md +104 -0
  477. package/src/bmm/agents/architect.md +85 -0
  478. package/src/bmm/agents/dev.md +100 -0
  479. package/src/bmm/agents/pm.md +98 -0
  480. package/src/bmm/agents/qa.md +90 -0
  481. package/src/bmm/agents/quick-flow-solo-dev.md +92 -0
  482. package/src/bmm/agents/review-agent.md +129 -0
  483. package/src/bmm/agents/sm.md +90 -0
  484. package/src/bmm/agents/tech-writer/tech-writer.md +94 -0
  485. package/src/bmm/agents/ux-designer.md +124 -0
  486. package/src/bmm/data/project-context-template.md +26 -0
  487. package/src/bmm/module-help.csv +31 -0
  488. package/src/bmm/teams/default-party.csv +20 -0
  489. package/src/bmm/teams/team-fullstack.yaml +12 -0
  490. package/src/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  491. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +115 -0
  492. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +107 -0
  493. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +141 -0
  494. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +144 -0
  495. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +147 -0
  496. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +161 -0
  497. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +99 -0
  498. package/src/bmm/workflows/1-analysis/create-product-brief/workflow.md +57 -0
  499. package/src/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +87 -0
  500. package/src/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +156 -0
  501. package/src/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +165 -0
  502. package/src/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +140 -0
  503. package/src/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +152 -0
  504. package/src/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +345 -0
  505. package/src/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +92 -0
  506. package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +164 -0
  507. package/src/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +174 -0
  508. package/src/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +184 -0
  509. package/src/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +105 -0
  510. package/src/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +360 -0
  511. package/src/bmm/workflows/1-analysis/research/research.template.md +29 -0
  512. package/src/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +87 -0
  513. package/src/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +165 -0
  514. package/src/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +174 -0
  515. package/src/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +141 -0
  516. package/src/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +159 -0
  517. package/src/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +387 -0
  518. package/src/bmm/workflows/1-analysis/research/workflow-domain-research.md +54 -0
  519. package/src/bmm/workflows/1-analysis/research/workflow-market-research.md +54 -0
  520. package/src/bmm/workflows/1-analysis/research/workflow-technical-research.md +54 -0
  521. package/src/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +15 -0
  522. package/src/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  523. package/src/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  524. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +139 -0
  525. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +100 -0
  526. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +160 -0
  527. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02b-vision.md +88 -0
  528. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02c-executive-summary.md +99 -0
  529. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +169 -0
  530. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +156 -0
  531. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +136 -0
  532. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +176 -0
  533. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +184 -0
  534. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +174 -0
  535. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +175 -0
  536. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +189 -0
  537. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +162 -0
  538. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +79 -0
  539. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +183 -0
  540. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +149 -0
  541. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +187 -0
  542. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +192 -0
  543. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +108 -0
  544. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +166 -0
  545. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +131 -0
  546. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +150 -0
  547. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +118 -0
  548. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +155 -0
  549. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +170 -0
  550. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +158 -0
  551. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +147 -0
  552. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +182 -0
  553. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +202 -0
  554. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +148 -0
  555. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +201 -0
  556. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +179 -0
  557. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +164 -0
  558. package/src/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
  559. package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-create-prd.md +65 -0
  560. package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-edit-prd.md +65 -0
  561. package/src/bmm/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +63 -0
  562. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +63 -0
  563. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +63 -0
  564. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +106 -0
  565. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +111 -0
  566. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +115 -0
  567. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +127 -0
  568. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +167 -0
  569. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +143 -0
  570. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +118 -0
  571. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +154 -0
  572. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +136 -0
  573. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +165 -0
  574. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +135 -0
  575. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +192 -0
  576. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +101 -0
  577. package/src/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  578. package/src/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +45 -0
  579. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +185 -0
  580. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +129 -0
  581. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +130 -0
  582. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +93 -0
  583. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +196 -0
  584. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +129 -0
  585. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  586. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +54 -0
  587. package/src/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  588. package/src/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +13 -0
  589. package/src/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  590. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +89 -0
  591. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +82 -0
  592. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +106 -0
  593. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +138 -0
  594. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +129 -0
  595. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +166 -0
  596. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +186 -0
  597. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +163 -0
  598. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +38 -0
  599. package/src/bmm/workflows/3-solutioning/create-architecture/workflow.md +49 -0
  600. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +129 -0
  601. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +124 -0
  602. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +122 -0
  603. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +84 -0
  604. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  605. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +58 -0
  606. package/src/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
  607. package/src/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
  608. package/src/bmm/workflows/4-implementation/code-review/workflow.yaml +43 -0
  609. package/src/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
  610. package/src/bmm/workflows/4-implementation/correct-course/instructions.md +207 -0
  611. package/src/bmm/workflows/4-implementation/correct-course/workflow.yaml +53 -0
  612. package/src/bmm/workflows/4-implementation/create-story/checklist.md +159 -0
  613. package/src/bmm/workflows/4-implementation/create-story/instructions.xml +574 -0
  614. package/src/bmm/workflows/4-implementation/create-story/template.md +79 -0
  615. package/src/bmm/workflows/4-implementation/create-story/workflow.yaml +52 -0
  616. package/src/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
  617. package/src/bmm/workflows/4-implementation/dev-story/instructions.xml +493 -0
  618. package/src/bmm/workflows/4-implementation/dev-story/workflow.yaml +20 -0
  619. package/src/bmm/workflows/4-implementation/retrospective/instructions.md +1444 -0
  620. package/src/bmm/workflows/4-implementation/retrospective/workflow.yaml +52 -0
  621. package/src/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  622. package/src/bmm/workflows/4-implementation/sprint-planning/instructions.md +232 -0
  623. package/src/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
  624. package/src/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +52 -0
  625. package/src/bmm/workflows/4-implementation/sprint-status/instructions.md +230 -0
  626. package/src/bmm/workflows/4-implementation/sprint-status/workflow.yaml +25 -0
  627. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +158 -0
  628. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +122 -0
  629. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +93 -0
  630. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +93 -0
  631. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +87 -0
  632. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +146 -0
  633. package/src/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
  634. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +204 -0
  635. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +152 -0
  636. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +123 -0
  637. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +201 -0
  638. package/src/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
  639. package/src/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
  640. package/src/bmm/workflows/document-project/checklist.md +245 -0
  641. package/src/bmm/workflows/document-project/documentation-requirements.csv +12 -0
  642. package/src/bmm/workflows/document-project/instructions.md +130 -0
  643. package/src/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
  644. package/src/bmm/workflows/document-project/templates/index-template.md +169 -0
  645. package/src/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
  646. package/src/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  647. package/src/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
  648. package/src/bmm/workflows/document-project/workflow.yaml +22 -0
  649. package/src/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
  650. package/src/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
  651. package/src/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
  652. package/src/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
  653. package/src/bmm/workflows/generate-project-context/project-context-template.md +21 -0
  654. package/src/bmm/workflows/generate-project-context/steps/step-01-discover.md +184 -0
  655. package/src/bmm/workflows/generate-project-context/steps/step-02-generate.md +322 -0
  656. package/src/bmm/workflows/generate-project-context/steps/step-03-complete.md +235 -0
  657. package/src/bmm/workflows/generate-project-context/workflow.md +49 -0
  658. package/src/bmm/workflows/qa/automate/workflow.yaml +233 -0
  659. package/src/bmm/workflows/qa-generate-e2e-tests/checklist.md +33 -0
  660. package/src/bmm/workflows/qa-generate-e2e-tests/instructions.md +110 -0
  661. package/src/bmm/workflows/qa-generate-e2e-tests/workflow.yaml +42 -0
  662. package/src/core/agents/bmad-master.md +56 -0
  663. package/src/core/agents/master-orchestrator.md +54 -0
  664. package/src/core/config.yaml +9 -0
  665. package/src/core/module-help.csv +10 -0
  666. package/src/core/scripts/generate-loop-report.py +72 -0
  667. package/src/core/skills/prepare-to-merge/SKILL.md +77 -0
  668. package/src/core/tasks/editorial-review-prose.xml +102 -0
  669. package/src/core/tasks/editorial-review-structure.xml +208 -0
  670. package/src/core/tasks/help.md +86 -0
  671. package/src/core/tasks/index-docs.xml +65 -0
  672. package/src/core/tasks/review-adversarial-general.xml +66 -0
  673. package/src/core/tasks/review-adversarial-loop.xml +46 -0
  674. package/src/core/tasks/review-edge-case-hunter.xml +63 -0
  675. package/src/core/tasks/review-party-loop.xml +46 -0
  676. package/src/core/tasks/shard-doc.xml +108 -0
  677. package/src/core/tasks/workflow.xml +236 -0
  678. package/src/core/templates/review-loop-report.html +88 -0
  679. package/src/core/templates/review-loop-report.md +5 -0
  680. package/src/core/workflows/advanced-elicitation/methods.csv +51 -0
  681. package/src/core/workflows/advanced-elicitation/workflow.xml +118 -0
  682. package/src/core/workflows/brainstorming/brain-methods.csv +62 -0
  683. package/src/core/workflows/brainstorming/steps/step-01-session-setup.md +212 -0
  684. package/src/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  685. package/src/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  686. package/src/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  687. package/src/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  688. package/src/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  689. package/src/core/workflows/brainstorming/steps/step-02e-deep-dive.md +68 -0
  690. package/src/core/workflows/brainstorming/steps/step-03-technique-execution.md +403 -0
  691. package/src/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  692. package/src/core/workflows/brainstorming/template.md +15 -0
  693. package/src/core/workflows/brainstorming/workflow.md +60 -0
  694. package/src/core/workflows/extract-trackers/workflow.md +45 -0
  695. package/src/core/workflows/party-mode/steps/step-01-agent-loading.md +142 -0
  696. package/src/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  697. package/src/core/workflows/party-mode/steps/step-03-graceful-exit.md +168 -0
  698. package/src/core/workflows/party-mode/workflow.md +194 -0
  699. package/src/docs/dev/tmux/actions_popup.py +291 -0
  700. package/src/docs/dev/tmux/actions_popup.sh +110 -0
  701. package/src/docs/dev/tmux/claude_usage.sh +15 -0
  702. package/src/docs/dev/tmux/colors.conf +34 -0
  703. package/src/docs/dev/tmux/cpu_usage.sh +7 -0
  704. package/src/docs/dev/tmux/dispatch.sh +10 -0
  705. package/src/docs/dev/tmux/float_init.sh +13 -0
  706. package/src/docs/dev/tmux/float_term.sh +23 -0
  707. package/src/docs/dev/tmux/open_clip.sh +14 -0
  708. package/src/docs/dev/tmux/paste_clipboard.sh +13 -0
  709. package/src/docs/dev/tmux/paste_image_wrapper.sh +83 -0
  710. package/src/docs/dev/tmux/ram_usage.sh +3 -0
  711. package/src/docs/dev/tmux/title_sync.sh +54 -0
  712. package/src/docs/dev/tmux/tmux-setup.md +806 -0
  713. package/src/docs/dev/tmux/tmux.conf +127 -0
  714. package/src/docs/dev/tmux/xclip +18 -0
@@ -0,0 +1,1067 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ """
4
+ Design System Generator - Aggregates search results and applies reasoning
5
+ to generate comprehensive design system recommendations.
6
+
7
+ Usage:
8
+ from design_system import generate_design_system
9
+ result = generate_design_system("SaaS dashboard", "My Project")
10
+
11
+ # With persistence (Master + Overrides pattern)
12
+ result = generate_design_system("SaaS dashboard", "My Project", persist=True)
13
+ result = generate_design_system("SaaS dashboard", "My Project", persist=True, page="dashboard")
14
+ """
15
+
16
+ import csv
17
+ import json
18
+ import os
19
+ from datetime import datetime
20
+ from pathlib import Path
21
+ from core import search, DATA_DIR
22
+
23
+
24
+ # ============ CONFIGURATION ============
25
+ REASONING_FILE = "ui-reasoning.csv"
26
+
27
+ SEARCH_CONFIG = {
28
+ "product": {"max_results": 1},
29
+ "style": {"max_results": 3},
30
+ "color": {"max_results": 2},
31
+ "landing": {"max_results": 2},
32
+ "typography": {"max_results": 2}
33
+ }
34
+
35
+
36
+ # ============ DESIGN SYSTEM GENERATOR ============
37
+ class DesignSystemGenerator:
38
+ """Generates design system recommendations from aggregated searches."""
39
+
40
+ def __init__(self):
41
+ self.reasoning_data = self._load_reasoning()
42
+
43
+ def _load_reasoning(self) -> list:
44
+ """Load reasoning rules from CSV."""
45
+ filepath = DATA_DIR / REASONING_FILE
46
+ if not filepath.exists():
47
+ return []
48
+ with open(filepath, 'r', encoding='utf-8') as f:
49
+ return list(csv.DictReader(f))
50
+
51
+ def _multi_domain_search(self, query: str, style_priority: list = None) -> dict:
52
+ """Execute searches across multiple domains."""
53
+ results = {}
54
+ for domain, config in SEARCH_CONFIG.items():
55
+ if domain == "style" and style_priority:
56
+ # For style, also search with priority keywords
57
+ priority_query = " ".join(style_priority[:2]) if style_priority else query
58
+ combined_query = f"{query} {priority_query}"
59
+ results[domain] = search(combined_query, domain, config["max_results"])
60
+ else:
61
+ results[domain] = search(query, domain, config["max_results"])
62
+ return results
63
+
64
+ def _find_reasoning_rule(self, category: str) -> dict:
65
+ """Find matching reasoning rule for a category."""
66
+ category_lower = category.lower()
67
+
68
+ # Try exact match first
69
+ for rule in self.reasoning_data:
70
+ if rule.get("UI_Category", "").lower() == category_lower:
71
+ return rule
72
+
73
+ # Try partial match
74
+ for rule in self.reasoning_data:
75
+ ui_cat = rule.get("UI_Category", "").lower()
76
+ if ui_cat in category_lower or category_lower in ui_cat:
77
+ return rule
78
+
79
+ # Try keyword match
80
+ for rule in self.reasoning_data:
81
+ ui_cat = rule.get("UI_Category", "").lower()
82
+ keywords = ui_cat.replace("/", " ").replace("-", " ").split()
83
+ if any(kw in category_lower for kw in keywords):
84
+ return rule
85
+
86
+ return {}
87
+
88
+ def _apply_reasoning(self, category: str, search_results: dict) -> dict:
89
+ """Apply reasoning rules to search results."""
90
+ rule = self._find_reasoning_rule(category)
91
+
92
+ if not rule:
93
+ return {
94
+ "pattern": "Hero + Features + CTA",
95
+ "style_priority": ["Minimalism", "Flat Design"],
96
+ "color_mood": "Professional",
97
+ "typography_mood": "Clean",
98
+ "key_effects": "Subtle hover transitions",
99
+ "anti_patterns": "",
100
+ "decision_rules": {},
101
+ "severity": "MEDIUM"
102
+ }
103
+
104
+ # Parse decision rules JSON
105
+ decision_rules = {}
106
+ try:
107
+ decision_rules = json.loads(rule.get("Decision_Rules", "{}"))
108
+ except json.JSONDecodeError:
109
+ pass
110
+
111
+ return {
112
+ "pattern": rule.get("Recommended_Pattern", ""),
113
+ "style_priority": [s.strip() for s in rule.get("Style_Priority", "").split("+")],
114
+ "color_mood": rule.get("Color_Mood", ""),
115
+ "typography_mood": rule.get("Typography_Mood", ""),
116
+ "key_effects": rule.get("Key_Effects", ""),
117
+ "anti_patterns": rule.get("Anti_Patterns", ""),
118
+ "decision_rules": decision_rules,
119
+ "severity": rule.get("Severity", "MEDIUM")
120
+ }
121
+
122
+ def _select_best_match(self, results: list, priority_keywords: list) -> dict:
123
+ """Select best matching result based on priority keywords."""
124
+ if not results:
125
+ return {}
126
+
127
+ if not priority_keywords:
128
+ return results[0]
129
+
130
+ # First: try exact style name match
131
+ for priority in priority_keywords:
132
+ priority_lower = priority.lower().strip()
133
+ for result in results:
134
+ style_name = result.get("Style Category", "").lower()
135
+ if priority_lower in style_name or style_name in priority_lower:
136
+ return result
137
+
138
+ # Second: score by keyword match in all fields
139
+ scored = []
140
+ for result in results:
141
+ result_str = str(result).lower()
142
+ score = 0
143
+ for kw in priority_keywords:
144
+ kw_lower = kw.lower().strip()
145
+ # Higher score for style name match
146
+ if kw_lower in result.get("Style Category", "").lower():
147
+ score += 10
148
+ # Lower score for keyword field match
149
+ elif kw_lower in result.get("Keywords", "").lower():
150
+ score += 3
151
+ # Even lower for other field matches
152
+ elif kw_lower in result_str:
153
+ score += 1
154
+ scored.append((score, result))
155
+
156
+ scored.sort(key=lambda x: x[0], reverse=True)
157
+ return scored[0][1] if scored and scored[0][0] > 0 else results[0]
158
+
159
+ def _extract_results(self, search_result: dict) -> list:
160
+ """Extract results list from search result dict."""
161
+ return search_result.get("results", [])
162
+
163
+ def generate(self, query: str, project_name: str = None) -> dict:
164
+ """Generate complete design system recommendation."""
165
+ # Step 1: First search product to get category
166
+ product_result = search(query, "product", 1)
167
+ product_results = product_result.get("results", [])
168
+ category = "General"
169
+ if product_results:
170
+ category = product_results[0].get("Product Type", "General")
171
+
172
+ # Step 2: Get reasoning rules for this category
173
+ reasoning = self._apply_reasoning(category, {})
174
+ style_priority = reasoning.get("style_priority", [])
175
+
176
+ # Step 3: Multi-domain search with style priority hints
177
+ search_results = self._multi_domain_search(query, style_priority)
178
+ search_results["product"] = product_result # Reuse product search
179
+
180
+ # Step 4: Select best matches from each domain using priority
181
+ style_results = self._extract_results(search_results.get("style", {}))
182
+ color_results = self._extract_results(search_results.get("color", {}))
183
+ typography_results = self._extract_results(search_results.get("typography", {}))
184
+ landing_results = self._extract_results(search_results.get("landing", {}))
185
+
186
+ best_style = self._select_best_match(style_results, reasoning.get("style_priority", []))
187
+ best_color = color_results[0] if color_results else {}
188
+ best_typography = typography_results[0] if typography_results else {}
189
+ best_landing = landing_results[0] if landing_results else {}
190
+
191
+ # Step 5: Build final recommendation
192
+ # Combine effects from both reasoning and style search
193
+ style_effects = best_style.get("Effects & Animation", "")
194
+ reasoning_effects = reasoning.get("key_effects", "")
195
+ combined_effects = style_effects if style_effects else reasoning_effects
196
+
197
+ return {
198
+ "project_name": project_name or query.upper(),
199
+ "category": category,
200
+ "pattern": {
201
+ "name": best_landing.get("Pattern Name", reasoning.get("pattern", "Hero + Features + CTA")),
202
+ "sections": best_landing.get("Section Order", "Hero > Features > CTA"),
203
+ "cta_placement": best_landing.get("Primary CTA Placement", "Above fold"),
204
+ "color_strategy": best_landing.get("Color Strategy", ""),
205
+ "conversion": best_landing.get("Conversion Optimization", "")
206
+ },
207
+ "style": {
208
+ "name": best_style.get("Style Category", "Minimalism"),
209
+ "type": best_style.get("Type", "General"),
210
+ "effects": style_effects,
211
+ "keywords": best_style.get("Keywords", ""),
212
+ "best_for": best_style.get("Best For", ""),
213
+ "performance": best_style.get("Performance", ""),
214
+ "accessibility": best_style.get("Accessibility", "")
215
+ },
216
+ "colors": {
217
+ "primary": best_color.get("Primary (Hex)", "#2563EB"),
218
+ "secondary": best_color.get("Secondary (Hex)", "#3B82F6"),
219
+ "cta": best_color.get("CTA (Hex)", "#F97316"),
220
+ "background": best_color.get("Background (Hex)", "#F8FAFC"),
221
+ "text": best_color.get("Text (Hex)", "#1E293B"),
222
+ "notes": best_color.get("Notes", "")
223
+ },
224
+ "typography": {
225
+ "heading": best_typography.get("Heading Font", "Inter"),
226
+ "body": best_typography.get("Body Font", "Inter"),
227
+ "mood": best_typography.get("Mood/Style Keywords", reasoning.get("typography_mood", "")),
228
+ "best_for": best_typography.get("Best For", ""),
229
+ "google_fonts_url": best_typography.get("Google Fonts URL", ""),
230
+ "css_import": best_typography.get("CSS Import", "")
231
+ },
232
+ "key_effects": combined_effects,
233
+ "anti_patterns": reasoning.get("anti_patterns", ""),
234
+ "decision_rules": reasoning.get("decision_rules", {}),
235
+ "severity": reasoning.get("severity", "MEDIUM")
236
+ }
237
+
238
+
239
+ # ============ OUTPUT FORMATTERS ============
240
+ BOX_WIDTH = 90 # Wider box for more content
241
+
242
+ def format_ascii_box(design_system: dict) -> str:
243
+ """Format design system as ASCII box with emojis (MCP-style)."""
244
+ project = design_system.get("project_name", "PROJECT")
245
+ pattern = design_system.get("pattern", {})
246
+ style = design_system.get("style", {})
247
+ colors = design_system.get("colors", {})
248
+ typography = design_system.get("typography", {})
249
+ effects = design_system.get("key_effects", "")
250
+ anti_patterns = design_system.get("anti_patterns", "")
251
+
252
+ def wrap_text(text: str, prefix: str, width: int) -> list:
253
+ """Wrap long text into multiple lines."""
254
+ if not text:
255
+ return []
256
+ words = text.split()
257
+ lines = []
258
+ current_line = prefix
259
+ for word in words:
260
+ if len(current_line) + len(word) + 1 <= width - 2:
261
+ current_line += (" " if current_line != prefix else "") + word
262
+ else:
263
+ if current_line != prefix:
264
+ lines.append(current_line)
265
+ current_line = prefix + word
266
+ if current_line != prefix:
267
+ lines.append(current_line)
268
+ return lines
269
+
270
+ # Build sections from pattern
271
+ sections = pattern.get("sections", "").split(">")
272
+ sections = [s.strip() for s in sections if s.strip()]
273
+
274
+ # Build output lines
275
+ lines = []
276
+ w = BOX_WIDTH - 1
277
+
278
+ lines.append("+" + "-" * w + "+")
279
+ lines.append(f"| TARGET: {project} - RECOMMENDED DESIGN SYSTEM".ljust(BOX_WIDTH) + "|")
280
+ lines.append("+" + "-" * w + "+")
281
+ lines.append("|" + " " * BOX_WIDTH + "|")
282
+
283
+ # Pattern section
284
+ lines.append(f"| PATTERN: {pattern.get('name', '')}".ljust(BOX_WIDTH) + "|")
285
+ if pattern.get('conversion'):
286
+ lines.append(f"| Conversion: {pattern.get('conversion', '')}".ljust(BOX_WIDTH) + "|")
287
+ if pattern.get('cta_placement'):
288
+ lines.append(f"| CTA: {pattern.get('cta_placement', '')}".ljust(BOX_WIDTH) + "|")
289
+ lines.append("| Sections:".ljust(BOX_WIDTH) + "|")
290
+ for i, section in enumerate(sections, 1):
291
+ lines.append(f"| {i}. {section}".ljust(BOX_WIDTH) + "|")
292
+ lines.append("|" + " " * BOX_WIDTH + "|")
293
+
294
+ # Style section
295
+ lines.append(f"| STYLE: {style.get('name', '')}".ljust(BOX_WIDTH) + "|")
296
+ if style.get("keywords"):
297
+ for line in wrap_text(f"Keywords: {style.get('keywords', '')}", "| ", BOX_WIDTH):
298
+ lines.append(line.ljust(BOX_WIDTH) + "|")
299
+ if style.get("best_for"):
300
+ for line in wrap_text(f"Best For: {style.get('best_for', '')}", "| ", BOX_WIDTH):
301
+ lines.append(line.ljust(BOX_WIDTH) + "|")
302
+ if style.get("performance") or style.get("accessibility"):
303
+ perf_a11y = f"Performance: {style.get('performance', '')} | Accessibility: {style.get('accessibility', '')}"
304
+ lines.append(f"| {perf_a11y}".ljust(BOX_WIDTH) + "|")
305
+ lines.append("|" + " " * BOX_WIDTH + "|")
306
+
307
+ # Colors section
308
+ lines.append("| COLORS:".ljust(BOX_WIDTH) + "|")
309
+ lines.append(f"| Primary: {colors.get('primary', '')}".ljust(BOX_WIDTH) + "|")
310
+ lines.append(f"| Secondary: {colors.get('secondary', '')}".ljust(BOX_WIDTH) + "|")
311
+ lines.append(f"| CTA: {colors.get('cta', '')}".ljust(BOX_WIDTH) + "|")
312
+ lines.append(f"| Background: {colors.get('background', '')}".ljust(BOX_WIDTH) + "|")
313
+ lines.append(f"| Text: {colors.get('text', '')}".ljust(BOX_WIDTH) + "|")
314
+ if colors.get("notes"):
315
+ for line in wrap_text(f"Notes: {colors.get('notes', '')}", "| ", BOX_WIDTH):
316
+ lines.append(line.ljust(BOX_WIDTH) + "|")
317
+ lines.append("|" + " " * BOX_WIDTH + "|")
318
+
319
+ # Typography section
320
+ lines.append(f"| TYPOGRAPHY: {typography.get('heading', '')} / {typography.get('body', '')}".ljust(BOX_WIDTH) + "|")
321
+ if typography.get("mood"):
322
+ for line in wrap_text(f"Mood: {typography.get('mood', '')}", "| ", BOX_WIDTH):
323
+ lines.append(line.ljust(BOX_WIDTH) + "|")
324
+ if typography.get("best_for"):
325
+ for line in wrap_text(f"Best For: {typography.get('best_for', '')}", "| ", BOX_WIDTH):
326
+ lines.append(line.ljust(BOX_WIDTH) + "|")
327
+ if typography.get("google_fonts_url"):
328
+ lines.append(f"| Google Fonts: {typography.get('google_fonts_url', '')}".ljust(BOX_WIDTH) + "|")
329
+ if typography.get("css_import"):
330
+ lines.append(f"| CSS Import: {typography.get('css_import', '')[:70]}...".ljust(BOX_WIDTH) + "|")
331
+ lines.append("|" + " " * BOX_WIDTH + "|")
332
+
333
+ # Key Effects section
334
+ if effects:
335
+ lines.append("| KEY EFFECTS:".ljust(BOX_WIDTH) + "|")
336
+ for line in wrap_text(effects, "| ", BOX_WIDTH):
337
+ lines.append(line.ljust(BOX_WIDTH) + "|")
338
+ lines.append("|" + " " * BOX_WIDTH + "|")
339
+
340
+ # Anti-patterns section
341
+ if anti_patterns:
342
+ lines.append("| AVOID (Anti-patterns):".ljust(BOX_WIDTH) + "|")
343
+ for line in wrap_text(anti_patterns, "| ", BOX_WIDTH):
344
+ lines.append(line.ljust(BOX_WIDTH) + "|")
345
+ lines.append("|" + " " * BOX_WIDTH + "|")
346
+
347
+ # Pre-Delivery Checklist section
348
+ lines.append("| PRE-DELIVERY CHECKLIST:".ljust(BOX_WIDTH) + "|")
349
+ checklist_items = [
350
+ "[ ] No emojis as icons (use SVG: Heroicons/Lucide)",
351
+ "[ ] cursor-pointer on all clickable elements",
352
+ "[ ] Hover states with smooth transitions (150-300ms)",
353
+ "[ ] Light mode: text contrast 4.5:1 minimum",
354
+ "[ ] Focus states visible for keyboard nav",
355
+ "[ ] prefers-reduced-motion respected",
356
+ "[ ] Responsive: 375px, 768px, 1024px, 1440px"
357
+ ]
358
+ for item in checklist_items:
359
+ lines.append(f"| {item}".ljust(BOX_WIDTH) + "|")
360
+ lines.append("|" + " " * BOX_WIDTH + "|")
361
+
362
+ lines.append("+" + "-" * w + "+")
363
+
364
+ return "\n".join(lines)
365
+
366
+
367
+ def format_markdown(design_system: dict) -> str:
368
+ """Format design system as markdown."""
369
+ project = design_system.get("project_name", "PROJECT")
370
+ pattern = design_system.get("pattern", {})
371
+ style = design_system.get("style", {})
372
+ colors = design_system.get("colors", {})
373
+ typography = design_system.get("typography", {})
374
+ effects = design_system.get("key_effects", "")
375
+ anti_patterns = design_system.get("anti_patterns", "")
376
+
377
+ lines = []
378
+ lines.append(f"## Design System: {project}")
379
+ lines.append("")
380
+
381
+ # Pattern section
382
+ lines.append("### Pattern")
383
+ lines.append(f"- **Name:** {pattern.get('name', '')}")
384
+ if pattern.get('conversion'):
385
+ lines.append(f"- **Conversion Focus:** {pattern.get('conversion', '')}")
386
+ if pattern.get('cta_placement'):
387
+ lines.append(f"- **CTA Placement:** {pattern.get('cta_placement', '')}")
388
+ if pattern.get('color_strategy'):
389
+ lines.append(f"- **Color Strategy:** {pattern.get('color_strategy', '')}")
390
+ lines.append(f"- **Sections:** {pattern.get('sections', '')}")
391
+ lines.append("")
392
+
393
+ # Style section
394
+ lines.append("### Style")
395
+ lines.append(f"- **Name:** {style.get('name', '')}")
396
+ if style.get('keywords'):
397
+ lines.append(f"- **Keywords:** {style.get('keywords', '')}")
398
+ if style.get('best_for'):
399
+ lines.append(f"- **Best For:** {style.get('best_for', '')}")
400
+ if style.get('performance') or style.get('accessibility'):
401
+ lines.append(f"- **Performance:** {style.get('performance', '')} | **Accessibility:** {style.get('accessibility', '')}")
402
+ lines.append("")
403
+
404
+ # Colors section
405
+ lines.append("### Colors")
406
+ lines.append(f"| Role | Hex |")
407
+ lines.append(f"|------|-----|")
408
+ lines.append(f"| Primary | {colors.get('primary', '')} |")
409
+ lines.append(f"| Secondary | {colors.get('secondary', '')} |")
410
+ lines.append(f"| CTA | {colors.get('cta', '')} |")
411
+ lines.append(f"| Background | {colors.get('background', '')} |")
412
+ lines.append(f"| Text | {colors.get('text', '')} |")
413
+ if colors.get("notes"):
414
+ lines.append(f"\n*Notes: {colors.get('notes', '')}*")
415
+ lines.append("")
416
+
417
+ # Typography section
418
+ lines.append("### Typography")
419
+ lines.append(f"- **Heading:** {typography.get('heading', '')}")
420
+ lines.append(f"- **Body:** {typography.get('body', '')}")
421
+ if typography.get("mood"):
422
+ lines.append(f"- **Mood:** {typography.get('mood', '')}")
423
+ if typography.get("best_for"):
424
+ lines.append(f"- **Best For:** {typography.get('best_for', '')}")
425
+ if typography.get("google_fonts_url"):
426
+ lines.append(f"- **Google Fonts:** {typography.get('google_fonts_url', '')}")
427
+ if typography.get("css_import"):
428
+ lines.append(f"- **CSS Import:**")
429
+ lines.append(f"```css")
430
+ lines.append(f"{typography.get('css_import', '')}")
431
+ lines.append(f"```")
432
+ lines.append("")
433
+
434
+ # Key Effects section
435
+ if effects:
436
+ lines.append("### Key Effects")
437
+ lines.append(f"{effects}")
438
+ lines.append("")
439
+
440
+ # Anti-patterns section
441
+ if anti_patterns:
442
+ lines.append("### Avoid (Anti-patterns)")
443
+ newline_bullet = '\n- '
444
+ lines.append(f"- {anti_patterns.replace(' + ', newline_bullet)}")
445
+ lines.append("")
446
+
447
+ # Pre-Delivery Checklist section
448
+ lines.append("### Pre-Delivery Checklist")
449
+ lines.append("- [ ] No emojis as icons (use SVG: Heroicons/Lucide)")
450
+ lines.append("- [ ] cursor-pointer on all clickable elements")
451
+ lines.append("- [ ] Hover states with smooth transitions (150-300ms)")
452
+ lines.append("- [ ] Light mode: text contrast 4.5:1 minimum")
453
+ lines.append("- [ ] Focus states visible for keyboard nav")
454
+ lines.append("- [ ] prefers-reduced-motion respected")
455
+ lines.append("- [ ] Responsive: 375px, 768px, 1024px, 1440px")
456
+ lines.append("")
457
+
458
+ return "\n".join(lines)
459
+
460
+
461
+ # ============ MAIN ENTRY POINT ============
462
+ def generate_design_system(query: str, project_name: str = None, output_format: str = "ascii",
463
+ persist: bool = False, page: str = None, output_dir: str = None) -> str:
464
+ """
465
+ Main entry point for design system generation.
466
+
467
+ Args:
468
+ query: Search query (e.g., "SaaS dashboard", "e-commerce luxury")
469
+ project_name: Optional project name for output header
470
+ output_format: "ascii" (default) or "markdown"
471
+ persist: If True, save design system to design-system/ folder
472
+ page: Optional page name for page-specific override file
473
+ output_dir: Optional output directory (defaults to current working directory)
474
+
475
+ Returns:
476
+ Formatted design system string
477
+ """
478
+ generator = DesignSystemGenerator()
479
+ design_system = generator.generate(query, project_name)
480
+
481
+ # Persist to files if requested
482
+ if persist:
483
+ persist_design_system(design_system, page, output_dir, query)
484
+
485
+ if output_format == "markdown":
486
+ return format_markdown(design_system)
487
+ return format_ascii_box(design_system)
488
+
489
+
490
+ # ============ PERSISTENCE FUNCTIONS ============
491
+ def persist_design_system(design_system: dict, page: str = None, output_dir: str = None, page_query: str = None) -> dict:
492
+ """
493
+ Persist design system to design-system/<project>/ folder using Master + Overrides pattern.
494
+
495
+ Args:
496
+ design_system: The generated design system dictionary
497
+ page: Optional page name for page-specific override file
498
+ output_dir: Optional output directory (defaults to current working directory)
499
+ page_query: Optional query string for intelligent page override generation
500
+
501
+ Returns:
502
+ dict with created file paths and status
503
+ """
504
+ base_dir = Path(output_dir) if output_dir else Path.cwd()
505
+
506
+ # Use project name for project-specific folder
507
+ project_name = design_system.get("project_name", "default")
508
+ project_slug = project_name.lower().replace(' ', '-')
509
+
510
+ design_system_dir = base_dir / "design-system" / project_slug
511
+ pages_dir = design_system_dir / "pages"
512
+
513
+ created_files = []
514
+
515
+ # Create directories
516
+ design_system_dir.mkdir(parents=True, exist_ok=True)
517
+ pages_dir.mkdir(parents=True, exist_ok=True)
518
+
519
+ master_file = design_system_dir / "MASTER.md"
520
+
521
+ # Generate and write MASTER.md
522
+ master_content = format_master_md(design_system)
523
+ with open(master_file, 'w', encoding='utf-8') as f:
524
+ f.write(master_content)
525
+ created_files.append(str(master_file))
526
+
527
+ # If page is specified, create page override file with intelligent content
528
+ if page:
529
+ page_file = pages_dir / f"{page.lower().replace(' ', '-')}.md"
530
+ page_content = format_page_override_md(design_system, page, page_query)
531
+ with open(page_file, 'w', encoding='utf-8') as f:
532
+ f.write(page_content)
533
+ created_files.append(str(page_file))
534
+
535
+ return {
536
+ "status": "success",
537
+ "design_system_dir": str(design_system_dir),
538
+ "created_files": created_files
539
+ }
540
+
541
+
542
+ def format_master_md(design_system: dict) -> str:
543
+ """Format design system as MASTER.md with hierarchical override logic."""
544
+ project = design_system.get("project_name", "PROJECT")
545
+ pattern = design_system.get("pattern", {})
546
+ style = design_system.get("style", {})
547
+ colors = design_system.get("colors", {})
548
+ typography = design_system.get("typography", {})
549
+ effects = design_system.get("key_effects", "")
550
+ anti_patterns = design_system.get("anti_patterns", "")
551
+
552
+ timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
553
+
554
+ lines = []
555
+
556
+ # Logic header
557
+ lines.append("# Design System Master File")
558
+ lines.append("")
559
+ lines.append("> **LOGIC:** When building a specific page, first check `design-system/pages/[page-name].md`.")
560
+ lines.append("> If that file exists, its rules **override** this Master file.")
561
+ lines.append("> If not, strictly follow the rules below.")
562
+ lines.append("")
563
+ lines.append("---")
564
+ lines.append("")
565
+ lines.append(f"**Project:** {project}")
566
+ lines.append(f"**Generated:** {timestamp}")
567
+ lines.append(f"**Category:** {design_system.get('category', 'General')}")
568
+ lines.append("")
569
+ lines.append("---")
570
+ lines.append("")
571
+
572
+ # Global Rules section
573
+ lines.append("## Global Rules")
574
+ lines.append("")
575
+
576
+ # Color Palette
577
+ lines.append("### Color Palette")
578
+ lines.append("")
579
+ lines.append("| Role | Hex | CSS Variable |")
580
+ lines.append("|------|-----|--------------|")
581
+ lines.append(f"| Primary | `{colors.get('primary', '#2563EB')}` | `--color-primary` |")
582
+ lines.append(f"| Secondary | `{colors.get('secondary', '#3B82F6')}` | `--color-secondary` |")
583
+ lines.append(f"| CTA/Accent | `{colors.get('cta', '#F97316')}` | `--color-cta` |")
584
+ lines.append(f"| Background | `{colors.get('background', '#F8FAFC')}` | `--color-background` |")
585
+ lines.append(f"| Text | `{colors.get('text', '#1E293B')}` | `--color-text` |")
586
+ lines.append("")
587
+ if colors.get("notes"):
588
+ lines.append(f"**Color Notes:** {colors.get('notes', '')}")
589
+ lines.append("")
590
+
591
+ # Typography
592
+ lines.append("### Typography")
593
+ lines.append("")
594
+ lines.append(f"- **Heading Font:** {typography.get('heading', 'Inter')}")
595
+ lines.append(f"- **Body Font:** {typography.get('body', 'Inter')}")
596
+ if typography.get("mood"):
597
+ lines.append(f"- **Mood:** {typography.get('mood', '')}")
598
+ if typography.get("google_fonts_url"):
599
+ lines.append(f"- **Google Fonts:** [{typography.get('heading', '')} + {typography.get('body', '')}]({typography.get('google_fonts_url', '')})")
600
+ lines.append("")
601
+ if typography.get("css_import"):
602
+ lines.append("**CSS Import:**")
603
+ lines.append("```css")
604
+ lines.append(typography.get("css_import", ""))
605
+ lines.append("```")
606
+ lines.append("")
607
+
608
+ # Spacing Variables
609
+ lines.append("### Spacing Variables")
610
+ lines.append("")
611
+ lines.append("| Token | Value | Usage |")
612
+ lines.append("|-------|-------|-------|")
613
+ lines.append("| `--space-xs` | `4px` / `0.25rem` | Tight gaps |")
614
+ lines.append("| `--space-sm` | `8px` / `0.5rem` | Icon gaps, inline spacing |")
615
+ lines.append("| `--space-md` | `16px` / `1rem` | Standard padding |")
616
+ lines.append("| `--space-lg` | `24px` / `1.5rem` | Section padding |")
617
+ lines.append("| `--space-xl` | `32px` / `2rem` | Large gaps |")
618
+ lines.append("| `--space-2xl` | `48px` / `3rem` | Section margins |")
619
+ lines.append("| `--space-3xl` | `64px` / `4rem` | Hero padding |")
620
+ lines.append("")
621
+
622
+ # Shadow Depths
623
+ lines.append("### Shadow Depths")
624
+ lines.append("")
625
+ lines.append("| Level | Value | Usage |")
626
+ lines.append("|-------|-------|-------|")
627
+ lines.append("| `--shadow-sm` | `0 1px 2px rgba(0,0,0,0.05)` | Subtle lift |")
628
+ lines.append("| `--shadow-md` | `0 4px 6px rgba(0,0,0,0.1)` | Cards, buttons |")
629
+ lines.append("| `--shadow-lg` | `0 10px 15px rgba(0,0,0,0.1)` | Modals, dropdowns |")
630
+ lines.append("| `--shadow-xl` | `0 20px 25px rgba(0,0,0,0.15)` | Hero images, featured cards |")
631
+ lines.append("")
632
+
633
+ # Component Specs section
634
+ lines.append("---")
635
+ lines.append("")
636
+ lines.append("## Component Specs")
637
+ lines.append("")
638
+
639
+ # Buttons
640
+ lines.append("### Buttons")
641
+ lines.append("")
642
+ lines.append("```css")
643
+ lines.append("/* Primary Button */")
644
+ lines.append(".btn-primary {")
645
+ lines.append(f" background: {colors.get('cta', '#F97316')};")
646
+ lines.append(" color: white;")
647
+ lines.append(" padding: 12px 24px;")
648
+ lines.append(" border-radius: 8px;")
649
+ lines.append(" font-weight: 600;")
650
+ lines.append(" transition: all 200ms ease;")
651
+ lines.append(" cursor: pointer;")
652
+ lines.append("}")
653
+ lines.append("")
654
+ lines.append(".btn-primary:hover {")
655
+ lines.append(" opacity: 0.9;")
656
+ lines.append(" transform: translateY(-1px);")
657
+ lines.append("}")
658
+ lines.append("")
659
+ lines.append("/* Secondary Button */")
660
+ lines.append(".btn-secondary {")
661
+ lines.append(f" background: transparent;")
662
+ lines.append(f" color: {colors.get('primary', '#2563EB')};")
663
+ lines.append(f" border: 2px solid {colors.get('primary', '#2563EB')};")
664
+ lines.append(" padding: 12px 24px;")
665
+ lines.append(" border-radius: 8px;")
666
+ lines.append(" font-weight: 600;")
667
+ lines.append(" transition: all 200ms ease;")
668
+ lines.append(" cursor: pointer;")
669
+ lines.append("}")
670
+ lines.append("```")
671
+ lines.append("")
672
+
673
+ # Cards
674
+ lines.append("### Cards")
675
+ lines.append("")
676
+ lines.append("```css")
677
+ lines.append(".card {")
678
+ lines.append(f" background: {colors.get('background', '#FFFFFF')};")
679
+ lines.append(" border-radius: 12px;")
680
+ lines.append(" padding: 24px;")
681
+ lines.append(" box-shadow: var(--shadow-md);")
682
+ lines.append(" transition: all 200ms ease;")
683
+ lines.append(" cursor: pointer;")
684
+ lines.append("}")
685
+ lines.append("")
686
+ lines.append(".card:hover {")
687
+ lines.append(" box-shadow: var(--shadow-lg);")
688
+ lines.append(" transform: translateY(-2px);")
689
+ lines.append("}")
690
+ lines.append("```")
691
+ lines.append("")
692
+
693
+ # Inputs
694
+ lines.append("### Inputs")
695
+ lines.append("")
696
+ lines.append("```css")
697
+ lines.append(".input {")
698
+ lines.append(" padding: 12px 16px;")
699
+ lines.append(" border: 1px solid #E2E8F0;")
700
+ lines.append(" border-radius: 8px;")
701
+ lines.append(" font-size: 16px;")
702
+ lines.append(" transition: border-color 200ms ease;")
703
+ lines.append("}")
704
+ lines.append("")
705
+ lines.append(".input:focus {")
706
+ lines.append(f" border-color: {colors.get('primary', '#2563EB')};")
707
+ lines.append(" outline: none;")
708
+ lines.append(f" box-shadow: 0 0 0 3px {colors.get('primary', '#2563EB')}20;")
709
+ lines.append("}")
710
+ lines.append("```")
711
+ lines.append("")
712
+
713
+ # Modals
714
+ lines.append("### Modals")
715
+ lines.append("")
716
+ lines.append("```css")
717
+ lines.append(".modal-overlay {")
718
+ lines.append(" background: rgba(0, 0, 0, 0.5);")
719
+ lines.append(" backdrop-filter: blur(4px);")
720
+ lines.append("}")
721
+ lines.append("")
722
+ lines.append(".modal {")
723
+ lines.append(" background: white;")
724
+ lines.append(" border-radius: 16px;")
725
+ lines.append(" padding: 32px;")
726
+ lines.append(" box-shadow: var(--shadow-xl);")
727
+ lines.append(" max-width: 500px;")
728
+ lines.append(" width: 90%;")
729
+ lines.append("}")
730
+ lines.append("```")
731
+ lines.append("")
732
+
733
+ # Style section
734
+ lines.append("---")
735
+ lines.append("")
736
+ lines.append("## Style Guidelines")
737
+ lines.append("")
738
+ lines.append(f"**Style:** {style.get('name', 'Minimalism')}")
739
+ lines.append("")
740
+ if style.get("keywords"):
741
+ lines.append(f"**Keywords:** {style.get('keywords', '')}")
742
+ lines.append("")
743
+ if style.get("best_for"):
744
+ lines.append(f"**Best For:** {style.get('best_for', '')}")
745
+ lines.append("")
746
+ if effects:
747
+ lines.append(f"**Key Effects:** {effects}")
748
+ lines.append("")
749
+
750
+ # Layout Pattern
751
+ lines.append("### Page Pattern")
752
+ lines.append("")
753
+ lines.append(f"**Pattern Name:** {pattern.get('name', '')}")
754
+ lines.append("")
755
+ if pattern.get('conversion'):
756
+ lines.append(f"- **Conversion Strategy:** {pattern.get('conversion', '')}")
757
+ if pattern.get('cta_placement'):
758
+ lines.append(f"- **CTA Placement:** {pattern.get('cta_placement', '')}")
759
+ lines.append(f"- **Section Order:** {pattern.get('sections', '')}")
760
+ lines.append("")
761
+
762
+ # Anti-Patterns section
763
+ lines.append("---")
764
+ lines.append("")
765
+ lines.append("## Anti-Patterns (Do NOT Use)")
766
+ lines.append("")
767
+ if anti_patterns:
768
+ anti_list = [a.strip() for a in anti_patterns.split("+")]
769
+ for anti in anti_list:
770
+ if anti:
771
+ lines.append(f"- ❌ {anti}")
772
+ lines.append("")
773
+ lines.append("### Additional Forbidden Patterns")
774
+ lines.append("")
775
+ lines.append("- ❌ **Emojis as icons** — Use SVG icons (Heroicons, Lucide, Simple Icons)")
776
+ lines.append("- ❌ **Missing cursor:pointer** — All clickable elements must have cursor:pointer")
777
+ lines.append("- ❌ **Layout-shifting hovers** — Avoid scale transforms that shift layout")
778
+ lines.append("- ❌ **Low contrast text** — Maintain 4.5:1 minimum contrast ratio")
779
+ lines.append("- ❌ **Instant state changes** — Always use transitions (150-300ms)")
780
+ lines.append("- ❌ **Invisible focus states** — Focus states must be visible for a11y")
781
+ lines.append("")
782
+
783
+ # Pre-Delivery Checklist
784
+ lines.append("---")
785
+ lines.append("")
786
+ lines.append("## Pre-Delivery Checklist")
787
+ lines.append("")
788
+ lines.append("Before delivering any UI code, verify:")
789
+ lines.append("")
790
+ lines.append("- [ ] No emojis used as icons (use SVG instead)")
791
+ lines.append("- [ ] All icons from consistent icon set (Heroicons/Lucide)")
792
+ lines.append("- [ ] `cursor-pointer` on all clickable elements")
793
+ lines.append("- [ ] Hover states with smooth transitions (150-300ms)")
794
+ lines.append("- [ ] Light mode: text contrast 4.5:1 minimum")
795
+ lines.append("- [ ] Focus states visible for keyboard navigation")
796
+ lines.append("- [ ] `prefers-reduced-motion` respected")
797
+ lines.append("- [ ] Responsive: 375px, 768px, 1024px, 1440px")
798
+ lines.append("- [ ] No content hidden behind fixed navbars")
799
+ lines.append("- [ ] No horizontal scroll on mobile")
800
+ lines.append("")
801
+
802
+ return "\n".join(lines)
803
+
804
+
805
+ def format_page_override_md(design_system: dict, page_name: str, page_query: str = None) -> str:
806
+ """Format a page-specific override file with intelligent AI-generated content."""
807
+ project = design_system.get("project_name", "PROJECT")
808
+ timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
809
+ page_title = page_name.replace("-", " ").replace("_", " ").title()
810
+
811
+ # Detect page type and generate intelligent overrides
812
+ page_overrides = _generate_intelligent_overrides(page_name, page_query, design_system)
813
+
814
+ lines = []
815
+
816
+ lines.append(f"# {page_title} Page Overrides")
817
+ lines.append("")
818
+ lines.append(f"> **PROJECT:** {project}")
819
+ lines.append(f"> **Generated:** {timestamp}")
820
+ lines.append(f"> **Page Type:** {page_overrides.get('page_type', 'General')}")
821
+ lines.append("")
822
+ lines.append("> ⚠️ **IMPORTANT:** Rules in this file **override** the Master file (`design-system/MASTER.md`).")
823
+ lines.append("> Only deviations from the Master are documented here. For all other rules, refer to the Master.")
824
+ lines.append("")
825
+ lines.append("---")
826
+ lines.append("")
827
+
828
+ # Page-specific rules with actual content
829
+ lines.append("## Page-Specific Rules")
830
+ lines.append("")
831
+
832
+ # Layout Overrides
833
+ lines.append("### Layout Overrides")
834
+ lines.append("")
835
+ layout = page_overrides.get("layout", {})
836
+ if layout:
837
+ for key, value in layout.items():
838
+ lines.append(f"- **{key}:** {value}")
839
+ else:
840
+ lines.append("- No overrides — use Master layout")
841
+ lines.append("")
842
+
843
+ # Spacing Overrides
844
+ lines.append("### Spacing Overrides")
845
+ lines.append("")
846
+ spacing = page_overrides.get("spacing", {})
847
+ if spacing:
848
+ for key, value in spacing.items():
849
+ lines.append(f"- **{key}:** {value}")
850
+ else:
851
+ lines.append("- No overrides — use Master spacing")
852
+ lines.append("")
853
+
854
+ # Typography Overrides
855
+ lines.append("### Typography Overrides")
856
+ lines.append("")
857
+ typography = page_overrides.get("typography", {})
858
+ if typography:
859
+ for key, value in typography.items():
860
+ lines.append(f"- **{key}:** {value}")
861
+ else:
862
+ lines.append("- No overrides — use Master typography")
863
+ lines.append("")
864
+
865
+ # Color Overrides
866
+ lines.append("### Color Overrides")
867
+ lines.append("")
868
+ colors = page_overrides.get("colors", {})
869
+ if colors:
870
+ for key, value in colors.items():
871
+ lines.append(f"- **{key}:** {value}")
872
+ else:
873
+ lines.append("- No overrides — use Master colors")
874
+ lines.append("")
875
+
876
+ # Component Overrides
877
+ lines.append("### Component Overrides")
878
+ lines.append("")
879
+ components = page_overrides.get("components", [])
880
+ if components:
881
+ for comp in components:
882
+ lines.append(f"- {comp}")
883
+ else:
884
+ lines.append("- No overrides — use Master component specs")
885
+ lines.append("")
886
+
887
+ # Page-Specific Components
888
+ lines.append("---")
889
+ lines.append("")
890
+ lines.append("## Page-Specific Components")
891
+ lines.append("")
892
+ unique_components = page_overrides.get("unique_components", [])
893
+ if unique_components:
894
+ for comp in unique_components:
895
+ lines.append(f"- {comp}")
896
+ else:
897
+ lines.append("- No unique components for this page")
898
+ lines.append("")
899
+
900
+ # Recommendations
901
+ lines.append("---")
902
+ lines.append("")
903
+ lines.append("## Recommendations")
904
+ lines.append("")
905
+ recommendations = page_overrides.get("recommendations", [])
906
+ if recommendations:
907
+ for rec in recommendations:
908
+ lines.append(f"- {rec}")
909
+ lines.append("")
910
+
911
+ return "\n".join(lines)
912
+
913
+
914
+ def _generate_intelligent_overrides(page_name: str, page_query: str, design_system: dict) -> dict:
915
+ """
916
+ Generate intelligent overrides based on page type using layered search.
917
+
918
+ Uses the existing search infrastructure to find relevant style, UX, and layout
919
+ data instead of hardcoded page types.
920
+ """
921
+ from core import search
922
+
923
+ page_lower = page_name.lower()
924
+ query_lower = (page_query or "").lower()
925
+ combined_context = f"{page_lower} {query_lower}"
926
+
927
+ # Search across multiple domains for page-specific guidance
928
+ style_search = search(combined_context, "style", max_results=1)
929
+ ux_search = search(combined_context, "ux", max_results=3)
930
+ landing_search = search(combined_context, "landing", max_results=1)
931
+
932
+ # Extract results from search response
933
+ style_results = style_search.get("results", [])
934
+ ux_results = ux_search.get("results", [])
935
+ landing_results = landing_search.get("results", [])
936
+
937
+ # Detect page type from search results or context
938
+ page_type = _detect_page_type(combined_context, style_results)
939
+
940
+ # Build overrides from search results
941
+ layout = {}
942
+ spacing = {}
943
+ typography = {}
944
+ colors = {}
945
+ components = []
946
+ unique_components = []
947
+ recommendations = []
948
+
949
+ # Extract style-based overrides
950
+ if style_results:
951
+ style = style_results[0]
952
+ style_name = style.get("Style Category", "")
953
+ keywords = style.get("Keywords", "")
954
+ best_for = style.get("Best For", "")
955
+ effects = style.get("Effects & Animation", "")
956
+
957
+ # Infer layout from style keywords
958
+ if any(kw in keywords.lower() for kw in ["data", "dense", "dashboard", "grid"]):
959
+ layout["Max Width"] = "1400px or full-width"
960
+ layout["Grid"] = "12-column grid for data flexibility"
961
+ spacing["Content Density"] = "High — optimize for information display"
962
+ elif any(kw in keywords.lower() for kw in ["minimal", "simple", "clean", "single"]):
963
+ layout["Max Width"] = "800px (narrow, focused)"
964
+ layout["Layout"] = "Single column, centered"
965
+ spacing["Content Density"] = "Low — focus on clarity"
966
+ else:
967
+ layout["Max Width"] = "1200px (standard)"
968
+ layout["Layout"] = "Full-width sections, centered content"
969
+
970
+ if effects:
971
+ recommendations.append(f"Effects: {effects}")
972
+
973
+ # Extract UX guidelines as recommendations
974
+ for ux in ux_results:
975
+ category = ux.get("Category", "")
976
+ do_text = ux.get("Do", "")
977
+ dont_text = ux.get("Don't", "")
978
+ if do_text:
979
+ recommendations.append(f"{category}: {do_text}")
980
+ if dont_text:
981
+ components.append(f"Avoid: {dont_text}")
982
+
983
+ # Extract landing pattern info for section structure
984
+ if landing_results:
985
+ landing = landing_results[0]
986
+ sections = landing.get("Section Order", "")
987
+ cta_placement = landing.get("Primary CTA Placement", "")
988
+ color_strategy = landing.get("Color Strategy", "")
989
+
990
+ if sections:
991
+ layout["Sections"] = sections
992
+ if cta_placement:
993
+ recommendations.append(f"CTA Placement: {cta_placement}")
994
+ if color_strategy:
995
+ colors["Strategy"] = color_strategy
996
+
997
+ # Add page-type specific defaults if no search results
998
+ if not layout:
999
+ layout["Max Width"] = "1200px"
1000
+ layout["Layout"] = "Responsive grid"
1001
+
1002
+ if not recommendations:
1003
+ recommendations = [
1004
+ "Refer to MASTER.md for all design rules",
1005
+ "Add specific overrides as needed for this page"
1006
+ ]
1007
+
1008
+ return {
1009
+ "page_type": page_type,
1010
+ "layout": layout,
1011
+ "spacing": spacing,
1012
+ "typography": typography,
1013
+ "colors": colors,
1014
+ "components": components,
1015
+ "unique_components": unique_components,
1016
+ "recommendations": recommendations
1017
+ }
1018
+
1019
+
1020
+ def _detect_page_type(context: str, style_results: list) -> str:
1021
+ """Detect page type from context and search results."""
1022
+ context_lower = context.lower()
1023
+
1024
+ # Check for common page type patterns
1025
+ page_patterns = [
1026
+ (["dashboard", "admin", "analytics", "data", "metrics", "stats", "monitor", "overview"], "Dashboard / Data View"),
1027
+ (["checkout", "payment", "cart", "purchase", "order", "billing"], "Checkout / Payment"),
1028
+ (["settings", "profile", "account", "preferences", "config"], "Settings / Profile"),
1029
+ (["landing", "marketing", "homepage", "hero", "home", "promo"], "Landing / Marketing"),
1030
+ (["login", "signin", "signup", "register", "auth", "password"], "Authentication"),
1031
+ (["pricing", "plans", "subscription", "tiers", "packages"], "Pricing / Plans"),
1032
+ (["blog", "article", "post", "news", "content", "story"], "Blog / Article"),
1033
+ (["product", "item", "detail", "pdp", "shop", "store"], "Product Detail"),
1034
+ (["search", "results", "browse", "filter", "catalog", "list"], "Search Results"),
1035
+ (["empty", "404", "error", "not found", "zero"], "Empty State"),
1036
+ ]
1037
+
1038
+ for keywords, page_type in page_patterns:
1039
+ if any(kw in context_lower for kw in keywords):
1040
+ return page_type
1041
+
1042
+ # Fallback: try to infer from style results
1043
+ if style_results:
1044
+ style_name = style_results[0].get("Style Category", "").lower()
1045
+ best_for = style_results[0].get("Best For", "").lower()
1046
+
1047
+ if "dashboard" in best_for or "data" in best_for:
1048
+ return "Dashboard / Data View"
1049
+ elif "landing" in best_for or "marketing" in best_for:
1050
+ return "Landing / Marketing"
1051
+
1052
+ return "General"
1053
+
1054
+
1055
+ # ============ CLI SUPPORT ============
1056
+ if __name__ == "__main__":
1057
+ import argparse
1058
+
1059
+ parser = argparse.ArgumentParser(description="Generate Design System")
1060
+ parser.add_argument("query", help="Search query (e.g., 'SaaS dashboard')")
1061
+ parser.add_argument("--project-name", "-p", type=str, default=None, help="Project name")
1062
+ parser.add_argument("--format", "-f", choices=["ascii", "markdown"], default="ascii", help="Output format")
1063
+
1064
+ args = parser.parse_args()
1065
+
1066
+ result = generate_design_system(args.query, args.project_name, args.format)
1067
+ print(result)