react-required-if

1.0.3 • Public • Published

react-required-if

React PropType to conditionally add .isRequired based on other props

Install

$ npm install --save react-required-if

Usage

import React, {PropTypes} from 'react';
import requiredIf from 'react-required-if';
 
export default class Component extends React.Component {
  static propTypes = {
    disabled: PropTypes.bool,
    onClick: requiredIf(PropTypes.func, props => !props.disabled)
  };
 
  render() {
    return <button onClick={this.props.onClick}>Click Me</button>
  }
}

Result:

import React from 'react';
import {render} from 'react-dom';
import Component from './Component';
 
render(
  <div>
    <Component onClick={() => {})/> // ok
    <Component disabled={true}/> // ok
    <Component/> // NOooooooo
  </div>,
  document.getElementById('root')
);

Dependencies (0)

    Dev Dependencies (0)

      Package Sidebar

      Install

      npm i react-required-if

      Weekly Downloads

      74,304

      Version

      1.0.3

      License

      MIT

      Last publish

      Collaborators

      • thejameskyle