jb-modal-react
v1.1.0
Published
modal react component
Downloads
3
Maintainers
Readme
JBModal
a react component modal that open different in mobile and desktop this component is React.js wrapper for jb-modal web component.
open like bottomsheet in mobile and open in center position in desktop
customizable layout with css variable
support typescript
support custom url to adapt "back to close" on android and "auto open modal on refresh"
installation
npm i jb-modal-react
in your jsx file
import {JBModal} from 'jb-modal-react'
<JBModal></JBModal>
use
you can place your modal content in <JBModal></JBModal>
like:
<JBModal>
<div>
<p>this is the modal content<p>
</div>
</JBModal>
props
- onClose you can pass a function to onClose props so that when a user click outside of the modal, the modal closes.
const [isOpen, setIsOpen] = useState(false);
<JBModal onClose={() => setIsOpen(false)}></JBModal>
- isOpen you can pass true or false to this props,this way the modal will be open based on the isOpen props.
<JBModal isOpen={true}></JBModal>
// the modal is open
- id you can set a specific id for each one of your modals,this way when the modal is open the id of the modal will be in your url.
<JBModal id={MYMODAL}></JBModal>
- onUrlOpen when the react copmonent first renders the default state of isModalOpen is false. when the url contains the id of the modal the function passed to onUrlOpen will update the react state and set the isModalOpen state to true. example:
[isModalOpen, setOpen] = useState(false);
<JBModal onUrlOpen={() => setOpen(true)}></JBModal>
customize modal look
you can customize modal look by following css properties
| css variable name | description |
| ------------- | ------------- |
| --jb-modal-bg-color | modal background color default is black #fff
|
| --jb-modal-border-radius | modal border-radius default 24px
|
| --jb-modal-border-radius-mobile | modal border-radius on mobile default is 24px 24px 0 0
|