Skip to content
This repository has been archived by the owner on Oct 21, 2022. It is now read-only.

Latest commit

 

History

History
36 lines (24 loc) · 1.4 KB

no-unused-prop-types.md

File metadata and controls

36 lines (24 loc) · 1.4 KB

Extension of a react's no-unused-prop-types rule filtering out false positive used in redux context. (react-redux/no-unused-prop-types)

react/no-unused-prop-types

Rule details

This rule fixes some of the false positive reported by the react rule

In below example react/no-unused-prop-types would report myProp PropType is defined but prop is never used while react-redux/no-unused-prop-types would correctly detect the usage of this prop within mapStateToProps.

 export const mapStateToProps = (state, ownProps) => ({
   myData: getMyData(state, ownProps.myProp),
 });

 export class MyComponent extends Component {
   render() {
     return <div>{this.props.myData}</div>;
   }
 }

 MyComponent.propTypes = {
   myProp: PropTypes.string.isRequired
 };

 export default connect(mapStateToProps)(MyComponent);

Implementation details and Limitations

The rule actually runs react/no-unused-prop-types rule and then filters out the reports of props that are used within redux's mapStateToProps or mapDispatchToProps. The rule only works within a context of a single file. So it would only work properly if compoent and container (react connect fucntion) are defined within the same file.

Configuration

You'd want to disable react/no-unused-prop-types if you using this rule.