expo-module

por expo

Guia para criar e escrever módulos e visualizações nativas do Expo usando a API de Módulos do Expo (Swift, Kotlin, TypeScript). Abrange o DSL de definição de módulos, nativo…

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.

Mais skills de expo

android-e2e-testing
expo
Teste recursos do Expo Router em emuladores Android usando ADB. Use após implementar funcionalidades nativas do Android ou ao verificar o comportamento da interface no Android.
official
deep-code-review
expo
Revisão de código aprofundada e focada em design - entende o contexto da base de código antes de avaliar alterações de PR, publica feedback estruturado no GitHub
official
building-native-ui
expo
Guia completo para construir aplicativos nativos com Expo, abordando roteamento, estilização, componentes e convenções de plataforma. Abrange fundamentos do Expo Router, abas nativas, navegação em pilha, modais e formulários em folha com convenções detalhadas de estrutura de rotas. Inclui regras de estilização alinhadas às Diretrizes de Interface Humana da Apple: layouts flexbox, tratamento de área segura, animações, sombras via CSS boxShadow e padrões de design responsivo. Documenta preferências de bibliotecas (expo-image para SF Symbols, expo-audio, expo-video,...
official
eas-update-insights
expo
Verifique a integridade das EAS Updates publicadas: taxas de falha, contagens de instalação/inicialização, usuários únicos, tamanho do payload e a divisão entre usuários incorporados e OTA por…
official
expo-api-routes
expo
Rotas de API no Expo Router para lógica do lado do servidor, segredos e integrações de terceiros no EAS Hosting. Crie rotas com sufixo +api.ts no diretório app; exporte funções nomeadas para métodos HTTP (GET, POST, PUT, DELETE). Manipule parâmetros de consulta, cabeçalhos, corpos JSON e segmentos de rota dinâmicos; adicione cabeçalhos CORS para clientes web. Acesse segredos do lado do servidor via process.env; defina variáveis localmente em .env ou via eas env:create para produção. Implante no EAS Hosting (Cloudflare Workers) com eas...
official
expo-cicd-workflows
expo
Escreve e valida arquivos YAML de fluxo de trabalho CI/CD do EAS para projetos Expo. Obtém o esquema JSON mais recente da API do Expo para garantir que tipos de job, parâmetros, gatilhos e configurações de runner estejam atualizados. Suporta expressões dinâmicas usando a sintaxe ${{ }} com contextos para eventos do GitHub, entradas de fluxo de trabalho, saídas de job e resultados de etapas. Inclui script de validação integrado que verifica a estrutura do fluxo de trabalho em relação ao esquema e relata erros antes da implantação. Fornece documentação de referência para sintaxe,...
official
expo-deployment
expo
Implantação automatizada de aplicativos Expo para a App Store da iOS, Play Store da Android, hospedagem web e ambientes de pré-visualização. Suporta builds de produção e submissões para iOS (App Store e TestFlight) e Android (Google Play Store) com comandos únicos. Inclui EAS Hosting para implantações web com URLs de pré-visualização automáticas de PR e suporte a domínios de produção. Fornece automação de fluxo de trabalho CI/CD via EAS Workflows para builds e submissões acionadas por pushes de código. Gerenciamento automático de versão com remoto...
official
expo-dev-client
expo
Crie clientes de desenvolvimento Expo personalizados para testar código nativo em dispositivos físicos via EAS Build ou localmente. Necessário apenas ao usar módulos nativos personalizados, alvos Apple (widgets, app clips) ou código nativo de terceiros que não está no Expo Go; experimente o Expo Go primeiro com npx expo start. Suporta compilações em nuvem com envio automático ao TestFlight ou compilações locais na sua máquina, gerando arquivos .ipa (iOS) ou .apk/.aab (Android). Requer configuração eas.json com um perfil de desenvolvimento que define...
official