mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
c24c8a039c
Summary: By depending on react-native, these files can't be flow strict until index.js is flow strict. By depending on the internals directly they can be flow strict as soon as their dependents are flow strict. Changelog: [Internal] Refactoring some core file imports to depend on internals directly Reviewed By: zackargyle Differential Revision: D18828324 fbshipit-source-id: 2a347c4e234a64edbb3e6f0ef6387ef1ce78badc
64 lines
2.0 KiB
JavaScript
64 lines
2.0 KiB
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.
|
|
*
|
|
* @format
|
|
* @flow
|
|
*/
|
|
|
|
// TODO: move this file to shims/ReactNative (requires React update and sync)
|
|
|
|
'use strict';
|
|
|
|
import requireNativeComponent from '../../Libraries/ReactNative/requireNativeComponent';
|
|
import type {HostComponent} from '../../Libraries/Renderer/shims/ReactNativeTypes';
|
|
import UIManager from '../ReactNative/UIManager';
|
|
|
|
// TODO: import from CodegenSchema once workspaces are enabled
|
|
type Options = $ReadOnly<{|
|
|
interfaceOnly?: boolean,
|
|
paperComponentName?: string,
|
|
paperComponentNameDeprecated?: string,
|
|
excludedPlatform?: 'iOS' | 'android',
|
|
|}>;
|
|
|
|
export type NativeComponentType<T> = HostComponent<T>;
|
|
|
|
function codegenNativeComponent<Props>(
|
|
componentName: string,
|
|
options?: Options,
|
|
): NativeComponentType<Props> {
|
|
let componentNameInUse =
|
|
options && options.paperComponentName
|
|
? options.paperComponentName
|
|
: componentName;
|
|
|
|
if (options != null && options.paperComponentNameDeprecated != null) {
|
|
if (UIManager.getViewManagerConfig(componentName)) {
|
|
componentNameInUse = componentName;
|
|
} else if (
|
|
options.paperComponentNameDeprecated != null &&
|
|
UIManager.getViewManagerConfig(options.paperComponentNameDeprecated)
|
|
) {
|
|
componentNameInUse = options.paperComponentNameDeprecated;
|
|
} else {
|
|
throw new Error(
|
|
`Failed to find native component for either ${componentName} or ${options.paperComponentNameDeprecated ||
|
|
'(unknown)'}`,
|
|
);
|
|
}
|
|
}
|
|
|
|
// If this function is run at runtime then that means the view configs were not
|
|
// generated with the view config babel plugin, so we need to require the native component.
|
|
//
|
|
// This will be useful during migration, but eventually this will error.
|
|
return (requireNativeComponent<Props>(
|
|
componentNameInUse,
|
|
): HostComponent<Props>);
|
|
}
|
|
|
|
export default codegenNativeComponent;
|