expo-dev-launcher
Version:
Pre-release version of the Expo development launcher package for testing.
214 lines (205 loc) • 5.34 kB
text/typescript
import { validate, type JSONSchema } from '@expo/schema-utils';
/**
* Type representing base dev launcher configuration.
*/
export type PluginConfigType = PluginConfigOptionsByPlatform & PluginConfigOptions;
/**
* Type representing available configuration for each platform.
*/
export type PluginConfigOptionsByPlatform = {
/**
* Type representing available configuration for Android dev launcher.
* @platform android
*/
android?: PluginConfigOptions;
/**
* Type representing available configuration for iOS dev launcher.
* @platform ios
*/
ios?: PluginConfigOptions;
};
/**
* Type representing available configuration for dev launcher.
*/
export type PluginConfigOptions = {
/**
* Determines whether to launch the most recently opened project or navigate to the launcher screen.
*
* - `'most-recent'` - Attempt to launch directly into a previously opened project and if unable to connect,
* fall back to the launcher screen.
*
* - `'launcher'` - Opens the launcher screen.
*
* @default 'most-recent'
*/
launchMode?: 'most-recent' | 'launcher';
/**
* Instead of navigating to launcher screen launch directly into this URL.
* If `launchMode` is set to `most-recent` then launcher will use the defaultLaunchURL if launching previously opened project fails.
*/
defaultLaunchURL?: string;
/**
* @deprecated use the `launchMode` property instead
*/
launchModeExperimental?: 'most-recent' | 'launcher';
/**
* Whether to show the tools button by default.
*
* @default true
*/
toolsButton?: boolean;
/**
* Whether to enable loading an embedded JS bundle from the dev launcher.
* When enabled and a bundle file is present in the app, a "Load embedded bundle"
* option appears in the dev launcher UI.
*
* @default false
*/
embeddedBundle?: boolean;
/**
* Skip the dev menu onboarding popup on first launch. Useful for E2E tests and CI
* builds where the onboarding overlay would block automated input.
*
* @default false
*/
skipOnboarding?: boolean;
/**
* Automatically open the dev menu when the app launches. Set to `false` to suppress
* the auto-launch in development builds where the dev menu would interfere (E2E tests,
* automated UI runs).
*
* @default true
*/
showMenuAtLaunch?: boolean;
};
const schema: JSONSchema<PluginConfigType> = {
title: 'expo-dev-launcher',
type: 'object',
properties: {
launchMode: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
defaultLaunchURL: {
type: ['string'],
nullable: true,
},
launchModeExperimental: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
toolsButton: {
type: 'boolean',
nullable: true,
},
embeddedBundle: {
type: 'boolean',
nullable: true,
},
skipOnboarding: {
type: 'boolean',
nullable: true,
},
showMenuAtLaunch: {
type: 'boolean',
nullable: true,
},
android: {
type: 'object',
properties: {
launchMode: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
launchModeExperimental: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
toolsButton: {
type: 'boolean',
nullable: true,
},
embeddedBundle: {
type: 'boolean',
nullable: true,
},
defaultLaunchURL: {
type: 'string',
nullable: true,
},
skipOnboarding: {
type: 'boolean',
nullable: true,
},
showMenuAtLaunch: {
type: 'boolean',
nullable: true,
},
},
nullable: true,
},
ios: {
type: 'object',
properties: {
launchMode: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
launchModeExperimental: {
type: 'string',
enum: ['most-recent', 'launcher'],
nullable: true,
},
toolsButton: {
type: 'boolean',
nullable: true,
},
embeddedBundle: {
type: 'boolean',
nullable: true,
},
defaultLaunchURL: {
type: 'string',
nullable: true,
},
skipOnboarding: {
type: 'boolean',
nullable: true,
},
showMenuAtLaunch: {
type: 'boolean',
nullable: true,
},
},
nullable: true,
},
},
};
/**
* @ignore
*/
export function validateConfig<T>(config: T): PluginConfigType {
validate(schema, config);
if (
config.launchModeExperimental ||
config.ios?.launchModeExperimental ||
config.android?.launchModeExperimental
) {
warnOnce(
'The `launchModeExperimental` property of expo-dev-launcher config plugin is deprecated and will be removed in a future SDK release. Use `launchMode` instead.'
);
}
return config;
}
const warnMap: Record<string, boolean> = {};
function warnOnce(message: string) {
if (!warnMap[message]) {
warnMap[message] = true;
console.warn(message);
}
}