Browse Source

Merge pull request #728 from Johann-S/modal_event

Create `modalOpen` and `modalClose` events.
pull/750/head
XhmikosR 10 years ago
parent
commit
c591a26792
  1. 19
      js/modals.js

19
js/modals.js

@ -9,6 +9,14 @@
!(function () { !(function () {
'use strict'; 'use strict';
var eventModalOpen = new CustomEvent('modalOpen', {
bubbles: true,
cancelable: true
});
var eventModalClose = new CustomEvent('modalClose', {
bubbles: true,
cancelable: true
});
var findModals = function (target) { var findModals = function (target) {
var i; var i;
var modals = document.querySelectorAll('a'); var modals = document.querySelectorAll('a');
@ -31,11 +39,14 @@
window.addEventListener('touchend', function (event) { window.addEventListener('touchend', function (event) {
var modal = getModal(event); var modal = getModal(event);
if (modal) { if (modal && modal.classList.contains('modal')) {
if (modal && modal.classList.contains('modal')) { var eventToDispatch = eventModalOpen;
modal.classList.toggle('active'); if (modal.classList.contains('active')) {
eventToDispatch = eventModalClose;
} }
event.preventDefault(); // prevents rewriting url (apps can still use hash values in url) modal.dispatchEvent(eventToDispatch);
modal.classList.toggle('active');
} }
event.preventDefault(); // prevents rewriting url (apps can still use hash values in url)
}); });
}()); }());

Loading…
Cancel
Save