Lightweight extension over bootstrap's modals to improve of the control, animations and visualization of modal windows.
Via npm
$ npm install @jlgarridol/modalizer.js@1.0.2
or add it directly using a CDN:
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@jlgarridol/modalizer.js@1.0.2/dist/css/modalizer.min.css">
<script src="https://cdn.jsdelivr.net/npm/@jlgarridol/modalizer.js@1.0.2/dist/js/modalizer.min.js"></script>
Add class modalinit and modal's identifier in data-modal
attribute to a <a>
, <buttom>
or any else HTML element.
Add class modalizer
to the modal div.
Example:
<a class="modalinit" data-modal="standard" href="#"> Click to open</a>
<div class="modal modalizer fade" id="standard" tabindex= "-1" role="dialog">
...
</div>
Add class closemodal
to a <a>
, <buttom>
or any else HTML element inside a modal div
.
Example:
<div class="modal modalizer fade" id="standard" tabindex= "-1" role="dialog">
...
<button class="closemodal">Close</button>
...
</div>
Use a Animate.css animation for open and close animation.
Add data-animate-in
and data-animate-out
with Animate.css animation (without animate__
), remove class fade
and add class animate__animated
in modal.
Example:
<div class="modal modalizer animate__animated" id="standard" tabindex= "-1" role="dialog" data-animate-in="zoomIn" data-animate-out="zoomOut">
...
</div>
A optionable modal is which have multiple submodals inside and the user can navigate it between their.
To transform a modal into an optionable you need to add the modal-optionable
class and assign a data-stack
to it.
It is necessary create a instance of MOD_Stack
with the same name in the javascript.
Example:
<div class="modal modalizer fade modal-optionable" data-stack="defaultStack" id="standard" tabindex= "-1" role="dialog">
...
</div>
<script>
const defaultStack = new MOD_Stack();
</script>
The submodals are the modal-dialog
with role="document"
and have full compatibility with classes for modal-dialog
in Bootstrap like centered
or scrollable
.
Any submodal, except the first, must have the style attribute display: none
.
To navigate between submodals exists two classes: nextaction
and beforeaction
to apply to a <a>
, <button>
or any alse HTML element.
Also, it is necessary to add the attribute data-next
with the identifier of the next submodal. If this attribute is not there then the modal will end.
In the case of going backwards, the highest submodal in the stack will go. If the stack is empty then the modal will be closed.
In addition, to enable the animation between submodals it is necessary add class animate__animated
in the submodal.
Example:
<div class="modal modalizer fade modal-optionable" data-stack="defaultStack" id="standard" tabindex= "-1" role="dialog">
<div class="modal-dialog animate__animated" id="first_submodal" role="document">
...
<button class="beforeaction">Before</button>
<button class="nextaction" data-next="last_submodal">Next</button>
...
</div>
<div class="modal-dialog animate__animated" id="last_submodal" role="document" style="display: none">
...
<button class="beforeaction">Before</button>
<button class="nextaction">Next</button>
...
</div>
</div>
For a fullscreen modal it is necessary add the class fullscreen
to the div
s with classes modal-dialog
, modal-content
, modal-header
and modal-footer
. To make it only for mobile screens you have to add -sm
to fullscreen
.
For blur background on modal open it is neccesary include all HTML elements (except modals) inside a div
with the identifier and class MOD_supreme-container