@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.
- package/.agent/.shared/ui-ux-pro-max/data/charts.csv +26 -0
- package/.agent/.shared/ui-ux-pro-max/data/colors.csv +97 -0
- package/.agent/.shared/ui-ux-pro-max/data/icons.csv +101 -0
- package/.agent/.shared/ui-ux-pro-max/data/landing.csv +31 -0
- package/.agent/.shared/ui-ux-pro-max/data/products.csv +97 -0
- package/.agent/.shared/ui-ux-pro-max/data/prompts.csv +24 -0
- package/.agent/.shared/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/.agent/.shared/ui-ux-pro-max/data/styles.csv +59 -0
- package/.agent/.shared/ui-ux-pro-max/data/typography.csv +58 -0
- package/.agent/.shared/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/.agent/.shared/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/.agent/.shared/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/core.py +258 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +487 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/search.py +76 -0
- package/.agent/ARCHITECTURE.md +225 -0
- package/.agent/CONTEXT.md +229 -0
- package/.agent/FEATURE_ROADMAP.md +435 -0
- package/.agent/PROMPT_TEMPLATES.md +261 -0
- package/.agent/agents/backend-specialist.md +263 -0
- package/.agent/agents/database-architect.md +226 -0
- package/.agent/agents/debugger.md +225 -0
- package/.agent/agents/devops-engineer.md +242 -0
- package/.agent/agents/documentation-writer.md +104 -0
- package/.agent/agents/explorer-agent.md +73 -0
- package/.agent/agents/frontend-specialist.md +556 -0
- package/.agent/agents/game-developer.md +162 -0
- package/.agent/agents/mobile-developer.md +377 -0
- package/.agent/agents/orchestrator.md +416 -0
- package/.agent/agents/penetration-tester.md +188 -0
- package/.agent/agents/performance-optimizer.md +187 -0
- package/.agent/agents/project-planner.md +403 -0
- package/.agent/agents/security-auditor.md +170 -0
- package/.agent/agents/seo-specialist.md +111 -0
- package/.agent/agents/test-engineer.md +158 -0
- package/.agent/rules/GEMINI.md +251 -0
- package/.agent/skills/api-patterns/SKILL.md +81 -0
- package/.agent/skills/api-patterns/api-style.md +42 -0
- package/.agent/skills/api-patterns/auth.md +24 -0
- package/.agent/skills/api-patterns/documentation.md +26 -0
- package/.agent/skills/api-patterns/graphql.md +41 -0
- package/.agent/skills/api-patterns/rate-limiting.md +31 -0
- package/.agent/skills/api-patterns/response.md +37 -0
- package/.agent/skills/api-patterns/rest.md +40 -0
- package/.agent/skills/api-patterns/scripts/api_validator.py +211 -0
- package/.agent/skills/api-patterns/security-testing.md +122 -0
- package/.agent/skills/api-patterns/trpc.md +41 -0
- package/.agent/skills/api-patterns/versioning.md +22 -0
- package/.agent/skills/app-builder/SKILL.md +75 -0
- package/.agent/skills/app-builder/agent-coordination.md +71 -0
- package/.agent/skills/app-builder/feature-building.md +53 -0
- package/.agent/skills/app-builder/project-detection.md +34 -0
- package/.agent/skills/app-builder/scaffolding.md +118 -0
- package/.agent/skills/app-builder/tech-stack.md +40 -0
- package/.agent/skills/app-builder/templates/SKILL.md +39 -0
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
- package/.agent/skills/architecture/SKILL.md +55 -0
- package/.agent/skills/architecture/context-discovery.md +43 -0
- package/.agent/skills/architecture/examples.md +94 -0
- package/.agent/skills/architecture/pattern-selection.md +68 -0
- package/.agent/skills/architecture/patterns-reference.md +50 -0
- package/.agent/skills/architecture/trade-off-analysis.md +77 -0
- package/.agent/skills/bash-linux/SKILL.md +199 -0
- package/.agent/skills/behavioral-modes/SKILL.md +242 -0
- package/.agent/skills/brainstorming/SKILL.md +163 -0
- package/.agent/skills/brainstorming/dynamic-questioning.md +350 -0
- package/.agent/skills/clean-code/SKILL.md +201 -0
- package/.agent/skills/code-review-checklist/SKILL.md +109 -0
- package/.agent/skills/database-design/SKILL.md +52 -0
- package/.agent/skills/database-design/database-selection.md +43 -0
- package/.agent/skills/database-design/indexing.md +39 -0
- package/.agent/skills/database-design/migrations.md +48 -0
- package/.agent/skills/database-design/optimization.md +36 -0
- package/.agent/skills/database-design/orm-selection.md +30 -0
- package/.agent/skills/database-design/schema-design.md +56 -0
- package/.agent/skills/database-design/scripts/schema_validator.py +172 -0
- package/.agent/skills/deployment-procedures/SKILL.md +241 -0
- package/.agent/skills/doc.md +177 -0
- package/.agent/skills/docker-expert/SKILL.md +409 -0
- package/.agent/skills/documentation-templates/SKILL.md +194 -0
- package/.agent/skills/frontend-design/SKILL.md +396 -0
- package/.agent/skills/frontend-design/animation-guide.md +331 -0
- package/.agent/skills/frontend-design/color-system.md +311 -0
- package/.agent/skills/frontend-design/decision-trees.md +418 -0
- package/.agent/skills/frontend-design/motion-graphics.md +306 -0
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -0
- package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -0
- package/.agent/skills/frontend-design/typography-system.md +345 -0
- package/.agent/skills/frontend-design/ux-psychology.md +541 -0
- package/.agent/skills/frontend-design/visual-effects.md +383 -0
- package/.agent/skills/game-development/2d-games/SKILL.md +119 -0
- package/.agent/skills/game-development/3d-games/SKILL.md +135 -0
- package/.agent/skills/game-development/SKILL.md +167 -0
- package/.agent/skills/game-development/game-art/SKILL.md +185 -0
- package/.agent/skills/game-development/game-audio/SKILL.md +190 -0
- package/.agent/skills/game-development/game-design/SKILL.md +129 -0
- package/.agent/skills/game-development/mobile-games/SKILL.md +108 -0
- package/.agent/skills/game-development/multiplayer/SKILL.md +132 -0
- package/.agent/skills/game-development/pc-games/SKILL.md +144 -0
- package/.agent/skills/game-development/vr-ar/SKILL.md +123 -0
- package/.agent/skills/game-development/web-games/SKILL.md +150 -0
- package/.agent/skills/geo-fundamentals/SKILL.md +156 -0
- package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
- package/.agent/skills/i18n-localization/SKILL.md +154 -0
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -0
- package/.agent/skills/lint-and-validate/SKILL.md +45 -0
- package/.agent/skills/lint-and-validate/scripts/lint_runner.py +172 -0
- package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -0
- package/.agent/skills/mcp-builder/SKILL.md +176 -0
- package/.agent/skills/mobile-design/SKILL.md +394 -0
- package/.agent/skills/mobile-design/decision-trees.md +516 -0
- package/.agent/skills/mobile-design/mobile-backend.md +491 -0
- package/.agent/skills/mobile-design/mobile-color-system.md +420 -0
- package/.agent/skills/mobile-design/mobile-debugging.md +122 -0
- package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -0
- package/.agent/skills/mobile-design/mobile-navigation.md +458 -0
- package/.agent/skills/mobile-design/mobile-performance.md +767 -0
- package/.agent/skills/mobile-design/mobile-testing.md +356 -0
- package/.agent/skills/mobile-design/mobile-typography.md +433 -0
- package/.agent/skills/mobile-design/platform-android.md +666 -0
- package/.agent/skills/mobile-design/platform-ios.md +561 -0
- package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -0
- package/.agent/skills/mobile-design/touch-psychology.md +537 -0
- package/.agent/skills/nestjs-expert/SKILL.md +552 -0
- package/.agent/skills/nextjs-best-practices/SKILL.md +203 -0
- package/.agent/skills/nodejs-best-practices/SKILL.md +333 -0
- package/.agent/skills/parallel-agents/SKILL.md +175 -0
- package/.agent/skills/performance-profiling/SKILL.md +143 -0
- package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -0
- package/.agent/skills/plan-writing/SKILL.md +152 -0
- package/.agent/skills/powershell-windows/SKILL.md +167 -0
- package/.agent/skills/prisma-expert/SKILL.md +355 -0
- package/.agent/skills/python-patterns/SKILL.md +441 -0
- package/.agent/skills/react-patterns/SKILL.md +198 -0
- package/.agent/skills/red-team-tactics/SKILL.md +199 -0
- package/.agent/skills/seo-fundamentals/SKILL.md +129 -0
- package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
- package/.agent/skills/server-management/SKILL.md +161 -0
- package/.agent/skills/systematic-debugging/SKILL.md +109 -0
- package/.agent/skills/tailwind-patterns/SKILL.md +269 -0
- package/.agent/skills/tdd-workflow/SKILL.md +149 -0
- package/.agent/skills/testing-patterns/SKILL.md +178 -0
- package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -0
- package/.agent/skills/typescript-expert/SKILL.md +429 -0
- package/.agent/skills/typescript-expert/references/tsconfig-strict.json +92 -0
- package/.agent/skills/typescript-expert/references/typescript-cheatsheet.md +383 -0
- package/.agent/skills/typescript-expert/references/utility-types.ts +335 -0
- package/.agent/skills/typescript-expert/scripts/ts_diagnostic.py +203 -0
- package/.agent/skills/ui-ux-pro-max/SKILL.md +351 -0
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -0
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -0
- package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -0
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -0
- package/.agent/skills/ui-ux-pro-max/data/products.csv +97 -0
- package/.agent/skills/ui-ux-pro-max/data/prompts.csv +24 -0
- package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +59 -0
- package/.agent/skills/ui-ux-pro-max/data/typography.csv +58 -0
- package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/.agent/skills/ui-ux-pro-max/scripts/core.py +257 -0
- package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +487 -0
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +76 -0
- package/.agent/skills/vulnerability-scanner/SKILL.md +276 -0
- package/.agent/skills/vulnerability-scanner/checklists.md +121 -0
- package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
- package/.agent/skills/webapp-testing/SKILL.md +187 -0
- package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -0
- package/.agent/workflows/brainstorm.md +113 -0
- package/.agent/workflows/create.md +59 -0
- package/.agent/workflows/debug.md +103 -0
- package/.agent/workflows/deploy.md +176 -0
- package/.agent/workflows/enhance.md +63 -0
- package/.agent/workflows/orchestrate.md +237 -0
- package/.agent/workflows/plan.md +89 -0
- package/.agent/workflows/preview.md +80 -0
- package/.agent/workflows/status.md +86 -0
- package/.agent/workflows/test.md +144 -0
- package/.agent/workflows/ui-ux-pro-max.md +231 -0
- package/LICENSE +21 -0
- package/README.md +101 -0
- package/bin/cli.js +235 -0
- package/index.js +1 -0
- 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.
|