create-watchos-version
npx skills add https://github.com/ghostscientist/skills --skill create-watchos-version
Agent 安装分布
Skill 文档
Create watchOS Version
Analyzes existing Apple platform projects and creates detailed, phased implementation plans for watchOS apps that are elegant, top-tier experiencesânot naive skins of the parent app.
Workflow
- Project Discovery – Analyze project structure, patterns, architecture
- Feature Mapping – Identify watchOS-suitable features and priorities
- API Compatibility – Search web for current watchOS API availability
- Architecture Planning – Design watchOS-specific architecture
- Plan Generation – Create phased plan with warnings and alternatives
- User Review – Present plan for approval before implementation
Phase 1: Project Discovery
Scan project root for:
âââ App Architecture (SwiftUI, UIKit, AppKit, hybrid)
âââ Data Layer (Core Data, SwiftData, Realm, custom)
âââ Networking (URLSession, Alamofire, custom)
âââ State Management (ObservableObject, TCA, Redux-like)
âââ Navigation (NavigationStack, Coordinator)
âââ Shared Frameworks (SPM packages, shared targets)
âââ Assets (colors, images, SF Symbols)
âââ Existing Watch Target (if any)
âââ Minimum iOS Version (affects watchOS targeting)
Key files: *.xcodeproj, Package.swift, Info.plist, App entry points, ViewModels, Models.
Phase 2: Feature Mapping
Glanceable (High Priority): Status displays, counters, progress, recent items, quick stats
Quick Actions (High Priority): Single-tap toggles, shortcuts, haptic confirmations
Complications/Widgets (Critical): Map data to WidgetKit familiesâaccessoryCircular, accessoryRectangular, accessoryInline, accessoryCorner. Consider Smart Stack relevance.
Background: HealthKit integration, background refresh, Watch Connectivity sync
Defer/Exclude: Complex data entry, long-form content, sustained screen time features
Phase 3: API Compatibility
CRITICAL: Always search web for current watchOS docs before finalizing. APIs change frequently.
Search: [FrameworkName] watchOS availability site:developer.apple.com
Quick Reference
Available: SwiftUI, SwiftData (10+), WidgetKit (9+), HealthKit, WorkoutKit, CoreLocation (limited), WatchConnectivity, CloudKit, CoreMotion, AVFoundation (audio), CoreBluetooth, Combine, Swift Concurrency
Unavailable/Limited: UIKit, WebKit, MapKit (limited), CoreImage (limited), ARKit, RealityKit, StoreKit (limited), Background URLSession (limited)
See references/api-compatibility.md for detailed compatibility matrix.
Phase 4: Architecture
Version Targeting
iOS 16+ â watchOS 9+ (WidgetKit complications)
iOS 17+ â watchOS 10+ (SwiftData, Smart Stack)
iOS 18+ â watchOS 11+ (Live Activities on Watch)
Structure
Shared/
âââ Models/ # Pure Swift, shared via target membership
âââ Services/ # Platform-agnostic logic
âââ Utilities/
WatchApp/
âââ App.swift
âââ Views/
âââ ViewModels/
âââ Complications/
âââ WatchConnectivity/
Design Principles
- Glanceability – Visible within 2 seconds
- Minimal Interaction – 1-3 taps max
- Context Awareness – Time, location, activity
- Battery Conscious – Efficient refresh, TimelineSchedule
- Haptic Feedback – Confirm actions appropriately
SwiftUI Gotchas
- Avoid nested TabViews (memory leaks)
- Use TimelineSchedule for efficient metric updates
- Check
isLuminanceReducedto reduce work when dimmed - Don’t use data-driven high-frequency UI refreshes
Phase 5: Plan Generation
Use template in references/plan-template.md to generate:
- Executive Summary
- â ï¸ API Compatibility Warnings table
- Phased implementation tasks
- Testing checklist
Phase 6: User Review
Present plan and ask for approval before implementing:
“I’ve analyzed your project and created a watchOS plan. Before proceeding:
- API Warnings: [N] APIs unavailableâalternatives documented.
- Recommended Features: [list] prioritized for Watch.
- Scope: [N] phases.
Proceed with implementation, or adjust the plan?”
Do not implement until user approves.
Best Practices Reference
Watch Connectivity
guard WCSession.default.activationState == .activated else { return }
// sendMessage: immediate, requires reachability
// transferUserInfo: queued, guaranteed
// transferCurrentComplicationUserInfo: complication priority
Complications
// Use appropriate reload policy
Timeline(entries: entries, policy: .after(nextUpdateDate))
// Use .never for static complications
Battery Efficiency
- Timeline-based over active refresh
- Check
isLuminanceReduced - Batch Watch Connectivity transfers
- Significant location change vs continuous updates