A customizable and responsive modal component for React.
Install the package using npm:
npm install responsive-modal-react
import React, { useState } from 'react';
import Modal from 'responsive-modal-react';
const App = () => {
const [modalState, setModalState] = useState(false);
return (
<div>
<button onClick={() => setModalState(true)}>Open Modal</button>
<Modal
isVisible={modalState}
onClose={() => setModalState(false)}
width="50%"
height="50%"
scroll
header={<YourHeaderComponent/>}
wrapperClassName="custom-wrapper"
contentClassName="custom-content"
bodyClassName="custom-body"
>
<div>Modal Content Goes Here</div>
</Modal>
</div>
);
};
export default App;
- Type:
ReactNode
- Description: The content to be rendered inside the modal.
- Type:
boolean
- Description: Controls the visibility of the modal.
- Type:
string
- Default:
undefined
- Description: Specifies the width of the modal. Accepts CSS values like percentages or pixels.
- Type:
string
- Default:
undefined
- Description: Specifies the height of the modal. Accepts CSS values like percentages or pixels.
- Type:
() => void
- Description: Callback function triggered when the modal is closed.
- Type:
boolean
- Default:
false
- Description: Enables or disables scrolling within the modal body.
- Type:
React.ReactElement<{ onClose?: () => void }>
- Default:
undefined
- Description: React element to be used as the modal header. It can have an optional
onClose
prop.
- Type:
string
- Default:
undefined
- Description: Custom class name for the modal wrapper.
- Type:
string
- Default:
undefined
- Description: Custom class name for the modal content.
- Type:
string
- Default:
undefined
- Description: Custom class name for the modal body.