Add expert SwiftUI Best Practices guidance to your AI coding tool (Agent Skills open format).
Find a file
github-actions[bot] a5f130a0be Bump version to 3.0.0
2026-04-22 13:45:02 +00:00
.agents/skills/update-swiftui-apis Add maintenance skill to scan and update SwiftUI API deprecations 2026-02-27 14:20:52 +01:00
.claude-plugin Bump version to 3.0.0 2026-04-22 13:45:02 +00:00
.cursor-plugin Bump version to 3.0.0 2026-04-22 13:45:02 +00:00
.github Add Cursor plugin packaging. 2026-03-16 15:51:59 +01:00
agents Sharpen SKILL.md concision and add OpenAI manifest 2026-03-16 19:17:28 +01:00
assets Add Cursor plugin packaging. 2026-03-16 15:51:59 +01:00
swiftui-expert-skill Fixes PR comments 2026-04-22 13:48:45 +01:00
.gitignore Updates .gitignore 2026-04-22 13:17:46 +01:00
AGENTS.md Add maintenance skill to scan and update SwiftUI API deprecations 2026-02-27 14:20:52 +01:00
CONTRIBUTING.md Add maintenance skill to scan and update SwiftUI API deprecations 2026-02-27 14:20:52 +01:00
LICENSE Initial commit 2026-01-21 15:42:30 +01:00
package.json feat: add pi package manager install support 2026-03-29 10:36:13 -07:00
README.md Mentions the recording in the README.md file 2026-04-22 14:40:24 +01:00

SwiftUI Expert Skill

License: MIT Weekly Installs GitHub Release GitHub Stars

Expert guidance for any AI coding tool that supports the Agent Skills open format — SwiftUI state management, view composition, performance, and iOS 26+ Liquid Glass adoption.

This repository distills practical SwiftUI best practices into actionable, concise references for agents and code review workflows.

Who this is for

  • Teams adopting modern SwiftUI APIs who want quick, correct defaults
  • Developers reviewing or refactoring SwiftUI views and data flow
  • Anyone shipping performant lists, scrolling, sheets, and navigation in SwiftUI

See also my other skills:

How to Use This Skill

Option A: Using skills.sh

Install this skill with a single command:

npx skills add https://github.com/avdlee/swiftui-agent-skill --skill swiftui-expert-skill

For more information, visit the skills.sh platform page.

Then use the skill in your AI agent, for example:

Use the swiftui expert skill and review the current SwiftUI code for state-management and performance improvements

Option B: Claude Code Plugin

Personal Usage

To install this Skill for your personal use in Claude Code:

  1. Add the marketplace:
/plugin marketplace add AvdLee/SwiftUI-Agent-Skill
  1. Install the Skill:
/plugin install swiftui-expert@swiftui-expert-skill

Option C: Cursor plugin (coming soon)

This repository is now packaged for Cursor plugin submission, but the marketplace listing is not live yet.

Once approved, you'll be able to install it from the Cursor Marketplace.

Project Configuration

To automatically provide this Skill to everyone working in a repository, configure the repository's .claude/settings.json:

{
  "enabledPlugins": {
    "swiftui-expert@swiftui-expert-skill": true
  },
  "extraKnownMarketplaces": {
    "swiftui-expert-skill": {
      "source": {
        "source": "github",
        "repo": "AvdLee/SwiftUI-Agent-Skill"
      }
    }
  }
}

When team members open the project, Claude Code will prompt them to install the Skill.

Option D: Codex / OpenAI-compatible tools

This repository includes an agents/openai.yaml manifest. Copy or symlink the swiftui-expert-skill/ folder into your Codex skills directory:

cp -R swiftui-expert-skill/ "$CODEX_HOME/skills/swiftui-expert-skill"

See Codex skills documentation for details on where to save skills.

Option E: Using pi package manager

Install via pi:

pi install https://github.com/AvdLee/SwiftUI-Agent-Skill

The skill will be available automatically in pi sessions.

Option F: Manual install

  1. Clone this repository.
  2. Install or symlink the swiftui-expert-skill/ folder following your tools official skills installation docs (see links below).
  3. Use your AI tool as usual and ask it to use the “swiftui-expert” skill for SwiftUI tasks.

Where to Save Skills

Follow your tools official documentation, here are a few popular ones:

How to verify:

Your agent should reference the workflow/checklists in swiftui-expert-skill/SKILL.md and jump into the relevant reference file for your task.

What's Inside

This skill covers the full surface of SwiftUI development -- from state management and view composition to Swift Charts, macOS multi-window scenes, animations, and iOS 26+ Liquid Glass -- without bloating your agent's task context. Reference files load on demand, so your agent gets deep guidance only for the topic at hand.

  • State management -- property wrapper selection, @Observable, data flow patterns
  • View composition -- extraction patterns, container views, identity stability
  • Performance -- hot-path optimization, lazy loading, @Observable granularity
  • Lists & ForEach -- stable identity, Table, inline filtering pitfalls
  • Navigation & sheets -- NavigationStack, NavigationSplitView, Inspector, enum-based sheets
  • Swift Charts -- marks, axes, selection, styling, accessibility, Chart3D
  • Animations -- implicit/explicit, transitions, phase/keyframe, @Animatable macro
  • macOS -- scenes, window styling, Table, HSplitView, AppKit interop
  • Liquid Glass -- iOS 26+ glass effects, containers, fallback patterns
  • Accessibility -- VoiceOver, Dynamic Type, grouping, traits
  • Image optimization -- AsyncImage, downsampling, caching
  • Latest APIs -- deprecated-to-modern migration guide (iOS 15+ through iOS 26+)
  • Instruments trace recording & analysis -- bundled xctrace toolchain for diagnosing hangs, hitches, and expensive SwiftUI view updates (see below)

Non-opinionated: focuses on correctness and performance, not architecture or code style.

Recording & Analysing Instruments Traces

Unlike the other reference files — which are text guidance — this part of the skill ships an executable Python toolchain that wraps xctrace. It lets the agent record a new .trace and analyse an existing one end-to-end: the parser reads the Time Profiler, Hangs, Animation Hitches, SwiftUI updates, and SwiftUI cause-graph lanes, correlates hangs/hitches with main-thread samples, and emits JSON + markdown so the agent can reason over structured data instead of the raw xctrace export firehose.

When it triggers:

  • A .trace path appears in the prompt (analysis).
  • The user asks to record, profile, or capture a session (recording).

What the agent can then ask:

Analyse ~/Desktop/MyApp.trace and tell me what's wrong.

Focus analysis on what happens right after the 'feed loaded' log.

Which of my SwiftUI views is responsible for the hang around 6s?

Record a new trace: attach to MyApp on my iPhone — I'll tell you when I'm done.

Under the hood:

  • scripts/record_trace.py — wraps xctrace record. Supports attach / launch / all-processes, stop-file for agent-driven sessions, time-limits, JSON device & template discovery.
  • scripts/analyze_trace.py — runs the five-lane analysis. Discovery modes --list-logs, --list-signposts, --fanin-for let the agent scope to a time window or trace a specific view back to its invalidation sources. --window START_MS:END_MS restricts every lane to a slice.
  • scripts/instruments_parser/ — one module per lane (time_profiler, hangs, hitches, swiftui, causes), plus cross-lane correlate and a markdown summary renderer. Pure stdlib Python 3; only external dep is xctrace (ships with Xcode).

Key diagnostic: main_running_coverage_pct on each hang/hitch correlation. < 25 % → main thread was blocked (I/O, lock, sync await); ≥ 75 % → CPU-bound. This single metric separates two radically different fix paths.

Full guidance: swiftui-expert-skill/references/trace-analysis.md and swiftui-expert-skill/references/trace-recording.md.

Skill Structure

swiftui-expert-skill/
  SKILL.md
  references/
    accessibility-patterns.md - Accessibility traits, grouping, Dynamic Type, and VoiceOver
    animation-advanced.md - Performance, interpolation, and complex animation chains
    animation-basics.md - Core animation concepts, implicit/explicit animations, timing
    animation-transitions.md - View transitions, matchedGeometryEffect, and state changes
    charts-accessibility.md - Charts accessibility, fallback strategies, and WWDC sessions
    charts.md - Swift Charts marks, axes, selection, styling, composition, and Chart3D
    focus-patterns.md
    image-optimization.md - AsyncImage usage, downsampling, caching
    latest-apis.md
    layout-best-practices.md - Layout patterns and GeometryReader alternatives
    liquid-glass.md - iOS 26+ glass effects and fallback patterns
    list-patterns.md - ForEach identity and list performance
    macos-scenes.md - Scene lifecycle, multi-window setups, and menu bar scenes on macOS
    macos-views.md - macOS-specific SwiftUI views and platform differences from iOS
    macos-window-styling.md - Window chrome, toolbar, and title bar styling in SwiftUI
    performance-patterns.md - Hot-path optimizations and update control
    scroll-patterns.md - ScrollViewReader and programmatic scrolling
    sheet-navigation-patterns.md - Sheets and type-safe navigation
    state-management.md - Property wrapper selection and data flow
    view-structure.md - View extraction and composition patterns

Maintenance

The repository includes a maintenance skill for keeping API guidance current:

.agents/skills/update-swiftui-apis/
  SKILL.md               - Workflow for scanning Apple docs and updating latest-apis.md
  references/
    scan-manifest.md     - Categorized API areas, doc paths, and search queries to scan

Use this skill after new iOS or Xcode releases to refresh the deprecated API reference. It requires the Sosumi MCP to be available. See AGENTS.md or CONTRIBUTING.md for details.

Note: only swiftui-expert-skill is intended to be published in the Cursor plugin. The maintenance skill remains a repository workflow utility.

Contributing

Contributions are welcome! This repository follows the Agent Skills open format, which has specific structural requirements.

Please read CONTRIBUTING.md for:

  • How to contribute improvements to SKILL.md and the reference files
  • Format requirements and quality standards
  • Pull request process

Acknowledgments

Several SwiftUI guidelines in this skill were inspired by or derived from the following works:

  • Skills by Thomas Ricouard — a collection of SwiftUI-focused Codex skills covering UI patterns, performance auditing, and Liquid Glass.
  • SwiftLee SwiftUI articles and Swift articles by Antoine van der Lee — practical SwiftUI best practices covering state management, accessibility, view composition, performance debugging, image optimization, and more.
  • Swift Charts Examples by Jordi Bruin — a comprehensive collection of Swift Charts examples covering line, bar, area, range, heat map, and point charts with accessibility and customization patterns. Used with permission.

About the authors

Created by Antoine van der Lee and Omar Elsayed. With years of experience in Swift & SwiftUI, this skill distills practical knowledge into actionable guidance for AI assistants. Antoine published tens of articles on SwiftUI on his blog called SwiftLee.

Resources

License

This skill is open-source and available under the MIT License. See LICENSE for details.