/** * 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 StyleSheetValidation * @flow */ 'use strict'; var ImageStylePropTypes = require('ImageStylePropTypes'); var TextStylePropTypes = require('TextStylePropTypes'); var ViewStylePropTypes = require('ViewStylePropTypes'); var invariant = require('fbjs/lib/invariant'); // Hardcoded because this is a legit case but we don't want to load it from // a private API. We might likely want to unify style sheet creation with how it // is done in the DOM so this might move into React. I know what I'm doing so // plz don't fire me. const ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED'; class StyleSheetValidation { /* $FlowFixMe(>=0.59.0 site=react_native_fb) This comment suppresses an error * caught by Flow 0.59 which was not caught before. Most likely, this error * is because an exported function parameter is missing an annotation. * Without an annotation, these parameters are uncovered by Flow. */ static validateStyleProp(prop, style, caller) { if (!__DEV__) { return; } if (allStylePropTypes[prop] === undefined) { var message1 = '"' + prop + '" is not a valid style property.'; var message2 = '\nValid style props: ' + JSON.stringify(Object.keys(allStylePropTypes).sort(), null, ' '); /* $FlowFixMe(>=0.56.0 site=react_native_oss) This comment suppresses an * error found when Flow v0.56 was deployed. To see the error delete this * comment and run Flow. */ /* $FlowFixMe(>=0.56.0 site=react_native_fb,react_native_oss) This * comment suppresses an error found when Flow v0.56 was deployed. To see * the error delete this comment and run Flow. */ styleError(message1, style, caller, message2); } var error = allStylePropTypes[prop]( style, prop, caller, 'prop', null, ReactPropTypesSecret, ); if (error) { /* $FlowFixMe(>=0.56.0 site=react_native_oss) This comment suppresses an * error found when Flow v0.56 was deployed. To see the error delete this * comment and run Flow. */ /* $FlowFixMe(>=0.56.0 site=react_native_fb,react_native_oss) This * comment suppresses an error found when Flow v0.56 was deployed. To see * the error delete this comment and run Flow. */ styleError(error.message, style, caller); } } /* $FlowFixMe(>=0.59.0 site=react_native_fb) This comment suppresses an error * caught by Flow 0.59 which was not caught before. Most likely, this error * is because an exported function parameter is missing an annotation. * Without an annotation, these parameters are uncovered by Flow. */ static validateStyle(name, styles) { if (!__DEV__) { return; } for (var prop in styles[name]) { StyleSheetValidation.validateStyleProp(prop, styles[name], 'StyleSheet ' + name); } } static addValidStylePropTypes(stylePropTypes) { for (var key in stylePropTypes) { allStylePropTypes[key] = stylePropTypes[key]; } } } var styleError = function(message1, style, caller?, message2?) { invariant( false, message1 + '\n' + (caller || '<>') + ': ' + JSON.stringify(style, null, ' ') + (message2 || '') ); }; var allStylePropTypes = {}; StyleSheetValidation.addValidStylePropTypes(ImageStylePropTypes); StyleSheetValidation.addValidStylePropTypes(TextStylePropTypes); StyleSheetValidation.addValidStylePropTypes(ViewStylePropTypes); module.exports = StyleSheetValidation;