src/orchestrator/plugins/expo/SKILL.md
Scaffolds Expo/React Native apps, configures EAS Build profiles, manages native modules via CNG, sets up Expo Router navigation, and uses EAS Update for OTA deployments. Use when creating React Native apps with Expo, configuring EAS builds, setting up Expo Router, managing native modules, or deploying OTA updates.
npx skillsauth add monkilabs/opencastle expo-developmentInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Read the matching reference before writing code for any of these topics:
| Topic | Reference |
|-------|-----------|
| EAS Build & deployment | references/eas-build.md |
| Expo Router & navigation | references/routing.md |
| Native modules & CNG | references/native-modules.md |
Project Setup
npx create-expo-app@latest for new projects — always target the latest SDKnpx expo prebuild when native config is neededapp.json / app.config.ts for all project metadata — never modify native projects directly when using CNGExpo Router
app/ — define _layout.tsx in each directory for <Stack>, <Tabs>, or <Drawer>Link for declarative navigation, useRouter() for imperative — configure scheme in app.json for deep linksEAS Build
development / preview / production profiles in eas.json"distribution": "internal" + "channel": "preview" — Development: add "developmentClient": true"channel": "production" + "autoIncrement": trueEAS Update (OTA)
eas update --channel production for JS-only changes — no app store review"runtimeVersion": { "policy": "fingerprint" } — mismatched runtimeVersion forces a new binary buildNative Modules
npx expo install for version resolutionapp.plugin.js) modify native projects at prebuild time — never edit ios/ or android/ directlynpx create-expo-module scaffolds Swift + Kotlin moduleSecurity
app.json or source codeexpo-secure-store for device-side secret storagenpx create-expo-app@latest my-app --template default@sdk-55cd my-app && npx expo start → confirm app loads in simulatoreas init && eas build:configure → creates eas.json with profileseas build --profile preview --platform ioseas build:list → wait for finished status; if errored → eas build:view <id> → fix config → rebuildeas build --profile production --platform alleas submit --platform ios && eas submit --platform androideas update --channel production --message "Fix: button alignment"eas update:list → confirm update published with correct runtimeVersioneas update:republish --group <previous-group-id>If
runtimeVersionmismatch: a new binary build is required — OTA cannot bridge native changes.
Build failed → check logs
├── "Provisioning profile" error → eas credentials → fix iOS signing
├── "SDK version mismatch" → npx expo install --fix → rebuild
├── "Metro bundler" error → check JS syntax → npx expo start to reproduce
├── "Native module" error → npx expo prebuild --clean → verify config plugins
└── "EAS secret" missing → eas secret:create → rebuild
// app/user/[id].tsx
import { useLocalSearchParams } from 'expo-router';
import { View, Text } from 'react-native';
export default function UserScreen() {
const { id } = useLocalSearchParams<{ id: string }>();
return (
<View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
<Text>User {id}</Text>
</View>
);
}
{
"build": {
"development": {
"developmentClient": true,
"distribution": "internal"
},
"preview": {
"distribution": "internal",
"channel": "preview"
},
"production": {
"channel": "production",
"autoIncrement": true
}
}
}
development
Defines 10 sequential validation gates: secret scanning, lint/test/build checks, blast radius analysis, dependency auditing, browser testing, cache management, regression checks, smoke tests. Use when running pre-deploy validation or CI checks, CI/CD pipelines, deployment pipeline validation, pre-merge checks, continuous integration, or pull request validation.
development
Generates test plans, writes unit/integration/E2E test files, identifies coverage gaps, flags common testing anti-patterns. Use when writing tests, creating test suites, planning test strategies, mocking dependencies, measuring code coverage, or test planning.
development
Provides model routing rules, validates delegation prerequisites, supplies cost tracking templates, defines dead-letter queue formats for Team Lead orchestration. Load when assigning tasks to agents, choosing model tiers, starting delegation session, running multi-agent workflow, delegating work, choosing which model to use, or assigning tasks.
testing
Saves, restores session state including task progress, file changes, delegation history. Use when saving progress, resuming interrupted work, picking up where you left off, or checkpointing current work.