Skip to content

Tiny and easy javascript library for creating web modals.

License

Notifications You must be signed in to change notification settings

vimtor/modaly.js

Repository files navigation

modaly.js Build Status Coverage Status Bundlephobia Size

Tiny and easy javascript library for creating web modals.

  • Easy to use and customize
  • Lightweight 3.5kB (1.41 kB gzip)
  • Automatic accessibility features
  • Single file with styles injection
  • Highly compatible (browser list)

Install

NPM

npm install modaly.js

CDN

<script src="https://unpkg.com/modaly.js@0.5.0/dist/modaly.min.js"></script>

Alternatively, you can download distribution files directly.

Usage

The basic setup for one modal with default options is the following.

<div id="modal-1">
    <!-- the modal content goes here -->
</div>
new Modaly("#modal-1");

To open the modal add the data-modaly-open attribute to any DOM element.

<button data-modaly-open="#modal-1">
    Open Modal
</button>

To close the modal add the data-modaly-close attribute to any element inside the modal.

<div id="modal-1">
    <!-- the modal content goes here -->

    <img src="close-icon.svg" data-modaly-close />
</div>

You can open/close the modal programmatically.

const modal = new Modaly("#offer-modal");

if (offersAvailable) {
    modal.show();
}
const modal = new Modaly("#timeout-modal");

setTimeout(() => modal.hide(), 5000);

Options

You can further customize the behaviour and looks of your modals.

new Modaly("#modal-custom", {
    // Style
    background: "black",
    opacity: 0.75,
    duration: 250,
    animation: "ease-in",

    // Navigation
    escape: true,
    overlay: true,
    accesible: true,

    // Callbacks
    onShow: (modal, trigger) => {},
    onHide: (modal, trigger) => {}
});

Option Default Description
background "black" Modal overlay color
opacity 0.75 Modal overlay opacity
duration 250 Milliseconds that the transition lasts
animation "ease-in" Timing function for the transition
escape true If the modal can be closed using the ESC key
overlay true If the modal can be closed clicking the overaly
accessible true Setup the modal and triggers to be used by assistive technologies
lazyLoading true Lazy load the resources inside the modal with data-src attribute

If the initial microsecond where the modal flashes is a problem, you can always add the display none attribute.

<div id="modal-1" style="display: none">
    <!-- the modal content goes here -->

    <img src="close-icon.svg" data-modaly-close />
</div>

Callbacks

onShow(modal, trigger)

Fired when the modal it is about to open.

  • modal: the modal DOM element.
  • trigger: which DOM element openned the modal. null if no DOM element triggered it.

onHide(modal, trigger)

Fired when the modal it is about to close.

  • modal: the modal DOM element.
  • trigger: which DOM element closed the modal. null if no DOM element triggered it.

Lazy Loading

Since version 0.5.0 you can lazy load the resources inside the modal when it opens. This comes in handy when dealing with image slideshows libraries that do not support this feature.

To use it, as in many other libraries, simple add the data-src attribute to the resource you want to lazy load.

If you use your own lazy loading, you can disable it by setting to false the lazyLoading options parameter.

Accessibility

If the option accesible is true, accessibility attributes will be added to the modal and the close triggers automatically.

It will change from this.

<div id="modal-1">
    <!-- modal content -->

    <img src="close-icon.svg" data-modaly-close />
</div>

To this. The aria-hidden attribute will toggle accordingly to the modal.

<div id="modal-1" role="dialog" aria-modal="true" aria-hidden="true">
    <!-- modal content -->

    <img src="close-icon.svg" data-modaly-close aria-label="close this dialog"/>
</div>

Disclaimer: I am by no means an expert on accessibility technologies, but if you are one, feel free to reach out for improving the library.

Licensing

Created by Victor Navarro and licensed under MIT license.