| name | app-intents-expert-skill |
| description | Expert App Intents guidance for building Siri, Shortcuts, Spotlight, Apple Intelligence, and interactive snippet integrations on iOS 26+. Use when implementing AppIntent, AppEntity, AppEnum, EntityQuery, AppShortcutsProvider, SnippetIntent, SiriTipView, IndexedEntity, or when making an app work with Siri, Shortcuts, Spotlight, Apple Intelligence, Visual Intelligence, Action Button, or Apple Pencil. Also use when asked about App Intents architecture, intent-driven development, or migrating from SiriKit. |
| license | MIT |
| metadata | {"author":"rudrankriyam","version":"1.0"} |
App Intents Expert Skill
Expert guidance for the App Intents framework on iOS 26+. This skill covers building intents, entities, queries, App Shortcuts, interactive snippets, and integrating with Siri, Spotlight, Apple Intelligence, and Visual Intelligence.
When to use this skill
Use this skill when the developer is:
- Creating or modifying any
AppIntent, AppEntity, AppEnum, or EntityQuery
- Adding Siri, Shortcuts, Spotlight, or Apple Intelligence support to an app
- Building
AppShortcutsProvider or App Shortcuts
- Implementing interactive snippets with
SnippetIntent
- Indexing entities for Spotlight with
IndexedEntity
- Integrating with Visual Intelligence or image search
- Navigating with
TargetContentProvidingIntent and onAppIntentExecution
- Migrating from SiriKit (
INIntent) to App Intents
- Debugging App Intents build errors or runtime issues
Task-based routing
Based on what the developer needs, read the relevant reference files.
"I want to create my first App Intent"
- Read references/intent-fundamentals.md
- Then references/shortcuts-provider.md for discoverability
"I want my app's content searchable in Siri and Spotlight"
- Read references/entities-and-queries.md
- Then references/spotlight-indexing.md
- Then references/siri-integration.md
"I want to integrate with Apple Intelligence and the new Siri"
- Read references/apple-intelligence.md
- Then references/siri-integration.md
- Then references/intent-fundamentals.md if new to the framework
"I want to build interactive snippets"
- Read references/interactive-snippets.md
- Then references/intent-fundamentals.md if not familiar with intents
"I want to add Shortcuts and Siri phrases to my app"
- Read references/shortcuts-provider.md
- Then references/siri-integration.md
"I want to structure my app around App Intents"
- Read references/intent-driven-architecture.md
- Then references/entities-and-queries.md
- Then references/intent-fundamentals.md
"I want to support Visual Intelligence / image search"
- Read references/apple-intelligence.md — image search section
- Then references/entities-and-queries.md
"I'm migrating from SiriKit"
- Read references/migration-from-sirikit.md
- Then references/intent-fundamentals.md
"I need to test my App Intents"
- Read references/testing-intents.md
"I'm hitting build errors or runtime issues"
- Read references/common-pitfalls.md
Quick-reference checklists
Minimum viable App Intent
Minimum viable App Entity
Minimum viable App Shortcut
Making an entity Spotlight-searchable
Adding interactive snippets (iOS 26+)
Key decision tree
Which protocol should my intent conform to?
Is it a basic action?
→ AppIntent
Does it open your app to show content?
→ OpenIntent + TargetContentProvidingIntent
Does it render an interactive view?
→ SnippetIntent
Should it support undo?
→ UndoableIntent
Does it match an Apple Intelligence domain?
→ Use @AppIntent macro with the appropriate schema
Which entity type should I use?
Is the set of values fixed and known at compile time?
→ AppEnum
Is the set of values dynamic?
→ AppEntity
Do I need Spotlight indexing?
→ AppEntity + IndexedEntity
Do I need image search / Visual Intelligence?
→ AppEntity + Transferable + OpenIntent
Which query type should I use?
Can all entities fit in memory?
→ EnumerableEntityQuery
Do I need text-based search?
→ EntityStringQuery
Do I need filtering by properties?
→ EntityPropertyQuery
Do I only need lookup by ID?
→ EntityQuery (base protocol)
Should a property be @Property, @ComputedProperty, or @DeferredProperty?
Is the value stored on the entity struct?
→ @Property
Can the value be derived from another source (UserDefaults, model)?
→ @ComputedProperty (preferred — lower overhead)
Is the value expensive to compute (network call, heavy I/O)?
→ @DeferredProperty (async getter, only called when system requests it)
Framework architecture notes
- App Intents uses build-time metadata extraction. Your Swift source code is read at compile time to generate an App Intents representation stored inside your app bundle. This is why certain values (titles, display representations) must be compile-time constants.
- The system reads this metadata without running your app. After installation, intents, entities, and shortcuts are available immediately.
- Each target in your app is processed independently. When sharing App Intent types across targets, use
AppIntentsPackage to register each target.
- App Intents can now live in Swift Packages and static libraries (new in iOS 26).
- Register dependencies with
AppDependencyManager.shared.add { } as early as possible in your app's lifecycle (typically in the App.init()).