react-responsive-modal
A simple responsive react modal compatible with React 15 and 16.
- Centered modals.
- Scrolling modals.
- Multiple modals.
- Easily customizable via props.
Demo
You can find a demo here.
Examples
https://react-responsive-modal.leopradel.com/#example
Installation
With npm: npm install react-responsive-modal --save
Or with yarn: yarn add react-responsive-modal
Usage
;;; Component state = open: false ; { this; }; { this; }; { const open = thisstate; return <div> <button onClick=thisonOpenModal>Open modal</button> <Modal open=open onClose=thisonCloseModal little> <h2>Simple centered modal</h2> </Modal> </div> ; } ReactDOM;
Usage with css
By default react-responsive-modal is using react-jss.
If you don't want to add it to your project you can use the css version of this project:
// Import the css file;;
Props
Property | Type | Default | Description |
---|---|---|---|
open* | Boolean | Control if the modal is open or not. | |
onClose* | Function | Fired when the Modal is requested to be closed by a click on the overlay or when user press esc key. | |
children | Node | The content of the modal. | |
closeOnEsc | Boolean | true | Is the modal closable when user press esc key. |
closeOnOverlayClick | Boolean | true | Is the modal closable when user click on overlay. |
little | Boolean | false | Is the dialog centered (when you don't have a lot of content). |
showCloseIcon | Boolean | true | Show the close icon. |
closeIconSize | Number | 28 | Close icon size. |
closeIconSvgPath | Node | A valid svg path to show as icon. | |
classNames | Object | {} | An object containing classNames to style the modal, can have properties 'overlay' (classname for overlay div), 'modal' (classname for modal content div), 'closeIcon' (classname for close icon svg). You can customize the transition with 'transitionEnter', 'transitionEnterActive', 'transitionExit', 'transitionExitActive' |
styles | Object | {} | An object containing the styles objects to style the modal, can have properties 'overlay', 'modal', 'closeIcon'. |
animationDuration | Number | 500 | Animation duration in milliseconds. |
License
MIT © Léo Pradel