mirror of
https://github.com/status-im/react-native.git
synced 2025-01-28 10:14:49 +00:00
5db5ee9f55
Summary:
There were several fixes to how calls to propType checkers. This is to
account for the new deprecation warning - React.PropTypes will not be
part of production builds in the future.
Note: There is still a warning about an invalid argument to `React.PropTypes.oneOf` (React is running that validation sooner now). Specifically [both of these](b1e49832ef/Libraries/Components/Touchable/TouchableWithoutFeedback.js (L44-L45)
) because `View.AccessibilityTraits` is actually undefined in tests (didn't look into why you conditionally set that).
**Test plan (required)**
`npm test` & fixed all warnings due to proptype secret
Closes https://github.com/facebook/react-native/pull/8758
Reviewed By: zpao
Differential Revision: D3564288
Pulled By: bestander
fbshipit-source-id: 1ff1f90907f41855e364048aa730ccd239c522b4
81 lines
2.6 KiB
JavaScript
81 lines
2.6 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 createStrictShapeTypeChecker
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
var ReactPropTypeLocationNames = require('react/lib/ReactPropTypeLocationNames');
|
|
var ReactPropTypesSecret = require('react/lib/ReactPropTypesSecret');
|
|
|
|
var invariant = require('fbjs/lib/invariant');
|
|
var merge = require('merge');
|
|
|
|
function createStrictShapeTypeChecker(
|
|
shapeTypes: {[key: string]: ReactPropsCheckType}
|
|
): ReactPropsChainableTypeChecker {
|
|
function checkType(isRequired, props, propName, componentName, location?) {
|
|
if (!props[propName]) {
|
|
if (isRequired) {
|
|
invariant(
|
|
false,
|
|
`Required object \`${propName}\` was not specified in ` +
|
|
`\`${componentName}\`.`
|
|
);
|
|
}
|
|
return;
|
|
}
|
|
var propValue = props[propName];
|
|
var propType = typeof propValue;
|
|
var locationName =
|
|
location && ReactPropTypeLocationNames[location] || '(unknown)';
|
|
if (propType !== 'object') {
|
|
invariant(
|
|
false,
|
|
`Invalid ${locationName} \`${propName}\` of type \`${propType}\` ` +
|
|
`supplied to \`${componentName}\`, expected \`object\`.`
|
|
);
|
|
}
|
|
// We need to check all keys in case some are required but missing from
|
|
// props.
|
|
var allKeys = merge(props[propName], shapeTypes);
|
|
for (var key in allKeys) {
|
|
var checker = shapeTypes[key];
|
|
if (!checker) {
|
|
invariant(
|
|
false,
|
|
`Invalid props.${propName} key \`${key}\` supplied to \`${componentName}\`.` +
|
|
`\nBad object: ` + JSON.stringify(props[propName], null, ' ') +
|
|
`\nValid keys: ` + JSON.stringify(Object.keys(shapeTypes), null, ' ')
|
|
);
|
|
}
|
|
var error = checker(propValue, key, componentName, location, null, ReactPropTypesSecret);
|
|
if (error) {
|
|
invariant(
|
|
false,
|
|
error.message +
|
|
`\nBad object: ` + JSON.stringify(props[propName], null, ' ')
|
|
);
|
|
}
|
|
}
|
|
}
|
|
function chainedCheckType(
|
|
props: {[key: string]: any},
|
|
propName: string,
|
|
componentName: string,
|
|
location?: string
|
|
): ?Error {
|
|
return checkType(false, props, propName, componentName, location);
|
|
}
|
|
chainedCheckType.isRequired = checkType.bind(null, true);
|
|
return chainedCheckType;
|
|
}
|
|
|
|
module.exports = createStrictShapeTypeChecker;
|