@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,561 @@
|
|
|
1
|
+
# iOS Platform Guidelines
|
|
2
|
+
|
|
3
|
+
> Human Interface Guidelines (HIG) essentials, iOS design conventions, SF Pro typography, and native patterns.
|
|
4
|
+
> **Read this file when building for iPhone/iPad.**
|
|
5
|
+
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## 1. Human Interface Guidelines Philosophy
|
|
9
|
+
|
|
10
|
+
### Core Apple Design Principles
|
|
11
|
+
|
|
12
|
+
```
|
|
13
|
+
CLARITY:
|
|
14
|
+
├── Text is legible at every size
|
|
15
|
+
├── Icons are precise and lucid
|
|
16
|
+
├── Adornments are subtle and appropriate
|
|
17
|
+
└── Focus on functionality drives design
|
|
18
|
+
|
|
19
|
+
DEFERENCE:
|
|
20
|
+
├── UI helps people understand and interact
|
|
21
|
+
├── Content fills the screen
|
|
22
|
+
├── UI never competes with content
|
|
23
|
+
└── Translucency hints at more content
|
|
24
|
+
|
|
25
|
+
DEPTH:
|
|
26
|
+
├── Distinct visual layers convey hierarchy
|
|
27
|
+
├── Transitions provide sense of depth
|
|
28
|
+
├── Touch reveals functionality
|
|
29
|
+
└── Content is elevated over UI
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
### iOS Design Values
|
|
33
|
+
|
|
34
|
+
| Value | Implementation |
|
|
35
|
+
|-------|----------------|
|
|
36
|
+
| **Aesthetic Integrity** | Design matches function (game ≠ productivity) |
|
|
37
|
+
| **Consistency** | Use system controls, familiar patterns |
|
|
38
|
+
| **Direct Manipulation** | Touch directly affects content |
|
|
39
|
+
| **Feedback** | Actions are acknowledged |
|
|
40
|
+
| **Metaphors** | Real-world comparisons aid understanding |
|
|
41
|
+
| **User Control** | User initiates actions, can cancel |
|
|
42
|
+
|
|
43
|
+
---
|
|
44
|
+
|
|
45
|
+
## 2. iOS Typography
|
|
46
|
+
|
|
47
|
+
### SF Pro Font Family
|
|
48
|
+
|
|
49
|
+
```
|
|
50
|
+
iOS System Fonts:
|
|
51
|
+
├── SF Pro Text: Body text (< 20pt)
|
|
52
|
+
├── SF Pro Display: Large titles (≥ 20pt)
|
|
53
|
+
├── SF Pro Rounded: Friendly contexts
|
|
54
|
+
├── SF Mono: Code, tabular data
|
|
55
|
+
└── SF Compact: Apple Watch, smaller screens
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### iOS Type Scale (Dynamic Type)
|
|
59
|
+
|
|
60
|
+
| Style | Default Size | Weight | Usage |
|
|
61
|
+
|-------|--------------|--------|-------|
|
|
62
|
+
| **Large Title** | 34pt | Bold | Navigation bar (scroll collapse) |
|
|
63
|
+
| **Title 1** | 28pt | Bold | Page titles |
|
|
64
|
+
| **Title 2** | 22pt | Bold | Section headers |
|
|
65
|
+
| **Title 3** | 20pt | Semibold | Subsection headers |
|
|
66
|
+
| **Headline** | 17pt | Semibold | Emphasized body |
|
|
67
|
+
| **Body** | 17pt | Regular | Primary content |
|
|
68
|
+
| **Callout** | 16pt | Regular | Secondary content |
|
|
69
|
+
| **Subhead** | 15pt | Regular | Tertiary content |
|
|
70
|
+
| **Footnote** | 13pt | Regular | Caption, timestamps |
|
|
71
|
+
| **Caption 1** | 12pt | Regular | Annotations |
|
|
72
|
+
| **Caption 2** | 11pt | Regular | Fine print |
|
|
73
|
+
|
|
74
|
+
### Dynamic Type Support (MANDATORY)
|
|
75
|
+
|
|
76
|
+
```swift
|
|
77
|
+
// ❌ WRONG: Fixed font size
|
|
78
|
+
Text("Hello")
|
|
79
|
+
.font(.system(size: 17))
|
|
80
|
+
|
|
81
|
+
// ✅ CORRECT: Dynamic Type
|
|
82
|
+
Text("Hello")
|
|
83
|
+
.font(.body) // Scales with user settings
|
|
84
|
+
|
|
85
|
+
// React Native equivalent
|
|
86
|
+
<Text style={{ fontSize: 17 }}> // ❌ Fixed
|
|
87
|
+
<Text style={styles.body}> // Use a dynamic scale system
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
### Font Weight Usage
|
|
91
|
+
|
|
92
|
+
| Weight | iOS Constant | Use Case |
|
|
93
|
+
|--------|--------------|----------|
|
|
94
|
+
| Regular (400) | `.regular` | Body text |
|
|
95
|
+
| Medium (500) | `.medium` | Buttons, emphasis |
|
|
96
|
+
| Semibold (600) | `.semibold` | Subheadings |
|
|
97
|
+
| Bold (700) | `.bold` | Titles, key info |
|
|
98
|
+
| Heavy (800) | `.heavy` | Rarely, marketing |
|
|
99
|
+
|
|
100
|
+
---
|
|
101
|
+
|
|
102
|
+
## 3. iOS Color System
|
|
103
|
+
|
|
104
|
+
### System Colors (Semantic)
|
|
105
|
+
|
|
106
|
+
```
|
|
107
|
+
Use semantic colors for automatic dark mode:
|
|
108
|
+
|
|
109
|
+
Primary:
|
|
110
|
+
├── .label → Primary text
|
|
111
|
+
├── .secondaryLabel → Secondary text
|
|
112
|
+
├── .tertiaryLabel → Tertiary text
|
|
113
|
+
├── .quaternaryLabel → Watermarks
|
|
114
|
+
|
|
115
|
+
Backgrounds:
|
|
116
|
+
├── .systemBackground → Main background
|
|
117
|
+
├── .secondarySystemBackground → Grouped content
|
|
118
|
+
├── .tertiarySystemBackground → Elevated content
|
|
119
|
+
|
|
120
|
+
Fills:
|
|
121
|
+
├── .systemFill → Large shapes
|
|
122
|
+
├── .secondarySystemFill → Medium shapes
|
|
123
|
+
├── .tertiarySystemFill → Small shapes
|
|
124
|
+
├── .quaternarySystemFill → Subtle shapes
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
### System Accent Colors
|
|
128
|
+
|
|
129
|
+
| Color | Light Mode | Dark Mode | Usage |
|
|
130
|
+
|-------|------------|-----------|-------|
|
|
131
|
+
| Blue | #007AFF | #0A84FF | Links, highlights, default tint |
|
|
132
|
+
| Green | #34C759 | #30D158 | Success, positive |
|
|
133
|
+
| Red | #FF3B30 | #FF453A | Errors, destructive |
|
|
134
|
+
| Orange | #FF9500 | #FF9F0A | Warnings |
|
|
135
|
+
| Yellow | #FFCC00 | #FFD60A | Attention |
|
|
136
|
+
| Purple | #AF52DE | #BF5AF2 | Special features |
|
|
137
|
+
| Pink | #FF2D55 | #FF375F | Affection, favorites |
|
|
138
|
+
| Teal | #5AC8FA | #64D2FF | Information |
|
|
139
|
+
|
|
140
|
+
### Dark Mode Considerations
|
|
141
|
+
|
|
142
|
+
```
|
|
143
|
+
iOS Dark Mode is not inverted light mode:
|
|
144
|
+
|
|
145
|
+
LIGHT MODE: DARK MODE:
|
|
146
|
+
├── White backgrounds ├── True black (#000) or near-black
|
|
147
|
+
├── High saturation ├── Desaturated colors
|
|
148
|
+
├── Black text ├── White/light gray text
|
|
149
|
+
└── Drop shadows └── Glows or no shadows
|
|
150
|
+
|
|
151
|
+
RULE: Always use semantic colors for automatic adaptation.
|
|
152
|
+
```
|
|
153
|
+
|
|
154
|
+
---
|
|
155
|
+
|
|
156
|
+
## 4. iOS Layout & Spacing
|
|
157
|
+
|
|
158
|
+
### Safe Areas
|
|
159
|
+
|
|
160
|
+
```
|
|
161
|
+
┌─────────────────────────────────────┐
|
|
162
|
+
│░░░░░░░░░░░ Status Bar ░░░░░░░░░░░░░│ ← Top safe area inset
|
|
163
|
+
├─────────────────────────────────────┤
|
|
164
|
+
│ │
|
|
165
|
+
│ │
|
|
166
|
+
│ Safe Content Area │
|
|
167
|
+
│ │
|
|
168
|
+
│ │
|
|
169
|
+
├─────────────────────────────────────┤
|
|
170
|
+
│░░░░░░░░░ Home Indicator ░░░░░░░░░░░│ ← Bottom safe area inset
|
|
171
|
+
└─────────────────────────────────────┘
|
|
172
|
+
|
|
173
|
+
RULE: Never place interactive content in unsafe areas.
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
### Standard Margins & Padding
|
|
177
|
+
|
|
178
|
+
| Element | Margin | Notes |
|
|
179
|
+
|---------|--------|-------|
|
|
180
|
+
| Screen edge → content | 16pt | Standard horizontal margin |
|
|
181
|
+
| Grouped table sections | 16pt top/bottom | Breathing room |
|
|
182
|
+
| List item padding | 16pt horizontal | Standard cell padding |
|
|
183
|
+
| Card internal padding | 16pt | Content within cards |
|
|
184
|
+
| Button internal padding | 12pt vertical, 16pt horizontal | Minimum |
|
|
185
|
+
|
|
186
|
+
### iOS Grid System
|
|
187
|
+
|
|
188
|
+
```
|
|
189
|
+
iPhone Grid (Standard):
|
|
190
|
+
├── 16pt margins (left/right)
|
|
191
|
+
├── 8pt minimum spacing
|
|
192
|
+
├── Content in 8pt multiples
|
|
193
|
+
|
|
194
|
+
iPhone Grid (Compact):
|
|
195
|
+
├── 8pt margins (when needed)
|
|
196
|
+
├── 4pt minimum spacing
|
|
197
|
+
|
|
198
|
+
iPad Grid:
|
|
199
|
+
├── 20pt margins (or more)
|
|
200
|
+
├── Consider multi-column layouts
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
---
|
|
204
|
+
|
|
205
|
+
## 5. iOS Navigation Patterns
|
|
206
|
+
|
|
207
|
+
### Navigation Types
|
|
208
|
+
|
|
209
|
+
| Pattern | Use Case | Implementation |
|
|
210
|
+
|---------|----------|----------------|
|
|
211
|
+
| **Tab Bar** | 3-5 top-level sections | Bottom, always visible |
|
|
212
|
+
| **Navigation Controller** | Hierarchical drill-down | Stack-based, back button |
|
|
213
|
+
| **Modal** | Focused task, interruption | Sheet or full-screen |
|
|
214
|
+
| **Sidebar** | iPad, multi-column | Left sidebar (iPad) |
|
|
215
|
+
|
|
216
|
+
### Tab Bar Guidelines
|
|
217
|
+
|
|
218
|
+
```
|
|
219
|
+
┌─────────────────────────────────────┐
|
|
220
|
+
│ │
|
|
221
|
+
│ Content Area │
|
|
222
|
+
│ │
|
|
223
|
+
├─────────────────────────────────────┤
|
|
224
|
+
│ 🏠 🔍 ➕ ❤️ 👤 │ ← Tab bar (49pt height)
|
|
225
|
+
│ Home Search New Saved Profile │
|
|
226
|
+
└─────────────────────────────────────┘
|
|
227
|
+
|
|
228
|
+
Rules:
|
|
229
|
+
├── 3-5 items maximum
|
|
230
|
+
├── Icons: SF Symbols or custom (25×25pt)
|
|
231
|
+
├── Labels: Always include (accessibility)
|
|
232
|
+
├── Active state: Filled icon + tint color
|
|
233
|
+
└── Tab bar always visible (don't hide on scroll)
|
|
234
|
+
```
|
|
235
|
+
|
|
236
|
+
### Navigation Bar Guidelines
|
|
237
|
+
|
|
238
|
+
```
|
|
239
|
+
┌─────────────────────────────────────┐
|
|
240
|
+
│ < Back Page Title Edit │ ← Navigation bar (44pt)
|
|
241
|
+
├─────────────────────────────────────┤
|
|
242
|
+
│ │
|
|
243
|
+
│ Content Area │
|
|
244
|
+
│ │
|
|
245
|
+
└─────────────────────────────────────┘
|
|
246
|
+
|
|
247
|
+
Rules:
|
|
248
|
+
├── Back button: System chevron + previous title (or "Back")
|
|
249
|
+
├── Title: Centered, dynamic font
|
|
250
|
+
├── Right actions: Max 2 items
|
|
251
|
+
├── Large title: Collapses on scroll (optional)
|
|
252
|
+
└── Prefer text buttons over icons (clarity)
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
### Modal Presentations
|
|
256
|
+
|
|
257
|
+
| Style | Use Case | Appearance |
|
|
258
|
+
|-------|----------|------------|
|
|
259
|
+
| **Sheet (default)** | Secondary tasks | Card slides up, parent visible |
|
|
260
|
+
| **Full Screen** | Immersive tasks | Covers entire screen |
|
|
261
|
+
| **Popover** | iPad, quick info | Arrow-pointed bubble |
|
|
262
|
+
| **Alert** | Critical interruption | Centered dialog |
|
|
263
|
+
| **Action Sheet** | Choices from context | Bottom sheet with options |
|
|
264
|
+
|
|
265
|
+
### Gestures
|
|
266
|
+
|
|
267
|
+
| Gesture | iOS Convention |
|
|
268
|
+
|---------|----------------|
|
|
269
|
+
| **Edge swipe (left)** | Navigate back |
|
|
270
|
+
| **Pull down (sheet)** | Dismiss modal |
|
|
271
|
+
| **Long press** | Context menu |
|
|
272
|
+
| **Deep press** | Peek/Pop (legacy) |
|
|
273
|
+
| **Two-finger swipe** | Scroll in nested scroll |
|
|
274
|
+
|
|
275
|
+
---
|
|
276
|
+
|
|
277
|
+
## 6. iOS Components
|
|
278
|
+
|
|
279
|
+
### Buttons
|
|
280
|
+
|
|
281
|
+
```
|
|
282
|
+
Button Styles (UIKit/SwiftUI):
|
|
283
|
+
|
|
284
|
+
┌──────────────────────────────┐
|
|
285
|
+
│ Tinted │ ← Primary action (filled)
|
|
286
|
+
├──────────────────────────────┤
|
|
287
|
+
│ Bordered │ ← Secondary action (outline)
|
|
288
|
+
├──────────────────────────────┤
|
|
289
|
+
│ Plain │ ← Tertiary action (text only)
|
|
290
|
+
└──────────────────────────────┘
|
|
291
|
+
|
|
292
|
+
Sizes:
|
|
293
|
+
├── Mini: Tight spaces
|
|
294
|
+
├── Small: Compact UI
|
|
295
|
+
├── Medium: Inline actions
|
|
296
|
+
├── Large: Primary CTAs (44pt minimum height)
|
|
297
|
+
```
|
|
298
|
+
|
|
299
|
+
### Lists & Tables
|
|
300
|
+
|
|
301
|
+
```
|
|
302
|
+
List Styles:
|
|
303
|
+
|
|
304
|
+
.plain → No separators, edge-to-edge
|
|
305
|
+
.insetGrouped → Rounded cards (default iOS 14+)
|
|
306
|
+
.grouped → Full-width sections
|
|
307
|
+
.sidebar → iPad sidebar navigation
|
|
308
|
+
|
|
309
|
+
Cell Accessories:
|
|
310
|
+
├── Disclosure indicator (>) → Navigates to detail
|
|
311
|
+
├── Detail button (i) → Shows info without navigation
|
|
312
|
+
├── Checkmark (✓) → Selection
|
|
313
|
+
├── Reorder (≡) → Drag to reorder
|
|
314
|
+
└── Delete (-) → Swipe/edit mode delete
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
### Text Fields
|
|
318
|
+
|
|
319
|
+
```
|
|
320
|
+
iOS Text Field Anatomy:
|
|
321
|
+
|
|
322
|
+
┌─────────────────────────────────────┐
|
|
323
|
+
│ 🔍 Search... ✕ │
|
|
324
|
+
└─────────────────────────────────────┘
|
|
325
|
+
↑ ↑
|
|
326
|
+
Leading icon Clear button
|
|
327
|
+
|
|
328
|
+
Borders: Rounded rectangle
|
|
329
|
+
Height: 36pt minimum
|
|
330
|
+
Placeholder: Secondary text color
|
|
331
|
+
Clear button: Appears when has text
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
### Segmented Controls
|
|
335
|
+
|
|
336
|
+
```
|
|
337
|
+
When to Use:
|
|
338
|
+
├── 2-5 related options
|
|
339
|
+
├── Filter content
|
|
340
|
+
├── Switch views
|
|
341
|
+
|
|
342
|
+
┌───────┬───────┬───────┐
|
|
343
|
+
│ All │ Active│ Done │
|
|
344
|
+
└───────┴───────┴───────┘
|
|
345
|
+
|
|
346
|
+
Rules:
|
|
347
|
+
├── Equal width segments
|
|
348
|
+
├── Text or icons (not both mixed)
|
|
349
|
+
├── Max 5 segments
|
|
350
|
+
└── Consider tabs if more complex
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
---
|
|
354
|
+
|
|
355
|
+
## 7. iOS Specific Patterns
|
|
356
|
+
|
|
357
|
+
### Pull to Refresh
|
|
358
|
+
|
|
359
|
+
```
|
|
360
|
+
Native UIRefreshControl behavior:
|
|
361
|
+
├── Pull beyond threshold → Spinner appears
|
|
362
|
+
├── Release → Refresh action triggered
|
|
363
|
+
├── Loading state → Spinner spins
|
|
364
|
+
├── Complete → Spinner disappears
|
|
365
|
+
|
|
366
|
+
RULE: Always use native UIRefreshControl (don't custom build).
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
### Swipe Actions
|
|
370
|
+
|
|
371
|
+
```
|
|
372
|
+
iOS swipe actions:
|
|
373
|
+
|
|
374
|
+
← Swipe Left (Destructive) Swipe Right (Constructive) →
|
|
375
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
376
|
+
│ List Item Content │
|
|
377
|
+
└─────────────────────────────────────────────────────────────┘
|
|
378
|
+
|
|
379
|
+
Left swipe reveals: Archive, Delete, Flag
|
|
380
|
+
Right swipe reveals: Pin, Star, Mark as Read
|
|
381
|
+
|
|
382
|
+
Full swipe: Triggers first action
|
|
383
|
+
```
|
|
384
|
+
|
|
385
|
+
### Context Menus
|
|
386
|
+
|
|
387
|
+
```
|
|
388
|
+
Long press → Context menu appears
|
|
389
|
+
|
|
390
|
+
┌─────────────────────────────┐
|
|
391
|
+
│ Preview Card │
|
|
392
|
+
├─────────────────────────────┤
|
|
393
|
+
│ 📋 Copy │
|
|
394
|
+
│ 📤 Share │
|
|
395
|
+
│ ➕ Add to... │
|
|
396
|
+
├─────────────────────────────┤
|
|
397
|
+
│ 🗑️ Delete (Red) │
|
|
398
|
+
└─────────────────────────────┘
|
|
399
|
+
|
|
400
|
+
Rules:
|
|
401
|
+
├── Preview: Show enlarged content
|
|
402
|
+
├── Actions: Related to content
|
|
403
|
+
├── Destructive: Last, in red
|
|
404
|
+
└── Max ~8 actions (scrollable if more)
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
### Sheets & Half-Sheets
|
|
408
|
+
|
|
409
|
+
```
|
|
410
|
+
iOS 15+ Sheets:
|
|
411
|
+
|
|
412
|
+
┌─────────────────────────────────────┐
|
|
413
|
+
│ │
|
|
414
|
+
│ Parent View (dimmed) │
|
|
415
|
+
│ │
|
|
416
|
+
├─────────────────────────────────────┤
|
|
417
|
+
│ ═══ (Grabber) │ ← Drag to resize
|
|
418
|
+
│ │
|
|
419
|
+
│ Sheet Content │
|
|
420
|
+
│ │
|
|
421
|
+
│ │
|
|
422
|
+
└─────────────────────────────────────┘
|
|
423
|
+
|
|
424
|
+
Detents:
|
|
425
|
+
├── .medium → Half screen
|
|
426
|
+
├── .large → Full screen (with safe area)
|
|
427
|
+
├── Custom → Specific height
|
|
428
|
+
```
|
|
429
|
+
|
|
430
|
+
---
|
|
431
|
+
|
|
432
|
+
## 8. SF Symbols
|
|
433
|
+
|
|
434
|
+
### Usage Guidelines
|
|
435
|
+
|
|
436
|
+
```
|
|
437
|
+
SF Symbols: Apple's icon library (5000+ icons)
|
|
438
|
+
|
|
439
|
+
Weights: Match text weight
|
|
440
|
+
├── Ultralight / Thin / Light
|
|
441
|
+
├── Regular / Medium / Semibold
|
|
442
|
+
├── Bold / Heavy / Black
|
|
443
|
+
|
|
444
|
+
Scales:
|
|
445
|
+
├── .small → Inline with small text
|
|
446
|
+
├── .medium → Standard UI
|
|
447
|
+
├── .large → Emphasis, standalone
|
|
448
|
+
```
|
|
449
|
+
|
|
450
|
+
### Symbol Configurations
|
|
451
|
+
|
|
452
|
+
```swift
|
|
453
|
+
// SwiftUI
|
|
454
|
+
Image(systemName: "star.fill")
|
|
455
|
+
.font(.title2)
|
|
456
|
+
.foregroundStyle(.yellow)
|
|
457
|
+
|
|
458
|
+
// With rendering mode
|
|
459
|
+
Image(systemName: "heart.fill")
|
|
460
|
+
.symbolRenderingMode(.multicolor)
|
|
461
|
+
|
|
462
|
+
// Animated (iOS 17+)
|
|
463
|
+
Image(systemName: "checkmark.circle")
|
|
464
|
+
.symbolEffect(.bounce)
|
|
465
|
+
```
|
|
466
|
+
|
|
467
|
+
### Symbol Best Practices
|
|
468
|
+
|
|
469
|
+
| Guideline | Implementation |
|
|
470
|
+
|-----------|----------------|
|
|
471
|
+
| Match text weight | Symbol weight = font weight |
|
|
472
|
+
| Use standard symbols | Users recognize them |
|
|
473
|
+
| Multicolor when meaningful | Not just decoration |
|
|
474
|
+
| Fallback for older iOS | Check availability |
|
|
475
|
+
|
|
476
|
+
---
|
|
477
|
+
|
|
478
|
+
## 9. iOS Accessibility
|
|
479
|
+
|
|
480
|
+
### VoiceOver Requirements
|
|
481
|
+
|
|
482
|
+
```
|
|
483
|
+
Every interactive element needs:
|
|
484
|
+
├── Accessibility label (what it is)
|
|
485
|
+
├── Accessibility hint (what it does) - optional
|
|
486
|
+
├── Accessibility traits (button, link, etc.)
|
|
487
|
+
└── Accessibility value (current state)
|
|
488
|
+
|
|
489
|
+
SwiftUI:
|
|
490
|
+
.accessibilityLabel("Play")
|
|
491
|
+
.accessibilityHint("Plays the selected track")
|
|
492
|
+
|
|
493
|
+
React Native:
|
|
494
|
+
accessibilityLabel="Play"
|
|
495
|
+
accessibilityHint="Plays the selected track"
|
|
496
|
+
accessibilityRole="button"
|
|
497
|
+
```
|
|
498
|
+
|
|
499
|
+
### Dynamic Type Scaling
|
|
500
|
+
|
|
501
|
+
```
|
|
502
|
+
MANDATORY: Support Dynamic Type
|
|
503
|
+
|
|
504
|
+
Users can set text size from:
|
|
505
|
+
├── xSmall → 14pt body
|
|
506
|
+
├── Small → 15pt body
|
|
507
|
+
├── Medium → 16pt body
|
|
508
|
+
├── Large (Default) → 17pt body
|
|
509
|
+
├── xLarge → 19pt body
|
|
510
|
+
├── xxLarge → 21pt body
|
|
511
|
+
├── xxxLarge → 23pt body
|
|
512
|
+
├── Accessibility sizes → up to 53pt
|
|
513
|
+
|
|
514
|
+
Your app MUST scale gracefully at all sizes.
|
|
515
|
+
```
|
|
516
|
+
|
|
517
|
+
### Reduce Motion
|
|
518
|
+
|
|
519
|
+
```
|
|
520
|
+
Respect motion preferences:
|
|
521
|
+
|
|
522
|
+
@Environment(\.accessibilityReduceMotion) var reduceMotion
|
|
523
|
+
|
|
524
|
+
if reduceMotion {
|
|
525
|
+
// Use instant transitions
|
|
526
|
+
} else {
|
|
527
|
+
// Use animations
|
|
528
|
+
}
|
|
529
|
+
|
|
530
|
+
React Native:
|
|
531
|
+
import { AccessibilityInfo } from 'react-native';
|
|
532
|
+
AccessibilityInfo.isReduceMotionEnabled()
|
|
533
|
+
```
|
|
534
|
+
|
|
535
|
+
---
|
|
536
|
+
|
|
537
|
+
## 10. iOS Checklist
|
|
538
|
+
|
|
539
|
+
### Before Every iOS Screen
|
|
540
|
+
|
|
541
|
+
- [ ] Using SF Pro or SF Symbols
|
|
542
|
+
- [ ] Dynamic Type supported
|
|
543
|
+
- [ ] Safe areas respected
|
|
544
|
+
- [ ] Navigation follows HIG (back gesture works)
|
|
545
|
+
- [ ] Tab bar items ≤ 5
|
|
546
|
+
- [ ] Touch targets ≥ 44pt
|
|
547
|
+
|
|
548
|
+
### Before iOS Release
|
|
549
|
+
|
|
550
|
+
- [ ] Dark mode tested
|
|
551
|
+
- [ ] All text sizes tested (Accessibility Inspector)
|
|
552
|
+
- [ ] VoiceOver tested
|
|
553
|
+
- [ ] Edge swipe back works everywhere
|
|
554
|
+
- [ ] Keyboard avoidance implemented
|
|
555
|
+
- [ ] Notch/Dynamic Island handled
|
|
556
|
+
- [ ] Home indicator area respected
|
|
557
|
+
- [ ] Native components used where possible
|
|
558
|
+
|
|
559
|
+
---
|
|
560
|
+
|
|
561
|
+
> **Remember:** iOS users have strong expectations from other iOS apps. Deviating from HIG patterns feels "broken" to them. When in doubt, use the native component.
|