react-modal-jkf
v1.0.5
Published
A react modal component
Downloads
4
Readme
react-modal-jkf
Un composant modal React
Installation
npm install --save react-modal-jkf
Utilisation
import React from 'react'
import { Modal, useModal } from 'react-modal-jkf'
import 'react-modal-jkf/dist/index.css'
function Example() {
const { isShowing, toggle, openModal, closeModal } = useModal()
return (
<div>
<button onClick={toggle}>Ouvrir la fenêtre modale</button>
<Modal
isShowing={isShowing}
toggle={toggle}
closeModal={closeModal}
btnChildren={btnChildren}
overlayClass='your-overlay-class'
modalClass='your-modal-class'
bodyClass='your-modal-body-class'
btnClass='your-modal-btn-class'
>
Contenu de la fenêtre modale
</Modal>
</div>
)
}
Modal
Modal
est un composant React qui affiche une fenêtre modale.
Props
overlayClass
: La classe CSS à appliquer à l'overlay de la fenêtre modale. Par défaut, c'est la classe.modalOverlay
dansstyles.module.css
.modalClass
: La classe CSS à appliquer à la fenêtre modale. Par défaut, c'est la classe.modal
dansstyles.module.css
.btnClass
: La classe CSS à appliquer au bouton de l'en-tête. Par défaut, c'est la classe.modalBtn
dansstyles.module.css
.bodyClass
: La classe CSS à appliquer au corps de la fenêtre modale. Par défaut, c'est la classe.modalBody
dansstyles.module.css
.
useModal
useModal
est un hook personnalisé pour gérer l'état d'affichage d'une fenêtre modale.
Retour
isShowing
: Un booléen indiquant si la fenêtre modale est actuellement affichée.toggle
: Une fonction qui permet de basculer l'affichage de la fenêtre modale.openModal
: Une fonction qui permet d'activer l'affichage la fenêtre modale.closeModal
: Une fonction qui permet de désactiver l'affichage de la fenêtre modale.
styles.module.css
Ce fichier contient les styles par défaut pour le composant Modal
. Vous pouvez les surcharger en passant vos propres classes CSS (string) aux props correspondantes du composant Modal
.
Classes par défaut CSS du fichier styles.module.css
:
.modalOverlay {
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
z-index: 10;
box-sizing: border-box;
background-color: rgba(0, 0, 0, 0.75);
}
.modal {
position: relative;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 20;
max-width: 500px;
box-sizing: border-box;
width: 90%;
background: #fff;
padding: 15px 30px;
text-align: left;
scrollbar-width: none;
border-radius: 5px;
max-height: 300px;
}
.modalBody {
overflow-y: auto;
max-height: 300px;
}
.modalBtn {
position: absolute;
top: -12.5px;
right: -12.5px;
display: block;
width: 30px;
height: 30px;
background-image: url('');
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
color: #fff;
background-color: black;
border: 1px solid #000;
border-radius: 50%;
font-size: 16px;
padding: 10px;
}
.modalBtn:hover {
cursor: pointer;
}
.modalBody::-webkit-scrollbar {
display: none;
}
License
MIT © ThomasJSimpson