expo-module

por expo

Guía para crear y escribir módulos y vistas nativos de Expo utilizando la API de Módulos de Expo (Swift, Kotlin, TypeScript). Cubre el DSL de definición de módulos, nativos…

npx skills add https://github.com/expo/skills --skill expo-module

Writing Expo Modules

Complete reference for building native modules and views using the Expo Modules API. Covers Swift (iOS), Kotlin (Android), and TypeScript.

When to Use

  • Creating a new Expo native module or native view
  • Adding native functionality (camera, sensors, system APIs) to an Expo app
  • Wrapping platform SDKs for React Native consumption
  • Building config plugins that modify native project files
  • Adding Android, Apple, or web support to an existing Expo module
  • Editing expo-module.config.json, config plugins, or lifecycle hooks

References

Consult these resources as needed:

references/
  create-expo-module.md      Scaffolding and add-platform-support workflow, defaults, and quirks
  native-module.md           Module definition DSL: Name, Function, AsyncFunction, Property, Constant, Events, type system, shared objects
  native-view.md             Native view components: View, Prop, EventDispatcher, view lifecycle, ref-based functions
  lifecycle.md               Lifecycle hooks: module, iOS app/AppDelegate, Android activity/application listeners
  config-plugin.md           Config plugins: modifying Info.plist, AndroidManifest.xml, reading values in native code
  module-config.md           expo-module.config.json fields, file placement, and autolinking behavior

Quick Start

Prefer create-expo-module over manually creating native module files and directories. In practice, the best path is usually to create the scaffold first and then build on top of it. The scaffold sets up the expected layout, expo-module.config.json, podspec or Gradle files, TypeScript bindings, and the standalone example app flow.

If an existing Expo module only needs another platform, use create-expo-module add-platform-support instead of manually copying native directories.

See references/create-expo-module.md before scaffolding or extending a module. It covers:

  • local vs standalone modules
  • --platform, --features, --barrel, --package-manager, and non-interactive mode
  • expo.autolinking.nativeModulesDir
  • add-platform-support behavior and quirks

Recommended Workflow

  1. Choose the scaffold type first:
    • Local module for one app
    • Standalone module for reuse, monorepos, or publishing
  2. Determine native expo-module features that you will need.
    • Based on the user's instructions determine which feature scaffolding will be useful.
    • Available features: Constant, Function, AsyncFunction, Event, View, ViewEvent, SharedObject
  3. Scaffold deliberately:
    • pass an explicit slug or path
    • choose --platform intentionally instead of relying on defaults
    • use --features to choose code samples which you will modify in the next step to match the real implementation.
  4. Replace generated example code with the real implementation.
  5. If you add a new platform later, prefer add-platform-support over manual file copying.

Practical Scaffolding Rules

  • Feature examples are opt-in. A newly scaffolded module may be minimal if no features were selected.
  • ViewEvent implies View.
  • Local modules do not generate an index.ts barrel by default. Use --barrel only if you want one.
  • In non-interactive local scaffolding, pass the positional slug or path explicitly. --name changes the native class name, not the folder name.
  • Local modules live in expo.autolinking.nativeModulesDir when configured, otherwise in modules/.
  • Standalone modules have their own package metadata, scripts, and usually an example app. Local modules use the host app's tooling instead.

Core File Shapes

The Swift and Kotlin DSL share the same structure. Swift is usually the clearest primary example; consult the references for feature-specific details.

Module Structure Reference

The Swift and Kotlin DSL share the same structure. Both platforms are shown here for reference — in other reference files, Swift is shown as the primary language unless the Kotlin pattern meaningfully differs.

Swift (iOS):

import ExpoModulesCore

public class MyModule: Module {
  public func definition() -> ModuleDefinition {
    Name("MyModule")

    Function("hello") { (name: String) -> String in
      return "Hello \(name)!"
    }
  }
}

Kotlin (Android):

package expo.modules.mymodule

import expo.modules.kotlin.modules.Module
import expo.modules.kotlin.modules.ModuleDefinition

class MyModule : Module() {
  override fun definition() = ModuleDefinition {
    Name("MyModule")

    Function("hello") { name: String ->
      "Hello $name!"
    }
  }
}

TypeScript:

import { requireNativeModule } from "expo";

const MyModule = requireNativeModule("MyModule");

export function hello(name: string): string {
  return MyModule.hello(name);
}

expo-module.config.json

{
  "platforms": ["android", "apple"],
  "apple": {
    "modules": ["MyModule"]
  },
  "android": {
    "modules": ["expo.modules.mymodule.MyModule"]
  }
}

Note: iOS uses just the class name; Android uses the fully-qualified class name (package + class). See references/module-config.md for all fields.

Más skills de expo

android-e2e-testing
expo
Prueba las funciones de Expo Router en emuladores de Android usando ADB. Úsalo después de implementar funciones nativas de Android o al verificar el comportamiento de la interfaz de usuario en Android.
official
deep-code-review
expo
Revisión de código profunda centrada en el diseño: comprende el contexto del código base antes de evaluar los cambios del PR, publica comentarios estructurados en GitHub.
official
building-native-ui
expo
Guía completa para crear aplicaciones nativas con Expo, que abarca enrutamiento, estilos, componentes y convenciones de plataforma. Cubre los fundamentos de Expo Router, pestañas nativas, navegación en pila, modales y hojas de formulario con convenciones detalladas de estructura de rutas. Incluye reglas de estilo alineadas con las Guías de Interfaz Humana de Apple: diseños flexbox, manejo de áreas seguras, animaciones, sombras mediante CSS boxShadow y patrones de diseño responsivo. Documenta preferencias de librerías (expo-image para SF Symbols, expo-audio, expo-video,...).
official
eas-update-insights
expo
Verificar el estado de las actualizaciones de EAS publicadas: tasas de fallos, recuentos de instalación/inicio, usuarios únicos, tamaño del payload y la división entre usuarios integrados y OTA por…
official
expo-api-routes
expo
Rutas API en Expo Router para lógica del lado del servidor, secretos e integraciones de terceros en EAS Hosting. Crea rutas con el sufijo +api.ts en el directorio app; exporta funciones nombradas para métodos HTTP (GET, POST, PUT, DELETE). Maneja parámetros de consulta, encabezados, cuerpos JSON y segmentos de ruta dinámicos; agrega encabezados CORS para clientes web. Accede a secretos del lado del servidor mediante process.env; configura variables localmente en .env o mediante eas env:create para producción. Despliega en EAS Hosting (Cloudflare Workers) con eas...
official
expo-cicd-workflows
expo
Escribe y valida archivos YAML de flujos de trabajo CI/CD de EAS para proyectos Expo. Obtiene el esquema JSON más reciente desde la API de Expo para garantizar que los tipos de trabajo, parámetros, disparadores y configuraciones del ejecutor estén actualizados. Admite expresiones dinámicas usando la sintaxis ${{ }} con contextos para eventos de GitHub, entradas de flujo de trabajo, salidas de trabajo y resultados de pasos. Incluye un script de validación integrado que verifica la estructura del flujo de trabajo contra el esquema e informa errores antes del despliegue. Proporciona documentación de referencia para la sintaxis,...
official
expo-deployment
expo
Implementación automatizada de aplicaciones Expo en la App Store de iOS, Play Store de Android, alojamiento web y entornos de vista previa. Admite compilaciones de producción y envíos para iOS (App Store y TestFlight) y Android (Google Play Store) con comandos individuales. Incluye EAS Hosting para implementaciones web con URLs de vista previa automáticas para PR y soporte de dominio de producción. Proporciona automatización de flujos de trabajo CI/CD mediante EAS Workflows para compilaciones y envíos activados por cambios de código. Gestión automática de versiones con control remoto...
official
expo-dev-client
expo
Crea clientes de desarrollo Expo personalizados para probar código nativo en dispositivos físicos mediante EAS Build o de forma local. Solo es necesario al usar módulos nativos personalizados, destinos de Apple (widgets, app clips) o código nativo de terceros que no esté en Expo Go; prueba primero Expo Go con npx expo start. Admite compilaciones en la nube con envío automático a TestFlight o compilaciones locales en tu máquina, generando archivos .ipa (iOS) o .apk/.aab (Android). Requiere configuración de eas.json con un perfil de desarrollo que establezca...
official