mirror of
https://github.com/status-im/react-native.git
synced 2025-01-18 05:23:26 +00:00
90eaeb019b
Reviewed By: avikchaudhuri Differential Revision: D5648819 Ninja: T20988071 fbshipit-source-id: 66e5b6747c79ae66b6eb69d40ede5e982c26174f
85 lines
3.2 KiB
JavaScript
85 lines
3.2 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @providesModule verifyPropTypes
|
|
* @flow
|
|
*/
|
|
'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) {
|
|
throw new Error(
|
|
/* $FlowFixMe(>=0.53.0 site=react_native_fb) This comment suppresses an
|
|
* error when upgrading Flow's support for React. Common errors found
|
|
* when upgrading Flow's React support are documented at
|
|
* https://fburl.com/eq7bs81w */
|
|
'`' + componentName + '` has no propTypes defined`'
|
|
);
|
|
}
|
|
|
|
var nativeProps = viewConfig.NativeProps;
|
|
for (var prop in nativeProps) {
|
|
if (!propTypes[prop] &&
|
|
!ReactNativeStyleAttributes[prop] &&
|
|
(!nativePropsToIgnore || !nativePropsToIgnore[prop])) {
|
|
var message;
|
|
if (propTypes.hasOwnProperty(prop)) {
|
|
/* $FlowFixMe(>=0.53.0 site=react_native_fb) This comment suppresses an
|
|
* error when upgrading Flow's support for React. Common errors found
|
|
* when upgrading Flow's React support are documented at
|
|
* https://fburl.com/eq7bs81w */
|
|
message = '`' + componentName + '` has incorrectly defined propType for native prop `' +
|
|
viewConfig.uiViewClassName + '.' + prop + '` of native type `' + nativeProps[prop];
|
|
} else {
|
|
/* $FlowFixMe(>=0.53.0 site=react_native_fb) This comment suppresses an
|
|
* error when upgrading Flow's support for React. Common errors found
|
|
* when upgrading Flow's React support are documented at
|
|
* https://fburl.com/eq7bs81w */
|
|
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;
|