mirror of
https://github.com/status-im/react-native.git
synced 2025-01-24 00:09:08 +00:00
d5e9e55fa3
Summary: This PR removes the need for having the `providesModule` tags in all the modules in the repository. It configures Flow, Jest and Metro to get the module names from the filenames (`Libraries/Animated/src/nodes/AnimatedInterpolation.js` => `AnimatedInterpolation`) * Checked the Flow configuration by running flow on the project root (no errors): ``` yarn flow ``` * Checked the Jest configuration by running the tests with a clean cache: ``` yarn jest --clearCache && yarn test ``` * Checked the Metro configuration by starting the server with a clean cache and requesting some bundles: ``` yarn run start --reset-cache curl 'localhost:8081/IntegrationTests/AccessibilityManagerTest.bundle?platform=android' curl 'localhost:8081/Libraries/Alert/Alert.bundle?platform=ios' ``` [INTERNAL] [FEATURE] [All] - Removed providesModule from all modules and configured tools. Closes https://github.com/facebook/react-native/pull/18995 Reviewed By: mjesun Differential Revision: D7729509 Pulled By: rubennorte fbshipit-source-id: 892f760a05ce1fddb088ff0cd2e97e521fb8e825
86 lines
2.4 KiB
JavaScript
86 lines
2.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* 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';
|
|
|
|
var ReactNativeStyleAttributes = require('ReactNativeStyleAttributes');
|
|
|
|
export type ComponentInterface =
|
|
| React$ComponentType<any>
|
|
| {
|
|
name?: string,
|
|
displayName?: string,
|
|
propTypes?: Object,
|
|
};
|
|
|
|
function verifyPropTypes(
|
|
componentInterface: ComponentInterface,
|
|
viewConfig: Object,
|
|
nativePropsToIgnore?: ?Object,
|
|
) {
|
|
if (!viewConfig) {
|
|
return; // This happens for UnimplementedView.
|
|
}
|
|
var componentName =
|
|
componentInterface.displayName || componentInterface.name || 'unknown';
|
|
|
|
// ReactNative `View.propTypes` have been deprecated in favor of
|
|
// `ViewPropTypes`. In their place a temporary getter has been added with a
|
|
// deprecated warning message. Avoid triggering that warning here by using
|
|
// temporary workaround, __propTypesSecretDontUseThesePlease.
|
|
// TODO (bvaughn) Revert this particular change any time after April 1
|
|
var propTypes =
|
|
(componentInterface: any).__propTypesSecretDontUseThesePlease ||
|
|
componentInterface.propTypes;
|
|
|
|
if (!propTypes) {
|
|
return;
|
|
}
|
|
|
|
var nativeProps = viewConfig.NativeProps;
|
|
for (var prop in nativeProps) {
|
|
if (
|
|
!propTypes[prop] &&
|
|
!ReactNativeStyleAttributes[prop] &&
|
|
(!nativePropsToIgnore || !nativePropsToIgnore[prop])
|
|
) {
|
|
var message;
|
|
if (propTypes.hasOwnProperty(prop)) {
|
|
message =
|
|
'`' +
|
|
componentName +
|
|
'` has incorrectly defined propType for native prop `' +
|
|
viewConfig.uiViewClassName +
|
|
'.' +
|
|
prop +
|
|
'` of native type `' +
|
|
nativeProps[prop];
|
|
} else {
|
|
message =
|
|
'`' +
|
|
componentName +
|
|
'` has no propType for native prop `' +
|
|
viewConfig.uiViewClassName +
|
|
'.' +
|
|
prop +
|
|
'` of native type `' +
|
|
nativeProps[prop] +
|
|
'`';
|
|
}
|
|
message +=
|
|
"\nIf you haven't changed this prop yourself, this usually means that " +
|
|
'your versions of the native code and JavaScript code are out of sync. Updating both ' +
|
|
'should make this error go away.';
|
|
throw new Error(message);
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = verifyPropTypes;
|