install
source · Clone the upstream repo
git clone https://github.com/sickn33/antigravity-awesome-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/sickn33/antigravity-awesome-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/antigravity-awesome-skills/skills/expo-ui-swift-ui" ~/.claude/skills/sickn33-antigravity-awesome-skills-expo-ui-swift-ui-95d9eb && rm -rf "$T"
manifest:
plugins/antigravity-awesome-skills/skills/expo-ui-swift-ui/SKILL.mdsource content
name: expo-ui-swift-ui
description: @expo/ui/swift-ui
package lets you use SwiftUI Views and modifiers in your app.
@expo/ui/swift-uiThe instructions in this skill apply to SDK 55 only. For other SDK versions, refer to the Expo UI SwiftUI docs for that version for the most accurate information.
When to Use
- You need to build iOS-native UI in Expo using
.@expo/ui/swift-ui - The task involves selecting SwiftUI views or modifiers, wrapping trees in
, or embedding React Native components withHost
.RNHostView - You are targeting Expo SDK 55 behavior for SwiftUI integration and extension guidance.
Installation
npx expo install @expo/ui
A native rebuild is required after installation (
npx expo run:ios).
Instructions
- Expo UI's API mirrors SwiftUI's API. Use SwiftUI knowledge to decide which components or modifiers to use.
- Components are imported from
, modifiers from@expo/ui/swift-ui
.@expo/ui/swift-ui/modifiers - When about to use a component, fetch its docs to confirm the API - https://docs.expo.dev/versions/v55.0.0/sdk/ui/swift-ui/{component-name}/index.md
- When unsure about a modifier's API, refer to the docs - https://docs.expo.dev/versions/v55.0.0/sdk/ui/swift-ui/modifiers/index.md
- Every SwiftUI tree must be wrapped in
.Host
is specifically for embedding RN components inside a SwiftUI tree. Example:RNHostView
import { Host, VStack, RNHostView } from "@expo-ui/swift-ui"; import { Pressable } from "react-native"; <Host matchContents> <VStack> <RNHostView matchContents> // Here, `Pressable` is an RN component so it is wrapped in `RNHostView`. <Pressable /> </RNHostView> </VStack> </Host>;
- If a required modifier or View is missing in Expo UI, it can be extended via a local Expo module. See: https://docs.expo.dev/guides/expo-ui-swift-ui/extending/index.md. Confirm with the user before extending.
Limitations
- Use this skill only when the task clearly matches the scope described above.
- Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
- Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.