@maestro-ai/cli 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 (252) hide show
  1. package/README.md +59 -0
  2. package/content/guides/Cat/303/241logo de Stacks para Cloud Moderna.md" +119 -0
  3. package/content/guides/Cat/303/241logo de Stacks para Hospedagem Compartilhada.md" +147 -0
  4. package/content/guides/Checklist Mestre de Entrega.md +68 -0
  5. package/content/guides/Gates de Qualidade.md +209 -0
  6. package/content/guides/Guia de Adi/303/247/303/243o de Novas Funcionalidades.md" +355 -0
  7. package/content/guides/Guia de Chaos Engineering.md +267 -0
  8. package/content/guides/Guia de Debugging com IA.md +135 -0
  9. package/content/guides/Guia de Estrat/303/251gias de Cache.md" +352 -0
  10. package/content/guides/Guia de Migrations Zero-Downtime.md +311 -0
  11. package/content/guides/Guia de Multi-tenancy.md +368 -0
  12. package/content/guides/Guia de Otimiza/303/247/303/243o de Custos Cloud.md" +195 -0
  13. package/content/guides/Guia de Refatora/303/247/303/243o de C/303/263digo Legado com IA.md" +162 -0
  14. package/content/guides/Guia de SLOs e Error Budgets.md +315 -0
  15. package/content/guides/M/303/251tricas de Efici/303/252ncia do Desenvolvimento com IA.md" +93 -0
  16. package/content/guides/Rules base.md +90 -0
  17. package/content/prompts/README.md +203 -0
  18. package/content/prompts/acessibilidade/analise-acessibilidade.md +257 -0
  19. package/content/prompts/apis/design-api-rest.md +303 -0
  20. package/content/prompts/apis/idempotencia.md +254 -0
  21. package/content/prompts/apis/versionamento.md +313 -0
  22. package/content/prompts/arquitetura/arquitetura-c4-completo.md +190 -0
  23. package/content/prompts/arquitetura/clean-architecture.md +151 -0
  24. package/content/prompts/arquitetura/ddd-bounded-contexts.md +183 -0
  25. package/content/prompts/arquitetura/ddd-cqrs.md +176 -0
  26. package/content/prompts/arquitetura/modelo-dominio.md +207 -0
  27. package/content/prompts/arquitetura/multi-tenancy.md +235 -0
  28. package/content/prompts/database/migrations-zero-downtime.md +192 -0
  29. package/content/prompts/database/otimizacao-queries.md +296 -0
  30. package/content/prompts/desenvolvimento/code-review.md +301 -0
  31. package/content/prompts/desenvolvimento/gerar-servico.md +271 -0
  32. package/content/prompts/devops/docker-compose.md +336 -0
  33. package/content/prompts/devops/feature-flags.md +374 -0
  34. package/content/prompts/devops/kubernetes-deploy.md +460 -0
  35. package/content/prompts/devops/pipeline-cicd.md +358 -0
  36. package/content/prompts/devops/terraform-iac.md +502 -0
  37. package/content/prompts/escalabilidade/analise-performance.md +240 -0
  38. package/content/prompts/escalabilidade/analise-performance.txt +94 -0
  39. package/content/prompts/escalabilidade/caching.md +255 -0
  40. package/content/prompts/observabilidade/chaos-testing.md +237 -0
  41. package/content/prompts/observabilidade/estrategia-observabilidade.md +263 -0
  42. package/content/prompts/observabilidade/estrategia-observabilidade.txt +134 -0
  43. package/content/prompts/observabilidade/slos.md +215 -0
  44. package/content/prompts/produto/discovery-inicial.md +203 -0
  45. package/content/prompts/produto/discovery-inicial.txt +33 -0
  46. package/content/prompts/requisitos/refinar-requisitos.md +232 -0
  47. package/content/prompts/requisitos/refinar-requisitos.txt +40 -0
  48. package/content/prompts/seguranca/analise-seguranca.md +243 -0
  49. package/content/prompts/seguranca/pentest-checklist.md +333 -0
  50. package/content/prompts/seguranca/rate-limiting.md +356 -0
  51. package/content/prompts/seguranca/revisao-lgpd.md +227 -0
  52. package/content/prompts/seguranca/threat-modeling.md +224 -0
  53. package/content/prompts/testes/contract-testing.md +340 -0
  54. package/content/prompts/testes/gerar-testes-unitarios.md +474 -0
  55. package/content/prompts/testes/testes-e2e.md +460 -0
  56. package/content/prompts/testes/testes-integracao.md +418 -0
  57. package/content/prompts/testes/testes-performance.md +458 -0
  58. package/content/prompts/ux/gerar-ui-stitch.md +151 -0
  59. package/content/skills/api-patterns/SKILL.md +81 -0
  60. package/content/skills/api-patterns/api-style.md +42 -0
  61. package/content/skills/api-patterns/auth.md +24 -0
  62. package/content/skills/api-patterns/documentation.md +26 -0
  63. package/content/skills/api-patterns/graphql.md +41 -0
  64. package/content/skills/api-patterns/rate-limiting.md +31 -0
  65. package/content/skills/api-patterns/response.md +37 -0
  66. package/content/skills/api-patterns/rest.md +40 -0
  67. package/content/skills/api-patterns/scripts/api_validator.py +211 -0
  68. package/content/skills/api-patterns/security-testing.md +122 -0
  69. package/content/skills/api-patterns/trpc.md +41 -0
  70. package/content/skills/api-patterns/versioning.md +22 -0
  71. package/content/skills/app-builder/SKILL.md +75 -0
  72. package/content/skills/app-builder/agent-coordination.md +71 -0
  73. package/content/skills/app-builder/feature-building.md +53 -0
  74. package/content/skills/app-builder/project-detection.md +34 -0
  75. package/content/skills/app-builder/scaffolding.md +118 -0
  76. package/content/skills/app-builder/tech-stack.md +40 -0
  77. package/content/skills/app-builder/templates/SKILL.md +39 -0
  78. package/content/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
  79. package/content/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
  80. package/content/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
  81. package/content/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
  82. package/content/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
  83. package/content/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
  84. package/content/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
  85. package/content/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
  86. package/content/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
  87. package/content/skills/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
  88. package/content/skills/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
  89. package/content/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
  90. package/content/skills/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
  91. package/content/skills/architecture/SKILL.md +55 -0
  92. package/content/skills/architecture/context-discovery.md +43 -0
  93. package/content/skills/architecture/examples.md +94 -0
  94. package/content/skills/architecture/pattern-selection.md +68 -0
  95. package/content/skills/architecture/patterns-reference.md +50 -0
  96. package/content/skills/architecture/trade-off-analysis.md +77 -0
  97. package/content/skills/bash-linux/SKILL.md +199 -0
  98. package/content/skills/behavioral-modes/SKILL.md +242 -0
  99. package/content/skills/brainstorming/SKILL.md +163 -0
  100. package/content/skills/brainstorming/dynamic-questioning.md +350 -0
  101. package/content/skills/clean-code/SKILL.md +201 -0
  102. package/content/skills/code-review-checklist/SKILL.md +109 -0
  103. package/content/skills/database-design/SKILL.md +52 -0
  104. package/content/skills/database-design/database-selection.md +43 -0
  105. package/content/skills/database-design/indexing.md +39 -0
  106. package/content/skills/database-design/migrations.md +48 -0
  107. package/content/skills/database-design/optimization.md +36 -0
  108. package/content/skills/database-design/orm-selection.md +30 -0
  109. package/content/skills/database-design/schema-design.md +56 -0
  110. package/content/skills/database-design/scripts/schema_validator.py +172 -0
  111. package/content/skills/deployment-procedures/SKILL.md +241 -0
  112. package/content/skills/doc.md +177 -0
  113. package/content/skills/documentation-templates/SKILL.md +194 -0
  114. package/content/skills/frontend-design/SKILL.md +396 -0
  115. package/content/skills/frontend-design/animation-guide.md +331 -0
  116. package/content/skills/frontend-design/color-system.md +311 -0
  117. package/content/skills/frontend-design/decision-trees.md +418 -0
  118. package/content/skills/frontend-design/motion-graphics.md +306 -0
  119. package/content/skills/frontend-design/scripts/accessibility_checker.py +183 -0
  120. package/content/skills/frontend-design/scripts/ux_audit.py +722 -0
  121. package/content/skills/frontend-design/typography-system.md +345 -0
  122. package/content/skills/frontend-design/ux-psychology.md +541 -0
  123. package/content/skills/frontend-design/visual-effects.md +383 -0
  124. package/content/skills/game-development/2d-games/SKILL.md +119 -0
  125. package/content/skills/game-development/3d-games/SKILL.md +135 -0
  126. package/content/skills/game-development/SKILL.md +167 -0
  127. package/content/skills/game-development/game-art/SKILL.md +185 -0
  128. package/content/skills/game-development/game-audio/SKILL.md +190 -0
  129. package/content/skills/game-development/game-design/SKILL.md +129 -0
  130. package/content/skills/game-development/mobile-games/SKILL.md +108 -0
  131. package/content/skills/game-development/multiplayer/SKILL.md +132 -0
  132. package/content/skills/game-development/pc-games/SKILL.md +144 -0
  133. package/content/skills/game-development/vr-ar/SKILL.md +123 -0
  134. package/content/skills/game-development/web-games/SKILL.md +150 -0
  135. package/content/skills/geo-fundamentals/SKILL.md +156 -0
  136. package/content/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
  137. package/content/skills/i18n-localization/SKILL.md +154 -0
  138. package/content/skills/i18n-localization/scripts/i18n_checker.py +241 -0
  139. package/content/skills/intelligent-routing/SKILL.md +334 -0
  140. package/content/skills/lint-and-validate/SKILL.md +45 -0
  141. package/content/skills/lint-and-validate/scripts/lint_runner.py +172 -0
  142. package/content/skills/lint-and-validate/scripts/type_coverage.py +173 -0
  143. package/content/skills/mcp-builder/SKILL.md +176 -0
  144. package/content/skills/mobile-design/SKILL.md +394 -0
  145. package/content/skills/mobile-design/decision-trees.md +516 -0
  146. package/content/skills/mobile-design/mobile-backend.md +491 -0
  147. package/content/skills/mobile-design/mobile-color-system.md +420 -0
  148. package/content/skills/mobile-design/mobile-debugging.md +122 -0
  149. package/content/skills/mobile-design/mobile-design-thinking.md +357 -0
  150. package/content/skills/mobile-design/mobile-navigation.md +458 -0
  151. package/content/skills/mobile-design/mobile-performance.md +767 -0
  152. package/content/skills/mobile-design/mobile-testing.md +356 -0
  153. package/content/skills/mobile-design/mobile-typography.md +433 -0
  154. package/content/skills/mobile-design/platform-android.md +666 -0
  155. package/content/skills/mobile-design/platform-ios.md +561 -0
  156. package/content/skills/mobile-design/scripts/mobile_audit.py +670 -0
  157. package/content/skills/mobile-design/touch-psychology.md +537 -0
  158. package/content/skills/nextjs-best-practices/SKILL.md +203 -0
  159. package/content/skills/nodejs-best-practices/SKILL.md +333 -0
  160. package/content/skills/parallel-agents/SKILL.md +175 -0
  161. package/content/skills/performance-profiling/SKILL.md +143 -0
  162. package/content/skills/performance-profiling/scripts/lighthouse_audit.py +76 -0
  163. package/content/skills/plan-writing/SKILL.md +152 -0
  164. package/content/skills/powershell-windows/SKILL.md +167 -0
  165. package/content/skills/python-patterns/SKILL.md +441 -0
  166. package/content/skills/react-patterns/SKILL.md +198 -0
  167. package/content/skills/red-team-tactics/SKILL.md +199 -0
  168. package/content/skills/seo-fundamentals/SKILL.md +129 -0
  169. package/content/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
  170. package/content/skills/server-management/SKILL.md +161 -0
  171. package/content/skills/systematic-debugging/SKILL.md +109 -0
  172. package/content/skills/tailwind-patterns/SKILL.md +269 -0
  173. package/content/skills/tdd-workflow/SKILL.md +149 -0
  174. package/content/skills/testing-patterns/SKILL.md +178 -0
  175. package/content/skills/testing-patterns/scripts/test_runner.py +219 -0
  176. package/content/skills/vulnerability-scanner/SKILL.md +276 -0
  177. package/content/skills/vulnerability-scanner/checklists.md +121 -0
  178. package/content/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
  179. package/content/skills/webapp-testing/SKILL.md +187 -0
  180. package/content/skills/webapp-testing/scripts/playwright_runner.py +173 -0
  181. package/content/specialists/Especialista em Acessibilidade.md +266 -0
  182. package/content/specialists/Especialista em An/303/241lise de Testes.md" +434 -0
  183. package/content/specialists/Especialista em Arquitetura Avan/303/247ada.md" +358 -0
  184. package/content/specialists/Especialista em Arquitetura de Software.md +177 -0
  185. package/content/specialists/Especialista em Banco de Dados.md +260 -0
  186. package/content/specialists/Especialista em Contrato de API.md +172 -0
  187. package/content/specialists/Especialista em Dados e Analytics com IA.md +246 -0
  188. package/content/specialists/Especialista em Debugging e Troubleshooting.md +191 -0
  189. package/content/specialists/Especialista em Desenvolvimento Frontend.md +477 -0
  190. package/content/specialists/Especialista em Desenvolvimento Mobile.md +241 -0
  191. package/content/specialists/Especialista em Desenvolvimento e Vibe Coding Estruturado.md +417 -0
  192. package/content/specialists/Especialista em DevOps e Infraestrutura.md +294 -0
  193. package/content/specialists/Especialista em Documenta/303/247/303/243o T/303/251cnica.md" +227 -0
  194. package/content/specialists/Especialista em Engenharia de Requisitos com IA.md +299 -0
  195. package/content/specialists/Especialista em Explora/303/247/303/243o de Codebase.md" +179 -0
  196. package/content/specialists/Especialista em Gest/303/243o de Produto.md" +179 -0
  197. package/content/specialists/Especialista em Migra/303/247/303/243o e Moderniza/303/247/303/243o.md" +410 -0
  198. package/content/specialists/Especialista em Modelagem e Arquitetura de Dom/303/255nio com IA.md" +248 -0
  199. package/content/specialists/Especialista em Observabilidade.md +415 -0
  200. package/content/specialists/Especialista em Performance e Escalabilidade.md +373 -0
  201. package/content/specialists/Especialista em Plano de Execu/303/247/303/243o com IA.md" +341 -0
  202. package/content/specialists/Especialista em Prototipagem R/303/241pida com Google Stitch.md" +419 -0
  203. package/content/specialists/Especialista em Seguran/303/247a da Informa/303/247/303/243o.md" +508 -0
  204. package/content/specialists/Especialista em UX Design.md +453 -0
  205. package/content/specialists/INDEX.md +43 -0
  206. package/content/templates/PRD.md +165 -0
  207. package/content/templates/README.md +65 -0
  208. package/content/templates/adr.md +103 -0
  209. package/content/templates/arquitetura.md +279 -0
  210. package/content/templates/backlog.md +185 -0
  211. package/content/templates/checklist-seguranca.md +180 -0
  212. package/content/templates/contexto.md +120 -0
  213. package/content/templates/criterios-aceite.md +99 -0
  214. package/content/templates/design-banco.md +270 -0
  215. package/content/templates/design-doc.md +240 -0
  216. package/content/templates/feature.md +88 -0
  217. package/content/templates/historia-backend.md +84 -0
  218. package/content/templates/historia-frontend.md +75 -0
  219. package/content/templates/historia-usuario.md +125 -0
  220. package/content/templates/mapa-navegacao.md +133 -0
  221. package/content/templates/matriz-rastreabilidade.md +121 -0
  222. package/content/templates/modelo-dominio.md +219 -0
  223. package/content/templates/plano-testes.md +199 -0
  224. package/content/templates/prototipo-stitch.md +138 -0
  225. package/content/templates/requisitos.md +162 -0
  226. package/content/templates/slo-sli.md +197 -0
  227. package/content/workflows/README-MCP.md +363 -0
  228. package/content/workflows/brainstorm.md +113 -0
  229. package/content/workflows/create.md +59 -0
  230. package/content/workflows/debug.md +103 -0
  231. package/content/workflows/deploy.md +176 -0
  232. package/content/workflows/enhance.md +63 -0
  233. package/content/workflows/mcp-debug.md +506 -0
  234. package/content/workflows/mcp-feature.md +385 -0
  235. package/content/workflows/mcp-gate.md +413 -0
  236. package/content/workflows/mcp-next.md +388 -0
  237. package/content/workflows/mcp-refactor.md +600 -0
  238. package/content/workflows/mcp-start.md +304 -0
  239. package/content/workflows/mcp-status.md +400 -0
  240. package/content/workflows/orchestrate.md +237 -0
  241. package/content/workflows/plan.md +89 -0
  242. package/content/workflows/preview.md +81 -0
  243. package/content/workflows/status.md +86 -0
  244. package/content/workflows/test.md +144 -0
  245. package/content/workflows/ui-ux-pro-max.md +296 -0
  246. package/dist/commands/init.d.ts +6 -0
  247. package/dist/commands/init.js +138 -0
  248. package/dist/commands/update.d.ts +5 -0
  249. package/dist/commands/update.js +50 -0
  250. package/dist/index.d.ts +2 -0
  251. package/dist/index.js +21 -0
  252. package/package.json +48 -0
@@ -0,0 +1,394 @@
1
+ ---
2
+ name: mobile-design
3
+ description: Mobile-first design thinking and decision-making for iOS and Android apps. Touch interaction, performance patterns, platform conventions. Teaches principles, not fixed values. Use when building React Native, Flutter, or native mobile apps.
4
+ allowed-tools: Read, Glob, Grep, Bash
5
+ ---
6
+
7
+ # Mobile Design System
8
+
9
+ > **Philosophy:** Touch-first. Battery-conscious. Platform-respectful. Offline-capable.
10
+ > **Core Principle:** Mobile is NOT a small desktop. THINK mobile constraints, ASK platform choice.
11
+
12
+ ---
13
+
14
+ ## 🔧 Runtime Scripts
15
+
16
+ **Execute these for validation (don't read, just run):**
17
+
18
+ | Script | Purpose | Usage |
19
+ |--------|---------|-------|
20
+ | `scripts/mobile_audit.py` | Mobile UX & Touch Audit | `python scripts/mobile_audit.py <project_path>` |
21
+
22
+ ---
23
+
24
+ ## 🔴 MANDATORY: Read Reference Files Before Working!
25
+
26
+ **⛔ DO NOT start development until you read the relevant files:**
27
+
28
+ ### Universal (Always Read)
29
+
30
+ | File | Content | Status |
31
+ |------|---------|--------|
32
+ | **[mobile-design-thinking.md](mobile-design-thinking.md)** | **⚠️ ANTI-MEMORIZATION: Forces thinking, prevents AI defaults** | **⬜ CRITICAL FIRST** |
33
+ | **[touch-psychology.md](touch-psychology.md)** | **Fitts' Law, gestures, haptics, thumb zone** | **⬜ CRITICAL** |
34
+ | **[mobile-performance.md](mobile-performance.md)** | **RN/Flutter performance, 60fps, memory** | **⬜ CRITICAL** |
35
+ | **[mobile-backend.md](mobile-backend.md)** | **Push notifications, offline sync, mobile API** | **⬜ CRITICAL** |
36
+ | **[mobile-testing.md](mobile-testing.md)** | **Testing pyramid, E2E, platform-specific** | **⬜ CRITICAL** |
37
+ | **[mobile-debugging.md](mobile-debugging.md)** | **Native vs JS debugging, Flipper, Logcat** | **⬜ CRITICAL** |
38
+ | [mobile-navigation.md](mobile-navigation.md) | Tab/Stack/Drawer, deep linking | ⬜ Read |
39
+ | [mobile-typography.md](mobile-typography.md) | System fonts, Dynamic Type, a11y | ⬜ Read |
40
+ | [mobile-color-system.md](mobile-color-system.md) | OLED, dark mode, battery-aware | ⬜ Read |
41
+ | [decision-trees.md](decision-trees.md) | Framework/state/storage selection | ⬜ Read |
42
+
43
+ > 🧠 **mobile-design-thinking.md is PRIORITY!** This file ensures AI thinks instead of using memorized patterns.
44
+
45
+ ### Platform-Specific (Read Based on Target)
46
+
47
+ | Platform | File | Content | When to Read |
48
+ |----------|------|---------|--------------|
49
+ | **iOS** | [platform-ios.md](platform-ios.md) | Human Interface Guidelines, SF Pro, SwiftUI patterns | Building for iPhone/iPad |
50
+ | **Android** | [platform-android.md](platform-android.md) | Material Design 3, Roboto, Compose patterns | Building for Android |
51
+ | **Cross-Platform** | Both above | Platform divergence points | React Native / Flutter |
52
+
53
+ > 🔴 **If building for iOS → Read platform-ios.md FIRST!**
54
+ > 🔴 **If building for Android → Read platform-android.md FIRST!**
55
+ > 🔴 **If cross-platform → Read BOTH and apply conditional platform logic!**
56
+
57
+ ---
58
+
59
+ ## ⚠️ CRITICAL: ASK BEFORE ASSUMING (MANDATORY)
60
+
61
+ > **STOP! If the user's request is open-ended, DO NOT default to your favorites.**
62
+
63
+ ### You MUST Ask If Not Specified:
64
+
65
+ | Aspect | Ask | Why |
66
+ |--------|-----|-----|
67
+ | **Platform** | "iOS, Android, or both?" | Affects EVERY design decision |
68
+ | **Framework** | "React Native, Flutter, or native?" | Determines patterns and tools |
69
+ | **Navigation** | "Tab bar, drawer, or stack-based?" | Core UX decision |
70
+ | **State** | "What state management? (Zustand/Redux/Riverpod/BLoC?)" | Architecture foundation |
71
+ | **Offline** | "Does this need to work offline?" | Affects data strategy |
72
+ | **Target devices** | "Phone only, or tablet support?" | Layout complexity |
73
+
74
+ ### ⛔ AI MOBILE ANTI-PATTERNS (YASAK LİSTESİ)
75
+
76
+ > 🚫 **These are AI default tendencies that MUST be avoided!**
77
+
78
+ #### Performance Sins
79
+
80
+ | ❌ NEVER DO | Why It's Wrong | ✅ ALWAYS DO |
81
+ |-------------|----------------|--------------|
82
+ | **ScrollView for long lists** | Renders ALL items, memory explodes | Use `FlatList` / `FlashList` / `ListView.builder` |
83
+ | **Inline renderItem function** | New function every render, all items re-render | `useCallback` + `React.memo` |
84
+ | **Missing keyExtractor** | Index-based keys cause bugs on reorder | Unique, stable ID from data |
85
+ | **Skip getItemLayout** | Async layout = janky scroll | Provide when items have fixed height |
86
+ | **setState() everywhere** | Unnecessary widget rebuilds | Targeted state, `const` constructors |
87
+ | **Native driver: false** | Animations blocked by JS thread | `useNativeDriver: true` always |
88
+ | **console.log in production** | Blocks JS thread severely | Remove before release build |
89
+ | **Skip React.memo/const** | Every item re-renders on any change | Memoize list items ALWAYS |
90
+
91
+ #### Touch/UX Sins
92
+
93
+ | ❌ NEVER DO | Why It's Wrong | ✅ ALWAYS DO |
94
+ |-------------|----------------|--------------|
95
+ | **Touch target < 44px** | Impossible to tap accurately, frustrating | Minimum 44pt (iOS) / 48dp (Android) |
96
+ | **Spacing < 8px between targets** | Accidental taps on neighbors | Minimum 8-12px gap |
97
+ | **Gesture-only interactions** | Motor impaired users excluded | Always provide button alternative |
98
+ | **No loading state** | User thinks app crashed | ALWAYS show loading feedback |
99
+ | **No error state** | User stuck, no recovery path | Show error with retry option |
100
+ | **No offline handling** | Crash/block when network lost | Graceful degradation, cached data |
101
+ | **Ignore platform conventions** | Users confused, muscle memory broken | iOS feels iOS, Android feels Android |
102
+
103
+ #### Security Sins
104
+
105
+ | ❌ NEVER DO | Why It's Wrong | ✅ ALWAYS DO |
106
+ |-------------|----------------|--------------|
107
+ | **Token in AsyncStorage** | Easily accessible, stolen on rooted device | `SecureStore` / `Keychain` / `EncryptedSharedPreferences` |
108
+ | **Hardcode API keys** | Reverse engineered from APK/IPA | Environment variables, secure storage |
109
+ | **Skip SSL pinning** | MITM attacks possible | Pin certificates in production |
110
+ | **Log sensitive data** | Logs can be extracted | Never log tokens, passwords, PII |
111
+
112
+ #### Architecture Sins
113
+
114
+ | ❌ NEVER DO | Why It's Wrong | ✅ ALWAYS DO |
115
+ |-------------|----------------|--------------|
116
+ | **Business logic in UI** | Untestable, unmaintainable | Service layer separation |
117
+ | **Global state for everything** | Unnecessary re-renders, complexity | Local state default, lift when needed |
118
+ | **Deep linking as afterthought** | Notifications, shares broken | Plan deep links from day one |
119
+ | **Skip dispose/cleanup** | Memory leaks, zombie listeners | Clean up subscriptions, timers |
120
+
121
+ ---
122
+
123
+ ## 📱 Platform Decision Matrix
124
+
125
+ ### When to Unify vs Diverge
126
+
127
+ ```
128
+ UNIFY (same on both) DIVERGE (platform-specific)
129
+ ─────────────────── ──────────────────────────
130
+ Business Logic ✅ Always -
131
+ Data Layer ✅ Always -
132
+ Core Features ✅ Always -
133
+
134
+ Navigation - ✅ iOS: edge swipe, Android: back button
135
+ Gestures - ✅ Platform-native feel
136
+ Icons - ✅ SF Symbols vs Material Icons
137
+ Date Pickers - ✅ Native pickers feel right
138
+ Modals/Sheets - ✅ iOS: bottom sheet vs Android: dialog
139
+ Typography - ✅ SF Pro vs Roboto (or custom)
140
+ Error Dialogs - ✅ Platform conventions for alerts
141
+ ```
142
+
143
+ ### Quick Reference: Platform Defaults
144
+
145
+ | Element | iOS | Android |
146
+ |---------|-----|---------|
147
+ | **Primary Font** | SF Pro / SF Compact | Roboto |
148
+ | **Min Touch Target** | 44pt × 44pt | 48dp × 48dp |
149
+ | **Back Navigation** | Edge swipe left | System back button/gesture |
150
+ | **Bottom Tab Icons** | SF Symbols | Material Symbols |
151
+ | **Action Sheet** | UIActionSheet from bottom | Bottom Sheet / Dialog |
152
+ | **Progress** | Spinner | Linear progress (Material) |
153
+ | **Pull to Refresh** | Native UIRefreshControl | SwipeRefreshLayout |
154
+
155
+ ---
156
+
157
+ ## 🧠 Mobile UX Psychology (Quick Reference)
158
+
159
+ ### Fitts' Law for Touch
160
+
161
+ ```
162
+ Desktop: Cursor is precise (1px)
163
+ Mobile: Finger is imprecise (~7mm contact area)
164
+
165
+ → Touch targets MUST be 44-48px minimum
166
+ → Important actions in THUMB ZONE (bottom of screen)
167
+ → Destructive actions AWAY from easy reach
168
+ ```
169
+
170
+ ### Thumb Zone (One-Handed Usage)
171
+
172
+ ```
173
+ ┌─────────────────────────────┐
174
+ │ HARD TO REACH │ ← Navigation, menu, back
175
+ │ (stretch) │
176
+ ├─────────────────────────────┤
177
+ │ OK TO REACH │ ← Secondary actions
178
+ │ (natural) │
179
+ ├─────────────────────────────┤
180
+ │ EASY TO REACH │ ← PRIMARY CTAs, tab bar
181
+ │ (thumb's natural arc) │ ← Main content interaction
182
+ └─────────────────────────────┘
183
+ [ HOME ]
184
+ ```
185
+
186
+ ### Mobile-Specific Cognitive Load
187
+
188
+ | Desktop | Mobile Difference |
189
+ |---------|-------------------|
190
+ | Multiple windows | ONE task at a time |
191
+ | Keyboard shortcuts | Touch gestures |
192
+ | Hover states | NO hover (tap or nothing) |
193
+ | Large viewport | Limited space, scroll vertical |
194
+ | Stable attention | Interrupted constantly |
195
+
196
+ For deep dive: [touch-psychology.md](touch-psychology.md)
197
+
198
+ ---
199
+
200
+ ## ⚡ Performance Principles (Quick Reference)
201
+
202
+ ### React Native Critical Rules
203
+
204
+ ```typescript
205
+ // ✅ CORRECT: Memoized renderItem + React.memo wrapper
206
+ const ListItem = React.memo(({ item }: { item: Item }) => (
207
+ <View style={styles.item}>
208
+ <Text>{item.title}</Text>
209
+ </View>
210
+ ));
211
+
212
+ const renderItem = useCallback(
213
+ ({ item }: { item: Item }) => <ListItem item={item} />,
214
+ []
215
+ );
216
+
217
+ // ✅ CORRECT: FlatList with all optimizations
218
+ <FlatList
219
+ data={items}
220
+ renderItem={renderItem}
221
+ keyExtractor={(item) => item.id} // Stable ID, NOT index
222
+ getItemLayout={(data, index) => ({
223
+ length: ITEM_HEIGHT,
224
+ offset: ITEM_HEIGHT * index,
225
+ index,
226
+ })}
227
+ removeClippedSubviews={true}
228
+ maxToRenderPerBatch={10}
229
+ windowSize={5}
230
+ />
231
+ ```
232
+
233
+ ### Flutter Critical Rules
234
+
235
+ ```dart
236
+ // ✅ CORRECT: const constructors prevent rebuilds
237
+ class MyWidget extends StatelessWidget {
238
+ const MyWidget({super.key}); // CONST!
239
+
240
+ @override
241
+ Widget build(BuildContext context) {
242
+ return const Column( // CONST!
243
+ children: [
244
+ Text('Static content'),
245
+ MyConstantWidget(),
246
+ ],
247
+ );
248
+ }
249
+ }
250
+
251
+ // ✅ CORRECT: Targeted state with ValueListenableBuilder
252
+ ValueListenableBuilder<int>(
253
+ valueListenable: counter,
254
+ builder: (context, value, child) => Text('$value'),
255
+ child: const ExpensiveWidget(), // Won't rebuild!
256
+ )
257
+ ```
258
+
259
+ ### Animation Performance
260
+
261
+ ```
262
+ GPU-accelerated (FAST): CPU-bound (SLOW):
263
+ ├── transform ├── width, height
264
+ ├── opacity ├── top, left, right, bottom
265
+ └── (use these ONLY) ├── margin, padding
266
+ └── (AVOID animating these)
267
+ ```
268
+
269
+ For complete guide: [mobile-performance.md](mobile-performance.md)
270
+
271
+ ---
272
+
273
+ ## 📝 CHECKPOINT (MANDATORY Before Any Mobile Work)
274
+
275
+ > **Before writing ANY mobile code, you MUST complete this checkpoint:**
276
+
277
+ ```
278
+ 🧠 CHECKPOINT:
279
+
280
+ Platform: [ iOS / Android / Both ]
281
+ Framework: [ React Native / Flutter / SwiftUI / Kotlin ]
282
+ Files Read: [ List the skill files you've read ]
283
+
284
+ 3 Principles I Will Apply:
285
+ 1. _______________
286
+ 2. _______________
287
+ 3. _______________
288
+
289
+ Anti-Patterns I Will Avoid:
290
+ 1. _______________
291
+ 2. _______________
292
+ ```
293
+
294
+ **Example:**
295
+ ```
296
+ 🧠 CHECKPOINT:
297
+
298
+ Platform: iOS + Android (Cross-platform)
299
+ Framework: React Native + Expo
300
+ Files Read: touch-psychology.md, mobile-performance.md, platform-ios.md, platform-android.md
301
+
302
+ 3 Principles I Will Apply:
303
+ 1. FlatList with React.memo + useCallback for all lists
304
+ 2. 48px touch targets, thumb zone for primary CTAs
305
+ 3. Platform-specific navigation (edge swipe iOS, back button Android)
306
+
307
+ Anti-Patterns I Will Avoid:
308
+ 1. ScrollView for lists → FlatList
309
+ 2. Inline renderItem → Memoized
310
+ 3. AsyncStorage for tokens → SecureStore
311
+ ```
312
+
313
+ > 🔴 **Can't fill the checkpoint? → GO BACK AND READ THE SKILL FILES.**
314
+
315
+ ---
316
+
317
+ ## 🔧 Framework Decision Tree
318
+
319
+ ```
320
+ WHAT ARE YOU BUILDING?
321
+
322
+ ├── Need OTA updates + rapid iteration + web team
323
+ │ └── ✅ React Native + Expo
324
+
325
+ ├── Need pixel-perfect custom UI + performance critical
326
+ │ └── ✅ Flutter
327
+
328
+ ├── Deep native features + single platform focus
329
+ │ ├── iOS only → SwiftUI
330
+ │ └── Android only → Kotlin + Jetpack Compose
331
+
332
+ ├── Existing RN codebase + new features
333
+ │ └── ✅ React Native (bare workflow)
334
+
335
+ └── Enterprise + existing Flutter codebase
336
+ └── ✅ Flutter
337
+ ```
338
+
339
+ For complete decision trees: [decision-trees.md](decision-trees.md)
340
+
341
+ ---
342
+
343
+ ## 📋 Pre-Development Checklist
344
+
345
+ ### Before Starting ANY Mobile Project
346
+
347
+ - [ ] **Platform confirmed?** (iOS / Android / Both)
348
+ - [ ] **Framework chosen?** (RN / Flutter / Native)
349
+ - [ ] **Navigation pattern decided?** (Tabs / Stack / Drawer)
350
+ - [ ] **State management selected?** (Zustand / Redux / Riverpod / BLoC)
351
+ - [ ] **Offline requirements known?**
352
+ - [ ] **Deep linking planned from day one?**
353
+ - [ ] **Target devices defined?** (Phone / Tablet / Both)
354
+
355
+ ### Before Every Screen
356
+
357
+ - [ ] **Touch targets ≥ 44-48px?**
358
+ - [ ] **Primary CTA in thumb zone?**
359
+ - [ ] **Loading state exists?**
360
+ - [ ] **Error state with retry exists?**
361
+ - [ ] **Offline handling considered?**
362
+ - [ ] **Platform conventions followed?**
363
+
364
+ ### Before Release
365
+
366
+ - [ ] **console.log removed?**
367
+ - [ ] **SecureStore for sensitive data?**
368
+ - [ ] **SSL pinning enabled?**
369
+ - [ ] **Lists optimized (memo, keyExtractor)?**
370
+ - [ ] **Memory cleanup on unmount?**
371
+ - [ ] **Tested on low-end devices?**
372
+ - [ ] **Accessibility labels on all interactive elements?**
373
+
374
+ ---
375
+
376
+ ## 📚 Reference Files
377
+
378
+ For deeper guidance on specific areas:
379
+
380
+ | File | When to Use |
381
+ |------|-------------|
382
+ | [mobile-design-thinking.md](mobile-design-thinking.md) | **FIRST! Anti-memorization, forces context-based thinking** |
383
+ | [touch-psychology.md](touch-psychology.md) | Understanding touch interaction, Fitts' Law, gesture design |
384
+ | [mobile-performance.md](mobile-performance.md) | Optimizing RN/Flutter, 60fps, memory/battery |
385
+ | [platform-ios.md](platform-ios.md) | iOS-specific design, HIG compliance |
386
+ | [platform-android.md](platform-android.md) | Android-specific design, Material Design 3 |
387
+ | [mobile-navigation.md](mobile-navigation.md) | Navigation patterns, deep linking |
388
+ | [mobile-typography.md](mobile-typography.md) | Type scale, system fonts, accessibility |
389
+ | [mobile-color-system.md](mobile-color-system.md) | OLED optimization, dark mode, battery |
390
+ | [decision-trees.md](decision-trees.md) | Framework, state, storage decisions |
391
+
392
+ ---
393
+
394
+ > **Remember:** Mobile users are impatient, interrupted, and using imprecise fingers on small screens. Design for the WORST conditions: bad network, one hand, bright sun, low battery. If it works there, it works everywhere.