tribunal-kit 2.4.6 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (250) hide show
  1. package/.agent/ARCHITECTURE.md +99 -99
  2. package/.agent/GEMINI.md +52 -52
  3. package/.agent/agents/accessibility-reviewer.md +139 -86
  4. package/.agent/agents/ai-code-reviewer.md +160 -90
  5. package/.agent/agents/backend-specialist.md +164 -127
  6. package/.agent/agents/code-archaeologist.md +115 -73
  7. package/.agent/agents/database-architect.md +130 -110
  8. package/.agent/agents/debugger.md +137 -97
  9. package/.agent/agents/dependency-reviewer.md +78 -30
  10. package/.agent/agents/devops-engineer.md +161 -118
  11. package/.agent/agents/documentation-writer.md +151 -87
  12. package/.agent/agents/explorer-agent.md +117 -99
  13. package/.agent/agents/frontend-reviewer.md +127 -47
  14. package/.agent/agents/frontend-specialist.md +169 -109
  15. package/.agent/agents/game-developer.md +28 -164
  16. package/.agent/agents/logic-reviewer.md +87 -49
  17. package/.agent/agents/mobile-developer.md +151 -103
  18. package/.agent/agents/mobile-reviewer.md +133 -50
  19. package/.agent/agents/orchestrator.md +121 -110
  20. package/.agent/agents/penetration-tester.md +103 -77
  21. package/.agent/agents/performance-optimizer.md +136 -92
  22. package/.agent/agents/performance-reviewer.md +139 -69
  23. package/.agent/agents/product-manager.md +104 -70
  24. package/.agent/agents/product-owner.md +6 -25
  25. package/.agent/agents/project-planner.md +95 -95
  26. package/.agent/agents/qa-automation-engineer.md +174 -87
  27. package/.agent/agents/security-auditor.md +133 -129
  28. package/.agent/agents/seo-specialist.md +160 -99
  29. package/.agent/agents/sql-reviewer.md +132 -44
  30. package/.agent/agents/supervisor-agent.md +137 -109
  31. package/.agent/agents/swarm-worker-contracts.md +17 -17
  32. package/.agent/agents/swarm-worker-registry.md +46 -46
  33. package/.agent/agents/test-coverage-reviewer.md +132 -53
  34. package/.agent/agents/test-engineer.md +0 -21
  35. package/.agent/agents/type-safety-reviewer.md +143 -33
  36. package/.agent/patterns/generator.md +9 -9
  37. package/.agent/patterns/inversion.md +12 -12
  38. package/.agent/patterns/pipeline.md +9 -9
  39. package/.agent/patterns/reviewer.md +13 -13
  40. package/.agent/patterns/tool-wrapper.md +9 -9
  41. package/.agent/rules/GEMINI.md +63 -63
  42. package/.agent/scripts/__pycache__/auto_preview.cpython-311.pyc +0 -0
  43. package/.agent/scripts/__pycache__/bundle_analyzer.cpython-311.pyc +0 -0
  44. package/.agent/scripts/__pycache__/checklist.cpython-311.pyc +0 -0
  45. package/.agent/scripts/__pycache__/dependency_analyzer.cpython-311.pyc +0 -0
  46. package/.agent/scripts/__pycache__/security_scan.cpython-311.pyc +0 -0
  47. package/.agent/scripts/__pycache__/session_manager.cpython-311.pyc +0 -0
  48. package/.agent/scripts/__pycache__/skill_integrator.cpython-311.pyc +0 -0
  49. package/.agent/scripts/__pycache__/swarm_dispatcher.cpython-311.pyc +0 -0
  50. package/.agent/scripts/__pycache__/test_runner.cpython-311.pyc +0 -0
  51. package/.agent/scripts/__pycache__/verify_all.cpython-311.pyc +0 -0
  52. package/.agent/scripts/compress_skills.py +167 -0
  53. package/.agent/scripts/consolidate_skills.py +173 -0
  54. package/.agent/scripts/deep_compress.py +202 -0
  55. package/.agent/scripts/minify_context.py +80 -0
  56. package/.agent/scripts/security_scan.py +1 -1
  57. package/.agent/scripts/strip_tribunal.py +41 -0
  58. package/.agent/skills/agent-organizer/SKILL.md +60 -100
  59. package/.agent/skills/agentic-patterns/SKILL.md +0 -70
  60. package/.agent/skills/ai-prompt-injection-defense/SKILL.md +108 -53
  61. package/.agent/skills/api-patterns/SKILL.md +197 -257
  62. package/.agent/skills/api-security-auditor/SKILL.md +125 -57
  63. package/.agent/skills/app-builder/SKILL.md +326 -50
  64. package/.agent/skills/app-builder/templates/SKILL.md +13 -15
  65. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
  66. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
  67. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
  68. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
  69. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
  70. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
  71. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
  72. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
  73. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
  74. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
  75. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
  76. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
  77. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
  78. package/.agent/skills/appflow-wireframe/SKILL.md +71 -98
  79. package/.agent/skills/architecture/SKILL.md +161 -200
  80. package/.agent/skills/authentication-best-practices/SKILL.md +121 -54
  81. package/.agent/skills/bash-linux/SKILL.md +71 -166
  82. package/.agent/skills/behavioral-modes/SKILL.md +8 -69
  83. package/.agent/skills/brainstorming/SKILL.md +345 -127
  84. package/.agent/skills/building-native-ui/SKILL.md +125 -57
  85. package/.agent/skills/clean-code/SKILL.md +266 -149
  86. package/.agent/skills/code-review-checklist/SKILL.md +0 -62
  87. package/.agent/skills/config-validator/SKILL.md +73 -131
  88. package/.agent/skills/csharp-developer/SKILL.md +434 -73
  89. package/.agent/skills/database-design/SKILL.md +190 -275
  90. package/.agent/skills/deployment-procedures/SKILL.md +81 -158
  91. package/.agent/skills/devops-engineer/SKILL.md +255 -94
  92. package/.agent/skills/devops-incident-responder/SKILL.md +50 -69
  93. package/.agent/skills/doc.md +5 -5
  94. package/.agent/skills/documentation-templates/SKILL.md +19 -63
  95. package/.agent/skills/edge-computing/SKILL.md +75 -165
  96. package/.agent/skills/extract-design-system/SKILL.md +84 -58
  97. package/.agent/skills/framer-motion-expert/SKILL.md +195 -0
  98. package/.agent/skills/frontend-design/SKILL.md +151 -499
  99. package/.agent/skills/game-design-expert/SKILL.md +71 -0
  100. package/.agent/skills/game-engineering-expert/SKILL.md +88 -0
  101. package/.agent/skills/geo-fundamentals/SKILL.md +52 -178
  102. package/.agent/skills/github-operations/SKILL.md +197 -272
  103. package/.agent/skills/gsap-expert/SKILL.md +194 -0
  104. package/.agent/skills/i18n-localization/SKILL.md +60 -172
  105. package/.agent/skills/intelligent-routing/SKILL.md +123 -103
  106. package/.agent/skills/lint-and-validate/SKILL.md +8 -52
  107. package/.agent/skills/llm-engineering/SKILL.md +281 -195
  108. package/.agent/skills/local-first/SKILL.md +76 -159
  109. package/.agent/skills/mcp-builder/SKILL.md +48 -188
  110. package/.agent/skills/mobile-design/SKILL.md +213 -219
  111. package/.agent/skills/motion-engineering/SKILL.md +184 -0
  112. package/.agent/skills/nextjs-react-expert/SKILL.md +184 -203
  113. package/.agent/skills/nodejs-best-practices/SKILL.md +403 -185
  114. package/.agent/skills/observability/SKILL.md +211 -203
  115. package/.agent/skills/parallel-agents/SKILL.md +53 -146
  116. package/.agent/skills/performance-profiling/SKILL.md +171 -151
  117. package/.agent/skills/plan-writing/SKILL.md +49 -153
  118. package/.agent/skills/platform-engineer/SKILL.md +57 -103
  119. package/.agent/skills/playwright-best-practices/SKILL.md +110 -63
  120. package/.agent/skills/powershell-windows/SKILL.md +61 -179
  121. package/.agent/skills/python-patterns/SKILL.md +7 -35
  122. package/.agent/skills/python-pro/SKILL.md +273 -114
  123. package/.agent/skills/react-specialist/SKILL.md +227 -108
  124. package/.agent/skills/readme-builder/SKILL.md +15 -85
  125. package/.agent/skills/realtime-patterns/SKILL.md +216 -243
  126. package/.agent/skills/red-team-tactics/SKILL.md +10 -51
  127. package/.agent/skills/rust-pro/SKILL.md +525 -142
  128. package/.agent/skills/seo-fundamentals/SKILL.md +92 -153
  129. package/.agent/skills/server-management/SKILL.md +110 -166
  130. package/.agent/skills/shadcn-ui-expert/SKILL.md +154 -55
  131. package/.agent/skills/skill-creator/SKILL.md +18 -58
  132. package/.agent/skills/sql-pro/SKILL.md +543 -68
  133. package/.agent/skills/supabase-postgres-best-practices/SKILL.md +28 -68
  134. package/.agent/skills/swiftui-expert/SKILL.md +124 -57
  135. package/.agent/skills/systematic-debugging/SKILL.md +49 -151
  136. package/.agent/skills/tailwind-patterns/SKILL.md +433 -149
  137. package/.agent/skills/tdd-workflow/SKILL.md +63 -169
  138. package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
  139. package/.agent/skills/testing-patterns/SKILL.md +437 -130
  140. package/.agent/skills/trend-researcher/SKILL.md +30 -71
  141. package/.agent/skills/ui-ux-pro-max/SKILL.md +0 -41
  142. package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
  143. package/.agent/skills/vue-expert/SKILL.md +225 -119
  144. package/.agent/skills/vulnerability-scanner/SKILL.md +264 -226
  145. package/.agent/skills/web-accessibility-auditor/SKILL.md +141 -58
  146. package/.agent/skills/web-design-guidelines/SKILL.md +17 -61
  147. package/.agent/skills/webapp-testing/SKILL.md +71 -196
  148. package/.agent/skills/whimsy-injector/SKILL.md +58 -132
  149. package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
  150. package/.agent/workflows/api-tester.md +96 -224
  151. package/.agent/workflows/audit.md +81 -122
  152. package/.agent/workflows/brainstorm.md +69 -105
  153. package/.agent/workflows/changelog.md +65 -97
  154. package/.agent/workflows/create.md +73 -88
  155. package/.agent/workflows/debug.md +80 -111
  156. package/.agent/workflows/deploy.md +119 -92
  157. package/.agent/workflows/enhance.md +80 -91
  158. package/.agent/workflows/fix.md +68 -97
  159. package/.agent/workflows/generate.md +165 -164
  160. package/.agent/workflows/migrate.md +106 -109
  161. package/.agent/workflows/orchestrate.md +103 -86
  162. package/.agent/workflows/performance-benchmarker.md +77 -268
  163. package/.agent/workflows/plan.md +120 -98
  164. package/.agent/workflows/preview.md +39 -96
  165. package/.agent/workflows/refactor.md +105 -97
  166. package/.agent/workflows/review-ai.md +63 -102
  167. package/.agent/workflows/review.md +71 -110
  168. package/.agent/workflows/session.md +53 -113
  169. package/.agent/workflows/status.md +42 -88
  170. package/.agent/workflows/strengthen-skills.md +90 -51
  171. package/.agent/workflows/swarm.md +114 -129
  172. package/.agent/workflows/test.md +125 -102
  173. package/.agent/workflows/tribunal-backend.md +60 -78
  174. package/.agent/workflows/tribunal-database.md +62 -100
  175. package/.agent/workflows/tribunal-frontend.md +62 -82
  176. package/.agent/workflows/tribunal-full.md +56 -100
  177. package/.agent/workflows/tribunal-mobile.md +65 -94
  178. package/.agent/workflows/tribunal-performance.md +62 -105
  179. package/.agent/workflows/ui-ux-pro-max.md +72 -121
  180. package/README.md +11 -15
  181. package/package.json +1 -1
  182. package/.agent/skills/api-patterns/api-style.md +0 -42
  183. package/.agent/skills/api-patterns/auth.md +0 -24
  184. package/.agent/skills/api-patterns/documentation.md +0 -26
  185. package/.agent/skills/api-patterns/graphql.md +0 -41
  186. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  187. package/.agent/skills/api-patterns/response.md +0 -37
  188. package/.agent/skills/api-patterns/rest.md +0 -40
  189. package/.agent/skills/api-patterns/security-testing.md +0 -122
  190. package/.agent/skills/api-patterns/trpc.md +0 -41
  191. package/.agent/skills/api-patterns/versioning.md +0 -22
  192. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  193. package/.agent/skills/app-builder/feature-building.md +0 -53
  194. package/.agent/skills/app-builder/project-detection.md +0 -34
  195. package/.agent/skills/app-builder/scaffolding.md +0 -118
  196. package/.agent/skills/app-builder/tech-stack.md +0 -40
  197. package/.agent/skills/architecture/context-discovery.md +0 -43
  198. package/.agent/skills/architecture/examples.md +0 -94
  199. package/.agent/skills/architecture/pattern-selection.md +0 -68
  200. package/.agent/skills/architecture/patterns-reference.md +0 -50
  201. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  202. package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
  203. package/.agent/skills/database-design/database-selection.md +0 -43
  204. package/.agent/skills/database-design/indexing.md +0 -39
  205. package/.agent/skills/database-design/migrations.md +0 -48
  206. package/.agent/skills/database-design/optimization.md +0 -36
  207. package/.agent/skills/database-design/orm-selection.md +0 -30
  208. package/.agent/skills/database-design/schema-design.md +0 -56
  209. package/.agent/skills/dotnet-core-expert/SKILL.md +0 -103
  210. package/.agent/skills/framer-motion-animations/SKILL.md +0 -74
  211. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  212. package/.agent/skills/frontend-design/color-system.md +0 -329
  213. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  214. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  215. package/.agent/skills/frontend-design/typography-system.md +0 -363
  216. package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
  217. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  218. package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
  219. package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
  220. package/.agent/skills/game-development/SKILL.md +0 -236
  221. package/.agent/skills/game-development/game-art/SKILL.md +0 -185
  222. package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
  223. package/.agent/skills/game-development/game-design/SKILL.md +0 -129
  224. package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
  225. package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
  226. package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
  227. package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
  228. package/.agent/skills/game-development/web-games/SKILL.md +0 -150
  229. package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
  230. package/.agent/skills/mobile-design/decision-trees.md +0 -516
  231. package/.agent/skills/mobile-design/mobile-backend.md +0 -491
  232. package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
  233. package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
  234. package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
  235. package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
  236. package/.agent/skills/mobile-design/mobile-performance.md +0 -767
  237. package/.agent/skills/mobile-design/mobile-testing.md +0 -356
  238. package/.agent/skills/mobile-design/mobile-typography.md +0 -433
  239. package/.agent/skills/mobile-design/platform-android.md +0 -666
  240. package/.agent/skills/mobile-design/platform-ios.md +0 -561
  241. package/.agent/skills/mobile-design/touch-psychology.md +0 -537
  242. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
  243. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
  244. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
  245. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
  246. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
  247. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
  248. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
  249. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
  250. package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
@@ -1,561 +0,0 @@
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.