expo-module

par expo

Guide pour créer et rédiger des modules et vues natifs Expo en utilisant l'API Expo Modules (Swift, Kotlin, TypeScript). Couvre le DSL de définition de module, les éléments natifs…

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.

Plus de skills de expo

android-e2e-testing
expo
Testez les fonctionnalités d'Expo Router sur des émulateurs Android à l'aide d'ADB. À utiliser après avoir implémenté des fonctionnalités Android natives ou lors de la vérification du comportement de l'interface utilisateur sur Android.
official
deep-code-review
expo
Revue de code approfondie axée sur la conception - comprend le contexte de la base de code avant d'évaluer les modifications de PR, publie des retours structurés sur GitHub
official
building-native-ui
expo
Guide complet pour créer des applications Expo natives avec routage, styles, composants et conventions de plateforme. Couvre les fondamentaux d'Expo Router, les onglets natifs, la navigation par pile, les modales et les feuilles de formulaire avec des conventions détaillées de structure de routage. Inclut des règles de style alignées sur les Apple Human Interface Guidelines : mises en page flexbox, gestion des zones de sécurité, animations, ombres via CSS boxShadow, et motifs de conception responsive. Documente les préférences de bibliothèques (expo-image pour les symboles SF, expo-audio, expo-video,...).
official
eas-update-insights
expo
Vérifier l’état des mises à jour EAS publiées : taux de crash, nombres d’installations/lancements, utilisateurs uniques, taille des charges utiles, et la répartition entre utilisateurs embarqués et OTA par…
official
expo-api-routes
expo
Routes API dans Expo Router pour la logique serveur, les secrets et les intégrations tierces sur EAS Hosting. Créez des routes avec le suffixe +api.ts dans le répertoire app ; exportez des fonctions nommées pour les méthodes HTTP (GET, POST, PUT, DELETE). Gérez les paramètres de requête, les en-têtes, les corps JSON et les segments de route dynamiques ; ajoutez des en-têtes CORS pour les clients web. Accédez aux secrets côté serveur via process.env ; définissez des variables localement dans .env ou via eas env:create pour la production. Déployez sur EAS Hosting (Cloudflare Workers) avec eas...
official
expo-cicd-workflows
expo
Rédige et valide des fichiers YAML de workflows CI/CD EAS pour des projets Expo. Récupère le dernier schéma JSON depuis l'API d'Expo pour garantir que les types de jobs, paramètres, déclencheurs et configurations d'exécuteurs sont à jour. Prend en charge les expressions dynamiques utilisant la syntaxe ${{ }} avec des contextes pour les événements GitHub, les entrées de workflow, les sorties de jobs et les résultats d'étapes. Inclut un script de validation intégré qui vérifie la structure du workflow par rapport au schéma et signale les erreurs avant le déploiement. Fournit une documentation de référence pour la syntaxe,...
official
expo-deployment
expo
Déploiement automatisé des applications Expo vers l'App Store iOS, le Play Store Android, l'hébergement web et les environnements de prévisualisation. Prend en charge les builds de production et les soumissions pour iOS (App Store et TestFlight) et Android (Google Play Store) avec des commandes uniques. Inclut EAS Hosting pour les déploiements web avec des URL de prévisualisation automatiques pour les PR et la prise en charge des domaines de production. Fournit l'automatisation des workflows CI/CD via EAS Workflows pour les builds et soumissions déclenchés par les push de code. Gestion automatique des versions avec...
official
expo-dev-client
expo
Construisez des clients de développement Expo personnalisés pour tester du code natif sur des appareils physiques via EAS Build ou localement. Nécessaire uniquement lors de l'utilisation de modules natifs personnalisés, de cibles Apple (widgets, app clips) ou de code natif tiers non présent dans Expo Go ; essayez d'abord Expo Go avec npx expo start. Prend en charge les builds cloud avec soumission automatique à TestFlight ou les builds locales sur votre machine, produisant des fichiers .ipa (iOS) ou .apk/.aab (Android). Nécessite une configuration eas.json avec un profil de développement qui définit...
official