UNPKG

modals

Version:

reimplementation of toast/alert/confirm/prompt

68 lines (54 loc) 1.43 kB
'use strict' require('../styles/modal.css') // there will be only one instance of modal. var MODAL_WRAP_CLASS = 'amfe-modal-wrap' var MODAL_NODE_CLASS = 'amfe-modal-node' function Modal() { this.wrap = document.querySelector(MODAL_WRAP_CLASS) this.node = document.querySelector(MODAL_NODE_CLASS) if (!this.wrap) { this.createWrap() } if (!this.node) { this.createNode() } this.clearNode() this.createNodeContent() this.bindEvents() } Modal.prototype = { show: function () { this.wrap.style.display = 'block' this.node.classList.remove('hide') }, destroy: function () { document.body.removeChild(this.wrap) document.body.removeChild(this.node) this.wrap = null this.node = null }, createWrap: function () { this.wrap = document.createElement('div') this.wrap.className = MODAL_WRAP_CLASS document.body.appendChild(this.wrap) }, createNode: function () { this.node = document.createElement('div') this.node.classList.add(MODAL_NODE_CLASS, 'hide') document.body.appendChild(this.node) }, clearNode: function () { this.node.innerHTML = '' }, createNodeContent: function () { // do nothing. // child classes can override this method. }, bindEvents: function () { this.wrap.addEventListener('click', function (e) { e.preventDefault() e.stopPropagation() }) } } module.exports = Modal