website/versioned_docs/version-0.78/appregistry.md
AppRegistry is the JS entry point to running all React Native apps. App root components should register themselves with AppRegistry.registerComponent, then the native system can load the bundle for the app and then actually run the app when it's ready by invoking AppRegistry.runApplication.
import {Text, AppRegistry} from 'react-native';
const App = () => (
<View>
<Text>App1</Text>
</View>
);
AppRegistry.registerComponent('Appname', () => App);
To "stop" an application when a view should be destroyed, call AppRegistry.unmountApplicationComponentAtRootTag with the tag that was passed into runApplication. These should always be used as a pair.
AppRegistry should be required early in the require sequence to make sure the JS execution environment is setup before other modules are required.
getAppKeys()static getAppKeys(): string[];
Returns an array of strings.
getRegistry()static getRegistry(): {sections: string[]; runnables: Runnable[]};
Returns a Registry object.
getRunnable()static getRunnable(appKey: string): : Runnable | undefined;
Returns a Runnable object.
Parameters:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
getSectionKeys()static getSectionKeys(): string[];
Returns an array of strings.
getSections()static getSections(): Record<string, Runnable>;
Returns a Runnables object.
registerCancellableHeadlessTask()static registerCancellableHeadlessTask(
taskKey: string,
taskProvider: TaskProvider,
taskCancelProvider: TaskCancelProvider,
);
Register a headless task which can be cancelled. A headless task is a bit of code that runs without a UI.
Parameters:
| Name | Type | Description |
|---|---|---|
| taskKey |
registerComponent()static registerComponent(
appKey: string,
getComponentFunc: ComponentProvider,
section?: boolean,
): string;
Parameters:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
| componentProvider <div className="label basic required">Required</div> | ComponentProvider |
| section | boolean |
registerConfig()static registerConfig(config: AppConfig[]);
Parameters:
| Name | Type |
|---|---|
| config <div className="label basic required">Required</div> | AppConfig[] |
registerHeadlessTask()static registerHeadlessTask(
taskKey: string,
taskProvider: TaskProvider,
);
Register a headless task. A headless task is a bit of code that runs without a UI.
This is a way to run tasks in JavaScript while your app is in the background. It can be used, for example, to sync fresh data, handle push notifications, or play music.
Parameters:
| Name | Type | Description |
|---|---|---|
| taskKey <div className="label basic required two-lines">Required</div> | string | The native id for this task instance that was used when startHeadlessTask was called. |
| taskProvider <div className="label basic required two-lines">Required</div> | TaskProvider | A promise returning function that takes some data passed from the native side as the only argument. When the promise is resolved or rejected the native side is notified of this event and it may decide to destroy the JS context. |
registerRunnable()static registerRunnable(appKey: string, func: Runnable): string;
Parameters:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
| run <div className="label basic required">Required</div> | function |
registerSection()static registerSection(
appKey: string,
component: ComponentProvider,
);
Parameters:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
| component <div className="label basic required">Required</div> | ComponentProvider |
runApplication()static runApplication(appKey: string, appParameters: any): void;
Loads the JavaScript bundle and runs the app.
Parameters:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
| appParameters <div className="label basic required">Required</div> | any |
setComponentProviderInstrumentationHook()static setComponentProviderInstrumentationHook(
hook: ComponentProviderInstrumentationHook,
);
Parameters:
| Name | Type |
|---|---|
| hook <div className="label basic required">Required</div> | function |
A valid hook function accepts the following as arguments:
| Name | Type |
|---|---|
| component <div className="label basic required">Required</div> | ComponentProvider |
| scopedPerformanceLogger <div className="label basic required">Required</div> | IPerformanceLogger |
The function must also return a React Component.
setWrapperComponentProvider()static setWrapperComponentProvider(
provider: WrapperComponentProvider,
);
Parameters:
| Name | Type |
|---|---|
| provider <div className="label basic required">Required</div> | ComponentProvider |
startHeadlessTask()static startHeadlessTask(
taskId: number,
taskKey: string,
data: any,
);
Only called from native code. Starts a headless task.
Parameters:
| Name | Type | Description |
|---|---|---|
| taskId <div className="label basic required">Required</div> | number | The native id for this task instance to keep track of its execution. |
| taskKey <div className="label basic required">Required</div> | string | The key for the task to start. |
| data <div className="label basic required">Required</div> | any | The data to pass to the task. |
unmountApplicationComponentAtRootTag()static unmountApplicationComponentAtRootTag(rootTag: number);
Stops an application when a view should be destroyed.
Parameters:
| Name | Type |
|---|---|
| rootTag <div className="label basic required">Required</div> | number |
Application configuration for the registerConfig method.
| Type |
|---|
| object |
Properties:
| Name | Type |
|---|---|
| appKey <div className="label basic required">Required</div> | string |
| component | ComponentProvider |
| run | function |
| section | boolean |
Note: Every config is expected to set either
componentorrunfunction.
| Type |
|---|
| object |
Properties:
| Name | Type |
|---|---|
| runnables | array of Runnables |
| sections | array of strings |
| Type |
|---|
| object |
Properties:
| Name | Type |
|---|---|
| component | ComponentProvider |
| run | function |
An object with key of appKey and value of type of Runnable.
| Type |
|---|
| object |
A Task is a function that accepts any data as argument and returns a Promise that resolves to undefined.
| Type |
|---|
| function |
A TaskCanceller is a function that accepts no argument and returns void.
| Type |
|---|
| function |
A valid TaskCancelProvider is a function that returns a TaskCanceller.
| Type |
|---|
| function |
A valid TaskProvider is a function that returns a Task.
| Type |
|---|
| function |