@musashishao/agent-kit 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.

Potentially problematic release.


This version of @musashishao/agent-kit might be problematic. Click here for more details.

Files changed (220) hide show
  1. package/.agent/.shared/ui-ux-pro-max/data/charts.csv +26 -0
  2. package/.agent/.shared/ui-ux-pro-max/data/colors.csv +97 -0
  3. package/.agent/.shared/ui-ux-pro-max/data/icons.csv +101 -0
  4. package/.agent/.shared/ui-ux-pro-max/data/landing.csv +31 -0
  5. package/.agent/.shared/ui-ux-pro-max/data/products.csv +97 -0
  6. package/.agent/.shared/ui-ux-pro-max/data/prompts.csv +24 -0
  7. package/.agent/.shared/ui-ux-pro-max/data/react-performance.csv +45 -0
  8. package/.agent/.shared/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  9. package/.agent/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  10. package/.agent/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  11. package/.agent/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  12. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  13. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  14. package/.agent/.shared/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  15. package/.agent/.shared/ui-ux-pro-max/data/stacks/react.csv +54 -0
  16. package/.agent/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  17. package/.agent/.shared/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  18. package/.agent/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  19. package/.agent/.shared/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  20. package/.agent/.shared/ui-ux-pro-max/data/styles.csv +59 -0
  21. package/.agent/.shared/ui-ux-pro-max/data/typography.csv +58 -0
  22. package/.agent/.shared/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  23. package/.agent/.shared/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  24. package/.agent/.shared/ui-ux-pro-max/data/web-interface.csv +31 -0
  25. package/.agent/.shared/ui-ux-pro-max/scripts/core.py +258 -0
  26. package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +487 -0
  27. package/.agent/.shared/ui-ux-pro-max/scripts/search.py +76 -0
  28. package/.agent/ARCHITECTURE.md +225 -0
  29. package/.agent/CONTEXT.md +229 -0
  30. package/.agent/FEATURE_ROADMAP.md +435 -0
  31. package/.agent/PROMPT_TEMPLATES.md +261 -0
  32. package/.agent/agents/backend-specialist.md +263 -0
  33. package/.agent/agents/database-architect.md +226 -0
  34. package/.agent/agents/debugger.md +225 -0
  35. package/.agent/agents/devops-engineer.md +242 -0
  36. package/.agent/agents/documentation-writer.md +104 -0
  37. package/.agent/agents/explorer-agent.md +73 -0
  38. package/.agent/agents/frontend-specialist.md +556 -0
  39. package/.agent/agents/game-developer.md +162 -0
  40. package/.agent/agents/mobile-developer.md +377 -0
  41. package/.agent/agents/orchestrator.md +416 -0
  42. package/.agent/agents/penetration-tester.md +188 -0
  43. package/.agent/agents/performance-optimizer.md +187 -0
  44. package/.agent/agents/project-planner.md +403 -0
  45. package/.agent/agents/security-auditor.md +170 -0
  46. package/.agent/agents/seo-specialist.md +111 -0
  47. package/.agent/agents/test-engineer.md +158 -0
  48. package/.agent/rules/GEMINI.md +251 -0
  49. package/.agent/skills/api-patterns/SKILL.md +81 -0
  50. package/.agent/skills/api-patterns/api-style.md +42 -0
  51. package/.agent/skills/api-patterns/auth.md +24 -0
  52. package/.agent/skills/api-patterns/documentation.md +26 -0
  53. package/.agent/skills/api-patterns/graphql.md +41 -0
  54. package/.agent/skills/api-patterns/rate-limiting.md +31 -0
  55. package/.agent/skills/api-patterns/response.md +37 -0
  56. package/.agent/skills/api-patterns/rest.md +40 -0
  57. package/.agent/skills/api-patterns/scripts/api_validator.py +211 -0
  58. package/.agent/skills/api-patterns/security-testing.md +122 -0
  59. package/.agent/skills/api-patterns/trpc.md +41 -0
  60. package/.agent/skills/api-patterns/versioning.md +22 -0
  61. package/.agent/skills/app-builder/SKILL.md +75 -0
  62. package/.agent/skills/app-builder/agent-coordination.md +71 -0
  63. package/.agent/skills/app-builder/feature-building.md +53 -0
  64. package/.agent/skills/app-builder/project-detection.md +34 -0
  65. package/.agent/skills/app-builder/scaffolding.md +118 -0
  66. package/.agent/skills/app-builder/tech-stack.md +40 -0
  67. package/.agent/skills/app-builder/templates/SKILL.md +39 -0
  68. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
  69. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
  70. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
  71. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
  72. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
  73. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
  74. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
  75. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
  76. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
  77. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
  78. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
  79. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
  80. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
  81. package/.agent/skills/architecture/SKILL.md +55 -0
  82. package/.agent/skills/architecture/context-discovery.md +43 -0
  83. package/.agent/skills/architecture/examples.md +94 -0
  84. package/.agent/skills/architecture/pattern-selection.md +68 -0
  85. package/.agent/skills/architecture/patterns-reference.md +50 -0
  86. package/.agent/skills/architecture/trade-off-analysis.md +77 -0
  87. package/.agent/skills/bash-linux/SKILL.md +199 -0
  88. package/.agent/skills/behavioral-modes/SKILL.md +242 -0
  89. package/.agent/skills/brainstorming/SKILL.md +163 -0
  90. package/.agent/skills/brainstorming/dynamic-questioning.md +350 -0
  91. package/.agent/skills/clean-code/SKILL.md +201 -0
  92. package/.agent/skills/code-review-checklist/SKILL.md +109 -0
  93. package/.agent/skills/database-design/SKILL.md +52 -0
  94. package/.agent/skills/database-design/database-selection.md +43 -0
  95. package/.agent/skills/database-design/indexing.md +39 -0
  96. package/.agent/skills/database-design/migrations.md +48 -0
  97. package/.agent/skills/database-design/optimization.md +36 -0
  98. package/.agent/skills/database-design/orm-selection.md +30 -0
  99. package/.agent/skills/database-design/schema-design.md +56 -0
  100. package/.agent/skills/database-design/scripts/schema_validator.py +172 -0
  101. package/.agent/skills/deployment-procedures/SKILL.md +241 -0
  102. package/.agent/skills/doc.md +177 -0
  103. package/.agent/skills/docker-expert/SKILL.md +409 -0
  104. package/.agent/skills/documentation-templates/SKILL.md +194 -0
  105. package/.agent/skills/frontend-design/SKILL.md +396 -0
  106. package/.agent/skills/frontend-design/animation-guide.md +331 -0
  107. package/.agent/skills/frontend-design/color-system.md +311 -0
  108. package/.agent/skills/frontend-design/decision-trees.md +418 -0
  109. package/.agent/skills/frontend-design/motion-graphics.md +306 -0
  110. package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -0
  111. package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -0
  112. package/.agent/skills/frontend-design/typography-system.md +345 -0
  113. package/.agent/skills/frontend-design/ux-psychology.md +541 -0
  114. package/.agent/skills/frontend-design/visual-effects.md +383 -0
  115. package/.agent/skills/game-development/2d-games/SKILL.md +119 -0
  116. package/.agent/skills/game-development/3d-games/SKILL.md +135 -0
  117. package/.agent/skills/game-development/SKILL.md +167 -0
  118. package/.agent/skills/game-development/game-art/SKILL.md +185 -0
  119. package/.agent/skills/game-development/game-audio/SKILL.md +190 -0
  120. package/.agent/skills/game-development/game-design/SKILL.md +129 -0
  121. package/.agent/skills/game-development/mobile-games/SKILL.md +108 -0
  122. package/.agent/skills/game-development/multiplayer/SKILL.md +132 -0
  123. package/.agent/skills/game-development/pc-games/SKILL.md +144 -0
  124. package/.agent/skills/game-development/vr-ar/SKILL.md +123 -0
  125. package/.agent/skills/game-development/web-games/SKILL.md +150 -0
  126. package/.agent/skills/geo-fundamentals/SKILL.md +156 -0
  127. package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
  128. package/.agent/skills/i18n-localization/SKILL.md +154 -0
  129. package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -0
  130. package/.agent/skills/lint-and-validate/SKILL.md +45 -0
  131. package/.agent/skills/lint-and-validate/scripts/lint_runner.py +172 -0
  132. package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -0
  133. package/.agent/skills/mcp-builder/SKILL.md +176 -0
  134. package/.agent/skills/mobile-design/SKILL.md +394 -0
  135. package/.agent/skills/mobile-design/decision-trees.md +516 -0
  136. package/.agent/skills/mobile-design/mobile-backend.md +491 -0
  137. package/.agent/skills/mobile-design/mobile-color-system.md +420 -0
  138. package/.agent/skills/mobile-design/mobile-debugging.md +122 -0
  139. package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -0
  140. package/.agent/skills/mobile-design/mobile-navigation.md +458 -0
  141. package/.agent/skills/mobile-design/mobile-performance.md +767 -0
  142. package/.agent/skills/mobile-design/mobile-testing.md +356 -0
  143. package/.agent/skills/mobile-design/mobile-typography.md +433 -0
  144. package/.agent/skills/mobile-design/platform-android.md +666 -0
  145. package/.agent/skills/mobile-design/platform-ios.md +561 -0
  146. package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -0
  147. package/.agent/skills/mobile-design/touch-psychology.md +537 -0
  148. package/.agent/skills/nestjs-expert/SKILL.md +552 -0
  149. package/.agent/skills/nextjs-best-practices/SKILL.md +203 -0
  150. package/.agent/skills/nodejs-best-practices/SKILL.md +333 -0
  151. package/.agent/skills/parallel-agents/SKILL.md +175 -0
  152. package/.agent/skills/performance-profiling/SKILL.md +143 -0
  153. package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -0
  154. package/.agent/skills/plan-writing/SKILL.md +152 -0
  155. package/.agent/skills/powershell-windows/SKILL.md +167 -0
  156. package/.agent/skills/prisma-expert/SKILL.md +355 -0
  157. package/.agent/skills/python-patterns/SKILL.md +441 -0
  158. package/.agent/skills/react-patterns/SKILL.md +198 -0
  159. package/.agent/skills/red-team-tactics/SKILL.md +199 -0
  160. package/.agent/skills/seo-fundamentals/SKILL.md +129 -0
  161. package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
  162. package/.agent/skills/server-management/SKILL.md +161 -0
  163. package/.agent/skills/systematic-debugging/SKILL.md +109 -0
  164. package/.agent/skills/tailwind-patterns/SKILL.md +269 -0
  165. package/.agent/skills/tdd-workflow/SKILL.md +149 -0
  166. package/.agent/skills/testing-patterns/SKILL.md +178 -0
  167. package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -0
  168. package/.agent/skills/typescript-expert/SKILL.md +429 -0
  169. package/.agent/skills/typescript-expert/references/tsconfig-strict.json +92 -0
  170. package/.agent/skills/typescript-expert/references/typescript-cheatsheet.md +383 -0
  171. package/.agent/skills/typescript-expert/references/utility-types.ts +335 -0
  172. package/.agent/skills/typescript-expert/scripts/ts_diagnostic.py +203 -0
  173. package/.agent/skills/ui-ux-pro-max/SKILL.md +351 -0
  174. package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -0
  175. package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -0
  176. package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -0
  177. package/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -0
  178. package/.agent/skills/ui-ux-pro-max/data/products.csv +97 -0
  179. package/.agent/skills/ui-ux-pro-max/data/prompts.csv +24 -0
  180. package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  181. package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  182. package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  183. package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  184. package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  185. package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  186. package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  187. package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  188. package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  189. package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  190. package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  191. package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  192. package/.agent/skills/ui-ux-pro-max/data/styles.csv +59 -0
  193. package/.agent/skills/ui-ux-pro-max/data/typography.csv +58 -0
  194. package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  195. package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  196. package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  197. package/.agent/skills/ui-ux-pro-max/scripts/core.py +257 -0
  198. package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +487 -0
  199. package/.agent/skills/ui-ux-pro-max/scripts/search.py +76 -0
  200. package/.agent/skills/vulnerability-scanner/SKILL.md +276 -0
  201. package/.agent/skills/vulnerability-scanner/checklists.md +121 -0
  202. package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
  203. package/.agent/skills/webapp-testing/SKILL.md +187 -0
  204. package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -0
  205. package/.agent/workflows/brainstorm.md +113 -0
  206. package/.agent/workflows/create.md +59 -0
  207. package/.agent/workflows/debug.md +103 -0
  208. package/.agent/workflows/deploy.md +176 -0
  209. package/.agent/workflows/enhance.md +63 -0
  210. package/.agent/workflows/orchestrate.md +237 -0
  211. package/.agent/workflows/plan.md +89 -0
  212. package/.agent/workflows/preview.md +80 -0
  213. package/.agent/workflows/status.md +86 -0
  214. package/.agent/workflows/test.md +144 -0
  215. package/.agent/workflows/ui-ux-pro-max.md +231 -0
  216. package/LICENSE +21 -0
  217. package/README.md +101 -0
  218. package/bin/cli.js +235 -0
  219. package/index.js +1 -0
  220. package/package.json +43 -0
@@ -0,0 +1,516 @@
1
+ # Mobile Decision Trees
2
+
3
+ > Framework selection, state management, storage strategy, and context-based decisions.
4
+ > **These are THINKING guides, not copy-paste answers.**
5
+
6
+ ---
7
+
8
+ ## 1. Framework Selection
9
+
10
+ ### Master Decision Tree
11
+
12
+ ```
13
+ WHAT ARE YOU BUILDING?
14
+
15
+ ├── Need OTA updates without app store review?
16
+ │ │
17
+ │ ├── Yes → React Native + Expo
18
+ │ │ ├── Expo Go for development
19
+ │ │ ├── EAS Update for production OTA
20
+ │ │ └── Best for: rapid iteration, web teams
21
+ │ │
22
+ │ └── No → Continue ▼
23
+
24
+ ├── Need pixel-perfect custom UI across platforms?
25
+ │ │
26
+ │ ├── Yes → Flutter
27
+ │ │ ├── Custom rendering engine
28
+ │ │ ├── Single UI for iOS + Android
29
+ │ │ └── Best for: branded, visual apps
30
+ │ │
31
+ │ └── No → Continue ▼
32
+
33
+ ├── Heavy native features (ARKit, HealthKit, specific sensors)?
34
+ │ │
35
+ │ ├── iOS only → SwiftUI / UIKit
36
+ │ │ └── Maximum native capability
37
+ │ │
38
+ │ ├── Android only → Kotlin + Jetpack Compose
39
+ │ │ └── Maximum native capability
40
+ │ │
41
+ │ └── Both → Consider native with shared logic
42
+ │ └── Kotlin Multiplatform for shared
43
+
44
+ ├── Existing web team + TypeScript codebase?
45
+ │ │
46
+ │ └── Yes → React Native
47
+ │ ├── Familiar paradigm for React devs
48
+ │ ├── Share code with web (limited)
49
+ │ └── Large ecosystem
50
+
51
+ └── Enterprise with existing Flutter team?
52
+
53
+ └── Yes → Flutter
54
+ └── Leverage existing expertise
55
+ ```
56
+
57
+ ### Framework Comparison
58
+
59
+ | Factor | React Native | Flutter | Native (Swift/Kotlin) |
60
+ |--------|-------------|---------|----------------------|
61
+ | **OTA Updates** | ✅ Expo | ❌ No | ❌ No |
62
+ | **Learning Curve** | Low (React devs) | Medium | Higher |
63
+ | **Performance** | Good | Excellent | Best |
64
+ | **UI Consistency** | Platform-native | Identical | Platform-native |
65
+ | **Bundle Size** | Medium | Larger | Smallest |
66
+ | **Native Access** | Via bridges | Via channels | Direct |
67
+ | **Hot Reload** | ✅ | ✅ | ✅ (Xcode 15+) |
68
+
69
+ ### When to Choose Native
70
+
71
+ ```
72
+ CHOOSE NATIVE WHEN:
73
+ ├── Maximum performance required (games, 3D)
74
+ ├── Deep OS integration needed
75
+ ├── Platform-specific features are core
76
+ ├── Team has native expertise
77
+ ├── App store presence is primary
78
+ └── Long-term maintenance priority
79
+
80
+ AVOID NATIVE WHEN:
81
+ ├── Limited budget/time
82
+ ├── Need rapid iteration
83
+ ├── Identical UI on both platforms
84
+ ├── Team is web-focused
85
+ └── Cross-platform is priority
86
+ ```
87
+
88
+ ---
89
+
90
+ ## 2. State Management Selection
91
+
92
+ ### React Native State Decision
93
+
94
+ ```
95
+ WHAT'S YOUR STATE COMPLEXITY?
96
+
97
+ ├── Simple app, few screens, minimal shared state
98
+ │ │
99
+ │ └── Zustand (or just useState/Context)
100
+ │ ├── Minimal boilerplate
101
+ │ ├── Easy to understand
102
+ │ └── Scales OK to medium
103
+
104
+ ├── Primarily server data (API-driven)
105
+ │ │
106
+ │ └── TanStack Query (React Query) + Zustand
107
+ │ ├── Query for server state
108
+ │ ├── Zustand for UI state
109
+ │ └── Excellent caching, refetching
110
+
111
+ ├── Complex app with many features
112
+ │ │
113
+ │ └── Redux Toolkit + RTK Query
114
+ │ ├── Predicable, debuggable
115
+ │ ├── RTK Query for API
116
+ │ └── Good for large teams
117
+
118
+ └── Atomic, granular state needs
119
+
120
+ └── Jotai
121
+ ├── Atom-based (like Recoil)
122
+ ├── Minimizes re-renders
123
+ └── Good for derived state
124
+ ```
125
+
126
+ ### Flutter State Decision
127
+
128
+ ```
129
+ WHAT'S YOUR STATE COMPLEXITY?
130
+
131
+ ├── Simple app, learning Flutter
132
+ │ │
133
+ │ └── Provider (or setState)
134
+ │ ├── Official, simple
135
+ │ ├── Built into Flutter
136
+ │ └── Good for small apps
137
+
138
+ ├── Modern, type-safe, testable
139
+ │ │
140
+ │ └── Riverpod 2.0
141
+ │ ├── Compile-time safety
142
+ │ ├── Code generation
143
+ │ ├── Excellent for medium-large apps
144
+ │ └── Recommended for new projects
145
+
146
+ ├── Enterprise, strict patterns needed
147
+ │ │
148
+ │ └── BLoC
149
+ │ ├── Event → State pattern
150
+ │ ├── Very testable
151
+ │ ├── More boilerplate
152
+ │ └── Good for large teams
153
+
154
+ └── Quick prototyping
155
+
156
+ └── GetX (with caution)
157
+ ├── Fast to implement
158
+ ├── Less strict patterns
159
+ └── Can become messy at scale
160
+ ```
161
+
162
+ ### State Management Anti-Patterns
163
+
164
+ ```
165
+ ❌ DON'T:
166
+ ├── Use global state for everything
167
+ ├── Mix state management approaches
168
+ ├── Store server state in local state
169
+ ├── Skip state normalization
170
+ ├── Overuse Context (re-render heavy)
171
+ └── Put navigation state in app state
172
+
173
+ ✅ DO:
174
+ ├── Server state → Query library
175
+ ├── UI state → Minimal, local first
176
+ ├── Lift state only when needed
177
+ ├── Choose ONE approach per project
178
+ └── Keep state close to where it's used
179
+ ```
180
+
181
+ ---
182
+
183
+ ## 3. Navigation Pattern Selection
184
+
185
+ ```
186
+ HOW MANY TOP-LEVEL DESTINATIONS?
187
+
188
+ ├── 2 destinations
189
+ │ └── Consider: Top tabs or simple stack
190
+
191
+ ├── 3-5 destinations (equal importance)
192
+ │ └── ✅ Tab Bar / Bottom Navigation
193
+ │ ├── Most common pattern
194
+ │ └── Easy discovery
195
+
196
+ ├── 5+ destinations
197
+ │ │
198
+ │ ├── All important → Drawer Navigation
199
+ │ │ └── Hidden but many options
200
+ │ │
201
+ │ └── Some less important → Tab bar + drawer hybrid
202
+
203
+ └── Single linear flow?
204
+ └── Stack Navigation only
205
+ └── Onboarding, checkout, etc.
206
+ ```
207
+
208
+ ### Navigation by App Type
209
+
210
+ | App Type | Pattern | Reason |
211
+ |----------|---------|--------|
212
+ | Social (Instagram) | Tab bar | Frequent switching |
213
+ | E-commerce | Tab bar + stack | Categories as tabs |
214
+ | Email (Gmail) | Drawer + list-detail | Many folders |
215
+ | Settings | Stack only | Deep drill-down |
216
+ | Onboarding | Stack wizard | Linear flow |
217
+ | Messaging | Tab (chats) + stack | Threads |
218
+
219
+ ---
220
+
221
+ ## 4. Storage Strategy Selection
222
+
223
+ ```
224
+ WHAT TYPE OF DATA?
225
+
226
+ ├── Sensitive (tokens, passwords, keys)
227
+ │ │
228
+ │ └── ✅ Secure Storage
229
+ │ ├── iOS: Keychain
230
+ │ ├── Android: EncryptedSharedPreferences
231
+ │ └── RN: expo-secure-store / react-native-keychain
232
+
233
+ ├── User preferences (settings, theme)
234
+ │ │
235
+ │ └── ✅ Key-Value Storage
236
+ │ ├── iOS: UserDefaults
237
+ │ ├── Android: SharedPreferences
238
+ │ └── RN: AsyncStorage / MMKV
239
+
240
+ ├── Structured data (entities, relationships)
241
+ │ │
242
+ │ └── ✅ Database
243
+ │ ├── SQLite (expo-sqlite, sqflite)
244
+ │ ├── Realm (NoSQL, reactive)
245
+ │ └── WatermelonDB (large datasets)
246
+
247
+ ├── Large files (images, documents)
248
+ │ │
249
+ │ └── ✅ File System
250
+ │ ├── iOS: Documents / Caches directory
251
+ │ ├── Android: Internal/External storage
252
+ │ └── RN: react-native-fs / expo-file-system
253
+
254
+ └── Cached API data
255
+
256
+ └── ✅ Query Library Cache
257
+ ├── TanStack Query (RN)
258
+ ├── Riverpod async (Flutter)
259
+ └── Automatic invalidation
260
+ ```
261
+
262
+ ### Storage Comparison
263
+
264
+ | Storage | Speed | Security | Capacity | Use Case |
265
+ |---------|-------|----------|----------|----------|
266
+ | Secure Storage | Medium | 🔒 High | Small | Tokens, secrets |
267
+ | Key-Value | Fast | Low | Medium | Settings |
268
+ | SQLite | Fast | Low | Large | Structured data |
269
+ | File System | Medium | Low | Very Large | Media, documents |
270
+ | Query Cache | Fast | Low | Medium | API responses |
271
+
272
+ ---
273
+
274
+ ## 5. Offline Strategy Selection
275
+
276
+ ```
277
+ HOW CRITICAL IS OFFLINE?
278
+
279
+ ├── Nice to have (works when possible)
280
+ │ │
281
+ │ └── Cache last data + show stale
282
+ │ ├── Simple implementation
283
+ │ ├── TanStack Query with staleTime
284
+ │ └── Show "last updated" timestamp
285
+
286
+ ├── Essential (core functionality offline)
287
+ │ │
288
+ │ └── Offline-first architecture
289
+ │ ├── Local database as source of truth
290
+ │ ├── Sync to server when online
291
+ │ ├── Conflict resolution strategy
292
+ │ └── Queue actions for later sync
293
+
294
+ └── Real-time critical (collaboration, chat)
295
+
296
+ └── WebSocket + local queue
297
+ ├── Optimistic updates
298
+ ├── Eventual consistency
299
+ └── Complex conflict handling
300
+ ```
301
+
302
+ ### Offline Implementation Patterns
303
+
304
+ ```
305
+ 1. CACHE-FIRST (Simple)
306
+ Request → Check cache → If stale, fetch → Update cache
307
+
308
+ 2. STALE-WHILE-REVALIDATE
309
+ Request → Return cached → Fetch update → Update UI
310
+
311
+ 3. OFFLINE-FIRST (Complex)
312
+ Action → Write to local DB → Queue sync → Sync when online
313
+
314
+ 4. SYNC ENGINE
315
+ Use: Firebase, Realm Sync, Supabase realtime
316
+ Handles conflict resolution automatically
317
+ ```
318
+
319
+ ---
320
+
321
+ ## 6. Authentication Pattern Selection
322
+
323
+ ```
324
+ WHAT AUTH TYPE NEEDED?
325
+
326
+ ├── Simple email/password
327
+ │ │
328
+ │ └── Token-based (JWT)
329
+ │ ├── Store refresh token securely
330
+ │ ├── Access token in memory
331
+ │ └── Silent refresh flow
332
+
333
+ ├── Social login (Google, Apple, etc.)
334
+ │ │
335
+ │ └── OAuth 2.0 + PKCE
336
+ │ ├── Use platform SDKs
337
+ │ ├── Deep link callback
338
+ │ └── Apple Sign-In required for iOS
339
+
340
+ ├── Enterprise/SSO
341
+ │ │
342
+ │ └── OIDC / SAML
343
+ │ ├── Web view or system browser
344
+ │ └── Handle redirect properly
345
+
346
+ └── Biometric (FaceID, fingerprint)
347
+
348
+ └── Local auth + secure token
349
+ ├── Biometrics unlock stored token
350
+ ├── Not a replacement for server auth
351
+ └── Fallback to PIN/password
352
+ ```
353
+
354
+ ### Auth Token Storage
355
+
356
+ ```
357
+ ❌ NEVER store tokens in:
358
+ ├── AsyncStorage (plain text)
359
+ ├── Redux/state (not persisted correctly)
360
+ ├── Local storage equivalent
361
+ └── Logs or debug output
362
+
363
+ ✅ ALWAYS store tokens in:
364
+ ├── iOS: Keychain
365
+ ├── Android: EncryptedSharedPreferences
366
+ ├── Expo: SecureStore
367
+ ├── Biometric-protected if available
368
+ ```
369
+
370
+ ---
371
+
372
+ ## 7. Project Type Templates
373
+
374
+ ### E-Commerce App
375
+
376
+ ```
377
+ RECOMMENDED STACK:
378
+ ├── Framework: React Native + Expo (OTA for pricing)
379
+ ├── Navigation: Tab bar (Home, Search, Cart, Account)
380
+ ├── State: TanStack Query (products) + Zustand (cart)
381
+ ├── Storage: SecureStore (auth) + SQLite (cart cache)
382
+ ├── Offline: Cache products, queue cart actions
383
+ └── Auth: Email/password + Social + Apple Pay
384
+
385
+ KEY DECISIONS:
386
+ ├── Product images: Lazy load, cache aggressively
387
+ ├── Cart: Sync across devices via API
388
+ ├── Checkout: Secure, minimal steps
389
+ └── Deep links: Product shares, marketing
390
+ ```
391
+
392
+ ### Social/Content App
393
+
394
+ ```
395
+ RECOMMENDED STACK:
396
+ ├── Framework: React Native or Flutter
397
+ ├── Navigation: Tab bar (Feed, Search, Create, Notifications, Profile)
398
+ ├── State: TanStack Query (feed) + Zustand (UI)
399
+ ├── Storage: SQLite (feed cache, drafts)
400
+ ├── Offline: Cache feed, queue posts
401
+ └── Auth: Social login primary, Apple required
402
+
403
+ KEY DECISIONS:
404
+ ├── Feed: Infinite scroll, memoized items
405
+ ├── Media: Upload queuing, background upload
406
+ ├── Push: Deep link to content
407
+ └── Real-time: WebSocket for notifications
408
+ ```
409
+
410
+ ### Productivity/SaaS App
411
+
412
+ ```
413
+ RECOMMENDED STACK:
414
+ ├── Framework: Flutter (consistent UI) or RN
415
+ ├── Navigation: Drawer or Tab bar
416
+ ├── State: Riverpod/BLoC or Redux Toolkit
417
+ ├── Storage: SQLite (offline), SecureStore (auth)
418
+ ├── Offline: Full offline editing, sync
419
+ └── Auth: SSO/OIDC for enterprise
420
+
421
+ KEY DECISIONS:
422
+ ├── Data sync: Conflict resolution strategy
423
+ ├── Collaborative: Real-time or eventual?
424
+ ├── Files: Large file handling
425
+ └── Enterprise: MDM, compliance
426
+ ```
427
+
428
+ ---
429
+
430
+ ## 8. Decision Checklist
431
+
432
+ ### Before Starting ANY Project
433
+
434
+ - [ ] Target platforms defined (iOS/Android/both)?
435
+ - [ ] Framework selected based on criteria?
436
+ - [ ] State management approach chosen?
437
+ - [ ] Navigation pattern selected?
438
+ - [ ] Storage strategy for each data type?
439
+ - [ ] Offline requirements defined?
440
+ - [ ] Auth flow designed?
441
+ - [ ] Deep linking planned from start?
442
+
443
+ ### Questions to Ask User
444
+
445
+ ```
446
+ If project details are vague, ASK:
447
+
448
+ 1. "Will this need OTA updates without app store review?"
449
+ → Affects framework choice (Expo = yes)
450
+
451
+ 2. "Do iOS and Android need identical UI?"
452
+ → Affects framework (Flutter = identical)
453
+
454
+ 3. "What's the offline requirement?"
455
+ → Affects architecture complexity
456
+
457
+ 4. "Is there an existing backend/auth system?"
458
+ → Affects auth and API approach
459
+
460
+ 5. "What devices? Phone only, or tablet?"
461
+ → Affects navigation and layout
462
+
463
+ 6. "Enterprise or consumer?"
464
+ → Affects auth (SSO), security, compliance
465
+ ```
466
+
467
+ ---
468
+
469
+ ## 9. Anti-Pattern Decisions
470
+
471
+ ### ❌ Decision Anti-Patterns
472
+
473
+ | Anti-Pattern | Why It's Bad | Better Approach |
474
+ |--------------|--------------|-----------------|
475
+ | **Redux for simple app** | Massive overkill | Zustand or context |
476
+ | **Native for MVP** | Slow development | Cross-platform MVP |
477
+ | **Drawer for 3 sections** | Hidden navigation | Tab bar |
478
+ | **AsyncStorage for tokens** | Insecure | SecureStore |
479
+ | **No offline consideration** | Broken on subway | Plan from start |
480
+ | **Same stack for all projects** | Doesn't fit context | Evaluate per project |
481
+
482
+ ---
483
+
484
+ ## 10. Quick Reference
485
+
486
+ ### Framework Quick Pick
487
+
488
+ ```
489
+ OTA needed? → React Native + Expo
490
+ Identical UI? → Flutter
491
+ Maximum performance? → Native
492
+ Web team? → React Native
493
+ Quick prototype? → Expo
494
+ ```
495
+
496
+ ### State Quick Pick
497
+
498
+ ```
499
+ Simple app? → Zustand / Provider
500
+ Server-heavy? → TanStack Query / Riverpod
501
+ Enterprise? → Redux / BLoC
502
+ Atomic state? → Jotai
503
+ ```
504
+
505
+ ### Storage Quick Pick
506
+
507
+ ```
508
+ Secrets? → SecureStore / Keychain
509
+ Settings? → AsyncStorage / UserDefaults
510
+ Structured data? → SQLite
511
+ API cache? → Query library
512
+ ```
513
+
514
+ ---
515
+
516
+ > **Remember:** These trees are guides for THINKING, not rules to follow blindly. Every project has unique constraints. ASK clarifying questions when requirements are vague, and choose based on actual needs, not defaults.