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-jetpack-compose" ~/.claude/skills/sickn33-antigravity-awesome-skills-expo-ui-jetpack-compose-70b2ab && rm -rf "$T"
manifest:
plugins/antigravity-awesome-skills/skills/expo-ui-jetpack-compose/SKILL.mdsource content
name: expo-ui-jetpack-compose
description: @expo/ui/jetpack-compose
package lets you use Jetpack Compose Views and modifiers in your app.
@expo/ui/jetpack-composeThe instructions in this skill apply to SDK 55 only. For other SDK versions, refer to the Expo UI Jetpack Compose docs for that version for the most accurate information.
When to Use
- You need to build Android-native UI in Expo using
.@expo/ui/jetpack-compose - The task involves choosing Compose views or modifiers, embedding them in
, or translating Jetpack Compose patterns into Expo UI code.Host - You are working specifically against Expo SDK 55 behavior for Jetpack Compose integration.
Installation
npx expo install @expo/ui
A native rebuild is required after installation (
npx expo run:android).
Instructions
- Expo UI's API mirrors Jetpack Compose's API. Use Jetpack Compose and Material Design 3 knowledge to decide which components or modifiers to use.
- Components are imported from
, modifiers from@expo/ui/jetpack-compose
.@expo/ui/jetpack-compose/modifiers - When about to use a component, fetch its docs to confirm the API - https://docs.expo.dev/versions/v55.0.0/sdk/ui/jetpack-compose/{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/jetpack-compose/modifiers/index.md
- Every Jetpack Compose tree must be wrapped in
. UseHost
for intrinsic sizing, or<Host matchContents>
when you need explicit size (e.g. as a parent of<Host style={{ flex: 1 }}>
). Example:LazyColumn
import { Host, Column, Button, Text } from "@expo/ui/jetpack-compose"; import { fillMaxWidth, paddingAll } from "@expo/ui/jetpack-compose/modifiers"; <Host matchContents> <Column verticalArrangement={{ spacedBy: 8 }} modifiers={[fillMaxWidth(), paddingAll(16)]}> <Text style={{ typography: "titleLarge" }}>Hello</Text> <Button onPress={() => alert("Pressed!")}>Press me</Button> </Column> </Host>;
Key Components
- LazyColumn — Use instead of react-native
/ScrollView
for scrollable lists. Wrap inFlatList
.<Host style={{ flex: 1 }}> - Icon — Use
with Android XML vector drawables from Material Symbols.<Icon source={require('./icon.xml')} size={24} />
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.