@mrtrinhvn/ag-kit 1.0.11 → 1.1.1

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 (218) hide show
  1. package/README.md +31 -0
  2. package/bin/cli.js +72 -0
  3. package/package.json +7 -1
  4. package/template/.agent/knowledge/orchestrator_v3_protocol.md +60 -0
  5. package/template/.agent/knowledge/self_healing_logs.md +22 -0
  6. package/{.agent → template/.agent}/skills/telegram-agentic-gateway/SKILL.md +0 -0
  7. package/template/.agent/skills/vfs-assistant/SKILL.md +39 -0
  8. package/.agent/agents/backend-specialist.md +0 -263
  9. package/.agent/agents/code-archaeologist.md +0 -106
  10. package/.agent/agents/database-architect.md +0 -226
  11. package/.agent/agents/debugger.md +0 -225
  12. package/.agent/agents/devops-engineer.md +0 -242
  13. package/.agent/agents/documentation-writer.md +0 -104
  14. package/.agent/agents/explorer-agent.md +0 -73
  15. package/.agent/agents/frontend-specialist.md +0 -556
  16. package/.agent/agents/game-developer.md +0 -162
  17. package/.agent/agents/mobile-developer.md +0 -377
  18. package/.agent/agents/orchestrator.md +0 -416
  19. package/.agent/agents/penetration-tester.md +0 -188
  20. package/.agent/agents/performance-optimizer.md +0 -187
  21. package/.agent/agents/product-manager.md +0 -112
  22. package/.agent/agents/product-owner.md +0 -95
  23. package/.agent/agents/project-planner.md +0 -406
  24. package/.agent/agents/qa-automation-engineer.md +0 -103
  25. package/.agent/agents/quant-architect.md +0 -31
  26. package/.agent/agents/security-auditor.md +0 -170
  27. package/.agent/agents/seo-specialist.md +0 -111
  28. package/.agent/agents/test-engineer.md +0 -158
  29. package/.agent/rules/GEMINI.md +0 -280
  30. package/.agent/scripts/auto_preview.py +0 -148
  31. package/.agent/scripts/checklist.py +0 -217
  32. package/.agent/scripts/session_manager.py +0 -120
  33. package/.agent/scripts/verify_all.py +0 -327
  34. package/.agent/skills/api-patterns/SKILL.md +0 -81
  35. package/.agent/skills/api-patterns/api-style.md +0 -42
  36. package/.agent/skills/api-patterns/auth.md +0 -24
  37. package/.agent/skills/api-patterns/documentation.md +0 -26
  38. package/.agent/skills/api-patterns/graphql.md +0 -41
  39. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  40. package/.agent/skills/api-patterns/response.md +0 -37
  41. package/.agent/skills/api-patterns/rest.md +0 -40
  42. package/.agent/skills/api-patterns/scripts/api_validator.py +0 -211
  43. package/.agent/skills/api-patterns/security-testing.md +0 -122
  44. package/.agent/skills/api-patterns/trpc.md +0 -41
  45. package/.agent/skills/api-patterns/versioning.md +0 -22
  46. package/.agent/skills/app-builder/SKILL.md +0 -75
  47. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  48. package/.agent/skills/app-builder/feature-building.md +0 -53
  49. package/.agent/skills/app-builder/project-detection.md +0 -34
  50. package/.agent/skills/app-builder/scaffolding.md +0 -118
  51. package/.agent/skills/app-builder/tech-stack.md +0 -40
  52. package/.agent/skills/app-builder/templates/SKILL.md +0 -39
  53. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +0 -76
  54. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +0 -92
  55. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +0 -88
  56. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +0 -88
  57. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +0 -83
  58. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +0 -90
  59. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +0 -90
  60. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +0 -82
  61. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +0 -100
  62. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +0 -106
  63. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +0 -101
  64. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +0 -83
  65. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +0 -93
  66. package/.agent/skills/architecture/SKILL.md +0 -55
  67. package/.agent/skills/architecture/context-discovery.md +0 -43
  68. package/.agent/skills/architecture/examples.md +0 -94
  69. package/.agent/skills/architecture/pattern-selection.md +0 -68
  70. package/.agent/skills/architecture/patterns-reference.md +0 -50
  71. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  72. package/.agent/skills/bash-linux/SKILL.md +0 -199
  73. package/.agent/skills/behavioral-modes/SKILL.md +0 -242
  74. package/.agent/skills/brainstorming/SKILL.md +0 -168
  75. package/.agent/skills/brainstorming/dynamic-questioning.md +0 -350
  76. package/.agent/skills/business-ops/SKILL.md +0 -26
  77. package/.agent/skills/clean-code/SKILL.md +0 -202
  78. package/.agent/skills/cli-generator/SKILL.md +0 -48
  79. package/.agent/skills/code-review-checklist/SKILL.md +0 -109
  80. package/.agent/skills/cognitive-session/SKILL.md +0 -28
  81. package/.agent/skills/data-science/SKILL.md +0 -28
  82. package/.agent/skills/database-design/SKILL.md +0 -52
  83. package/.agent/skills/database-design/database-selection.md +0 -43
  84. package/.agent/skills/database-design/indexing.md +0 -39
  85. package/.agent/skills/database-design/migrations.md +0 -48
  86. package/.agent/skills/database-design/optimization.md +0 -36
  87. package/.agent/skills/database-design/orm-selection.md +0 -30
  88. package/.agent/skills/database-design/schema-design.md +0 -56
  89. package/.agent/skills/database-design/scripts/schema_validator.py +0 -172
  90. package/.agent/skills/deployment-procedures/SKILL.md +0 -241
  91. package/.agent/skills/doc.md +0 -177
  92. package/.agent/skills/documentation-templates/SKILL.md +0 -194
  93. package/.agent/skills/frontend-design/SKILL.md +0 -418
  94. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  95. package/.agent/skills/frontend-design/color-system.md +0 -311
  96. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  97. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  98. package/.agent/skills/frontend-design/scripts/accessibility_checker.py +0 -183
  99. package/.agent/skills/frontend-design/scripts/ux_audit.py +0 -722
  100. package/.agent/skills/frontend-design/typography-system.md +0 -345
  101. package/.agent/skills/frontend-design/ux-psychology.md +0 -541
  102. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  103. package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
  104. package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
  105. package/.agent/skills/game-development/SKILL.md +0 -167
  106. package/.agent/skills/game-development/game-art/SKILL.md +0 -185
  107. package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
  108. package/.agent/skills/game-development/game-design/SKILL.md +0 -129
  109. package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
  110. package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
  111. package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
  112. package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
  113. package/.agent/skills/game-development/web-games/SKILL.md +0 -150
  114. package/.agent/skills/geo-fundamentals/SKILL.md +0 -156
  115. package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +0 -289
  116. package/.agent/skills/i18n-localization/SKILL.md +0 -154
  117. package/.agent/skills/i18n-localization/scripts/i18n_checker.py +0 -241
  118. package/.agent/skills/intelligent-routing/SKILL.md +0 -335
  119. package/.agent/skills/knowledge-management/SKILL.md +0 -66
  120. package/.agent/skills/lint-and-validate/SKILL.md +0 -45
  121. package/.agent/skills/lint-and-validate/scripts/lint_runner.py +0 -172
  122. package/.agent/skills/lint-and-validate/scripts/type_coverage.py +0 -173
  123. package/.agent/skills/llm-routing-quirks/SKILL.md +0 -41
  124. package/.agent/skills/mcp-builder/SKILL.md +0 -176
  125. package/.agent/skills/memory-architecture/SKILL.md +0 -107
  126. package/.agent/skills/mini-antigravity-injection/SKILL.md +0 -66
  127. package/.agent/skills/mobile-design/SKILL.md +0 -394
  128. package/.agent/skills/mobile-design/decision-trees.md +0 -516
  129. package/.agent/skills/mobile-design/mobile-backend.md +0 -491
  130. package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
  131. package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
  132. package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
  133. package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
  134. package/.agent/skills/mobile-design/mobile-performance.md +0 -767
  135. package/.agent/skills/mobile-design/mobile-testing.md +0 -356
  136. package/.agent/skills/mobile-design/mobile-typography.md +0 -433
  137. package/.agent/skills/mobile-design/platform-android.md +0 -666
  138. package/.agent/skills/mobile-design/platform-ios.md +0 -561
  139. package/.agent/skills/mobile-design/scripts/mobile_audit.py +0 -670
  140. package/.agent/skills/mobile-design/touch-psychology.md +0 -537
  141. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
  142. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
  143. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
  144. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
  145. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
  146. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
  147. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
  148. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
  149. package/.agent/skills/nextjs-react-expert/SKILL.md +0 -267
  150. package/.agent/skills/nextjs-react-expert/scripts/convert_rules.py +0 -222
  151. package/.agent/skills/nextjs-react-expert/scripts/react_performance_checker.py +0 -252
  152. package/.agent/skills/nodejs-best-practices/SKILL.md +0 -333
  153. package/.agent/skills/parallel-agents/SKILL.md +0 -175
  154. package/.agent/skills/performance-profiling/SKILL.md +0 -143
  155. package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +0 -76
  156. package/.agent/skills/plan-writing/SKILL.md +0 -153
  157. package/.agent/skills/powershell-windows/SKILL.md +0 -167
  158. package/.agent/skills/product-management/SKILL.md +0 -30
  159. package/.agent/skills/python-patterns/SKILL.md +0 -441
  160. package/.agent/skills/red-team-tactics/SKILL.md +0 -199
  161. package/.agent/skills/seo-fundamentals/SKILL.md +0 -129
  162. package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +0 -219
  163. package/.agent/skills/server-management/SKILL.md +0 -161
  164. package/.agent/skills/systematic-debugging/SKILL.md +0 -120
  165. package/.agent/skills/tailwind-patterns/SKILL.md +0 -269
  166. package/.agent/skills/tdd-workflow/SKILL.md +0 -148
  167. package/.agent/skills/testing-patterns/SKILL.md +0 -178
  168. package/.agent/skills/testing-patterns/scripts/test_runner.py +0 -219
  169. package/.agent/skills/vulnerability-scanner/SKILL.md +0 -276
  170. package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
  171. package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +0 -458
  172. package/.agent/skills/web-design-guidelines/SKILL.md +0 -57
  173. package/.agent/skills/webapp-testing/SKILL.md +0 -187
  174. package/.agent/skills/webapp-testing/scripts/playwright_runner.py +0 -173
  175. package/.agent/workflows/brainstorm.md +0 -113
  176. package/.agent/workflows/create.md +0 -59
  177. package/.agent/workflows/debug.md +0 -103
  178. package/.agent/workflows/deploy.md +0 -176
  179. package/.agent/workflows/enhance.md +0 -63
  180. package/.agent/workflows/orchestrate.md +0 -237
  181. package/.agent/workflows/plan.md +0 -89
  182. package/.agent/workflows/preview.md +0 -81
  183. package/.agent/workflows/status.md +0 -86
  184. package/.agent/workflows/test.md +0 -144
  185. package/.agent/workflows/ui-ux-pro-max.md +0 -296
  186. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/charts.csv +0 -0
  187. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/colors.csv +0 -0
  188. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/icons.csv +0 -0
  189. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/landing.csv +0 -0
  190. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/products.csv +0 -0
  191. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/prompts.csv +0 -0
  192. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/react-performance.csv +0 -0
  193. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/flutter.csv +0 -0
  194. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +0 -0
  195. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +0 -0
  196. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +0 -0
  197. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +0 -0
  198. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +0 -0
  199. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/react-native.csv +0 -0
  200. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/react.csv +0 -0
  201. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +0 -0
  202. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/svelte.csv +0 -0
  203. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +0 -0
  204. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/stacks/vue.csv +0 -0
  205. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/styles.csv +0 -0
  206. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/typography.csv +0 -0
  207. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/ui-reasoning.csv +0 -0
  208. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/ux-guidelines.csv +0 -0
  209. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/data/web-interface.csv +0 -0
  210. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/scripts/__pycache__/core.cpython-313.pyc +0 -0
  211. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-313.pyc +0 -0
  212. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/scripts/core.py +0 -0
  213. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/scripts/design_system.py +0 -0
  214. /package/{.agent → template/.agent}/.shared/ui-ux-pro-max/scripts/search.py +0 -0
  215. /package/{.agent → template/.agent}/ARCHITECTURE.md +0 -0
  216. /package/{.agent → template/.agent}/mcp_config.json +0 -0
  217. /package/{.agent → template/.agent}/skills/nextjs-react-expert/9-cache-components.md +0 -0
  218. /package/{.agent → template/.agent}/skills/rust-pro/SKILL.md +0 -0
@@ -1,516 +0,0 @@
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.