Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

define propTypes for compatibility #1543

Closed
mo22 opened this issue Feb 25, 2020 · 6 comments
Closed

define propTypes for compatibility #1543

mo22 opened this issue Feb 25, 2020 · 6 comments

Comments

@mo22
Copy link

mo22 commented Feb 25, 2020

Hi,

a lot of react-native libraries use ReactNative.Text.propTypes.style or ReactNative.ViewPropTypes to define their own propTypes.

I know that propTypes are deprecated, but right now this causes a lot of "cannot read property style of undefined" errors with third party libraries.

My workaround is to monkey patch the prop types:

import * as ReactNative from 'react-native-web';
{
  const PropTypes = require('prop-types');
  ReactNative.Text.propTypes = { style: PropTypes.any };
  ReactNative.View.propTypes = { style: PropTypes.any };
  ReactNative.Image.propTypes = { style: PropTypes.any };
  ReactNative.ViewPropTypes = { style: PropTypes.any };
}

I wonder if it makes sense to have the propTypes still defined by react-native-web for better user experience or just wait until propTypes are removed from the third party libraries.

Cheers
Mo

@LinusU
Copy link

LinusU commented Feb 27, 2020

Would you mind sharing which libraries this is? I think that the correct course is to send PRs to them ☺️

@mo22
Copy link
Author

mo22 commented Feb 27, 2020

I recall that react-native-swipeout was affected, and others also.

It's gonna be quite hard to push the removal of propTypes to those libraries as long as the latest react-native still provides them.

@dested
Copy link

dested commented Mar 5, 2020

I am currently dealing with it with https://github.com/archriss/react-native-snap-carousel

@necolas
Copy link
Owner

necolas commented Mar 5, 2020

React Native is going to stop exporting prop types so libraries should stop depending on them. I don't plan to add them back to RNfW

@jer-sen
Copy link

jer-sen commented Jan 10, 2022

React Native is going to stop exporting prop types so libraries should stop depending on them. I don't plan to add them back to RNfW

@necolas where does this information come from? As far as I known it's just about React.PropTypes extracted to prop-types module.

@phpepe
Copy link

phpepe commented Aug 19, 2022

Hey @mo22, I like your workaround. On which file are you adding this ?

import * as ReactNative from 'react-native-web';
{
 const PropTypes = require('prop-types');
 ReactNative.Text.propTypes = { style: PropTypes.any };
 ReactNative.View.propTypes = { style: PropTypes.any };
 ReactNative.Image.propTypes = { style: PropTypes.any };
 ReactNative.ViewPropTypes = { style: PropTypes.any };
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants