ios-swiftui-architecture-review

Analyze SwiftUI view hierarchies and suggest MVVM or other architectural improvements. Use when **reviewing existing SwiftUI code**, creating new SwiftUI components, analyzing view structure, or when the user asks about SwiftUI architecture patterns. Best for code review and refactoring guidance.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "ios-swiftui-architecture-review" with this command: npx skills add desquared/agents-rules-skills/desquared-agents-rules-skills-ios-swiftui-architecture-review

SwiftUI Architecture Review

When to Use This Skill:

  • Reviewing EXISTING SwiftUI views/ViewModels
  • Code review for architectural violations
  • Refactoring guidance for specific files
  • Validating state management patterns

When to Use project-architecture-analyst Agent Instead:

  • Planning NEW features (uncertain file placement)
  • Understanding project-wide architecture
  • Major changes affecting multiple modules
  • Need to discover existing patterns before implementing

Review Checklist

Separation of Concerns

  • Views: presentation only (no business logic, network, DB)
  • ViewModels: state + business logic (@Observable or ObservableObject)
  • Data access separated from views

State Management

  • @State - view-local state only
  • @StateObject - view-owned ViewModels (avoid in List rows)
  • @ObservedObject - passed-in ViewModels
  • @Bindable - two-way binding to Observable objects (iOS 17+)
  • @Environment - shared state (read-only preferred)
  • @EnvironmentObject - injected dependencies (check for missing inject)

State Lifecycle Issues

  • No retained cycles in ViewModels (@Published closures)
  • Proper cleanup in deinit or .onDisappear
  • @StateObject not recreated on parent refresh
  • Environment values exist before access

Dependency Injection

  • Dependencies injected (check project: Swinject, Resolver, Factory, manual)
  • No hardcoded singletons in views
  • ViewModels receive dependencies

View Composition

  • Views are small (single responsibility)
  • Complex views broken into components
  • Reusable components extracted

Common Issues

IssueFix
Business logic in viewExtract to ViewModel
Network call in viewMove to ViewModel with task
Singleton in viewInject via DI or @Environment
200+ line viewBreak into components

Severity

  • 🔴 Critical: Architecture violation
  • 🟡 Improvement: Better pattern available
  • 🟢 Enhancement: Optional optimization

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Automation

shared-bug-investigation

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

ios-accessibility-validator

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

android-accessibility-validator

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

android-compose-architecture-review

No summary provided by upstream source.

Repository SourceNeeds Review