mirror of
https://github.com/status-im/react-native.git
synced 2025-02-24 15:18:10 +00:00
Summary: Moved the JS wrapper function to github. To access a TurboModule from JS: ``` export interface Spec extends TurboModule { +func1: () => number, } const module = TurboModuleRegistry.get<Spec>('SampleTurboModule'); ``` This assumes: * the binding on the native side has been installed properly, i.e. `global.__turboModuleProxy` needs to be installed properly. * the module `SampleTurboModule` is registered properly in native. More instructions will be provided later. Reviewed By: yungsters Differential Revision: D13584561 fbshipit-source-id: 50d29d88787f8d9caa7a3ee0d54d378db866515c
36 lines
833 B
JavaScript
36 lines
833 B
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @flow
|
|
* @format
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
import type {TurboModule} from 'RCTExport';
|
|
import invariant from 'invariant';
|
|
import {NativeModules} from 'react-native';
|
|
|
|
// TODO
|
|
function get<T: TurboModule>(name: string): ?T {
|
|
// Backward compatibility layer during migration.
|
|
if (NativeModules[name] != null) {
|
|
return ((NativeModules[name]: any): T);
|
|
}
|
|
|
|
const module: ?T = global.__turboModuleProxy(name);
|
|
return module;
|
|
}
|
|
|
|
function getEnforcing<T: TurboModule>(name: string): T {
|
|
const module = get(name);
|
|
invariant(module != null, `${name} is not available in this app.`);
|
|
return module;
|
|
}
|
|
|
|
export {get};
|
|
export {getEnforcing};
|