ios-storyboard
SKILL.md
iOS Storyboard Best Practices
Legacy interoperability guidance for storyboard-heavy code that still exists in clinic projects. Not for new SwiftUI clinic feature development.
Comprehensive UI design and architecture guide for Xcode Storyboard and Interface Builder, focused on building maintainable, adaptive, and accessible iOS interfaces. Contains 45 rules across 8 categories, prioritized by impact to guide automated refactoring and code generation.
Clinic Architecture Contract (iOS 26 / Swift 6.2)
All guidance in this skill assumes the clinic modular MVVM-C architecture:
- Feature modules import
Domain+DesignSystemonly (neverData, never sibling features) - App target is the convergence point and owns
DependencyContainer, concrete coordinators, and Route Shell wiring Domainstays pure Swift and defines models plus repository,*Coordinating,ErrorRouting, andAppErrorcontractsDataowns SwiftData/network/sync/retry/background I/O and implements Domain protocols- Read/write flow defaults to stale-while-revalidate reads and optimistic queued writes
- ViewModels call repository protocols directly (no default use-case/interactor layer)
When to Apply
Reference these guidelines when:
- Creating or modifying Storyboard scenes in Xcode Interface Builder
- Setting up Auto Layout constraints for adaptive layouts
- Designing navigation flows with segues and storyboard references
- Configuring size classes and trait variations for universal apps
- Reviewing storyboard XML diffs and resolving merge conflicts
Rule Categories by Priority
| Priority | Category | Impact | Prefix |
|---|---|---|---|
| 1 | Storyboard Architecture | CRITICAL | arch- |
| 2 | Auto Layout Constraints | CRITICAL | layout- |
| 3 | Navigation & Segues | HIGH | nav- |
| 4 | Adaptive Layout & Size Classes | HIGH | adapt- |
| 5 | View Hierarchy & Stack Views | MEDIUM-HIGH | view- |
| 6 | Accessibility & VoiceOver | MEDIUM | ally- |
| 7 | Version Control & Collaboration | MEDIUM | vcs- |
| 8 | Debugging & Inspection | LOW-MEDIUM | debug- |
Quick Reference
1. Storyboard Architecture (CRITICAL)
arch-split-storyboards- Split Monolithic Storyboards into Feature Modulesarch-storyboard-references- Use Storyboard References for Cross-Module Navigationarch-one-scene-per-flow- Limit Each Storyboard to a Single User Flowarch-initial-view-controller- Set Initial View Controller Explicitly in Every Storyboardarch-avoid-hardcoded-identifiers- Avoid Hardcoded Storyboard and Cell Identifiersarch-scene-naming- Use Descriptive Scene Labels in Document Outlinearch-modular-xibs- Extract Reusable Views into Separate XIB Files
2. Auto Layout Constraints (CRITICAL)
layout-avoid-fixed-dimensions- Avoid Fixed Width and Height Constraintslayout-leading-trailing- Use Leading and Trailing Instead of Left and Rightlayout-safe-area- Constrain Views to Safe Area Guideslayout-content-hugging- Set Content Hugging and Compression Resistance Prioritieslayout-constraint-nearest-neighbor- Constrain to Nearest Neighbor Viewslayout-avoid-constant-offsets- Use Layout Margins Instead of Constant Offsetslayout-inequality-constraints- Use Inequality Constraints for Flexible Minimums and Maximumslayout-constraint-priorities- Assign Distinct Priorities to Optional Constraints
3. Navigation & Segues (HIGH)
nav-prepare-for-segue- Pass Data via prepare(for:sender:) Instead of Direct Property Accessnav-unwind-segues- Use Unwind Segues to Navigate Backwardnav-avoid-mixed-navigation- Avoid Mixing Segue and Programmatic Navigationnav-adaptive-segues- Use Show and Show Detail Instead of Push and Modalnav-perform-segue-validation- Validate Segue Conditions with shouldPerformSeguenav-container-view-controllers- Use Container Views for Embedded Child View Controllers
4. Adaptive Layout & Size Classes (HIGH)
adapt-size-classes- Configure Constraints per Size Class Using Vary for Traitsadapt-trait-variations- Use Trait Variations for Font and Spacing Adjustmentsadapt-safe-area-all-devices- Test Adaptive Layouts on All Device Size Classesadapt-readable-content-guide- Use Readable Content Guide for Text on Large Screensadapt-dynamic-type- Support Dynamic Type for All Text Labels
5. View Hierarchy & Stack Views (MEDIUM-HIGH)
view-prefer-stack-views- Use Stack Views Instead of Manual Constraints for Linear Layoutsview-avoid-deep-nesting- Avoid Deeply Nested Stack Views Beyond Two Levelsview-intrinsic-content-size- Rely on Intrinsic Content Size for Standard UIKit Controlsview-placeholder-intrinsic-size- Use Placeholder Intrinsic Size for Custom Views in Storyboardview-clip-to-bounds- Enable Clip to Bounds for Views with Corner Radiusview-content-mode- Set Correct Content Mode for UIImageView in Storyboard
6. Accessibility & VoiceOver (MEDIUM)
ally-labels- Set Accessibility Labels for All Interactive Elementsally-traits- Assign Correct Accessibility Traits in Interface Builderally-grouping- Group Related Elements for VoiceOver Navigationally-identifiers- Set Accessibility Identifiers for UI Testingally-dynamic-labels- Update Accessibility Labels for Dynamic Content
7. Version Control & Collaboration (MEDIUM)
vcs-one-scene-per-developer- Assign Storyboard Scenes to Individual Developersvcs-open-as-source- Review Storyboard Diffs as Source Code Before Committingvcs-lock-storyboard-files- Use Git File Locking for Active Storyboard Editsvcs-gitattributes-merge- Configure .gitattributes to Use Union Merge for Storyboards
8. Debugging & Inspection (LOW-MEDIUM)
debug-view-hierarchy- Use Debug View Hierarchy to Inspect Layout Issuesdebug-ambiguous-layout- Use hasAmbiguousLayout to Detect Constraint Problems at Runtimedebug-constraint-identifier- Assign Identifiers to Constraints for Readable Logsdebug-stale-outlets- Remove Stale Outlet Connections to Prevent Crashes
How to Use
Read individual reference files for detailed explanations and code examples:
- Section definitions - Category structure and impact levels
- Rule template - Template for adding new rules
Reference Files
| File | Description |
|---|---|
| references/_sections.md | Category definitions and ordering |
| assets/templates/_template.md | Template for new rules |
| metadata.json | Version and reference information |
Weekly Installs
33
Repository
pproenca/dot-skillsGitHub Stars
70
First Seen
Feb 8, 2026
Security Audits
Installed on
codex29
github-copilot28
gemini-cli28
opencode27
kimi-cli27
cursor27