| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 | 
							- 'use strict';
 
- exports.__esModule = true;
 
- var _vue = require('vue');
 
- var _vue2 = _interopRequireDefault(_vue);
 
- var _dom = require('element-ui/lib/utils/dom');
 
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 
- var hasModal = false;
 
- var hasInitZIndex = false;
 
- var zIndex = void 0;
 
- var getModal = function getModal() {
 
-   if (_vue2.default.prototype.$isServer) return;
 
-   var modalDom = PopupManager.modalDom;
 
-   if (modalDom) {
 
-     hasModal = true;
 
-   } else {
 
-     hasModal = false;
 
-     modalDom = document.createElement('div');
 
-     PopupManager.modalDom = modalDom;
 
-     modalDom.addEventListener('touchmove', function (event) {
 
-       event.preventDefault();
 
-       event.stopPropagation();
 
-     });
 
-     modalDom.addEventListener('click', function () {
 
-       PopupManager.doOnModalClick && PopupManager.doOnModalClick();
 
-     });
 
-   }
 
-   return modalDom;
 
- };
 
- var instances = {};
 
- var PopupManager = {
 
-   modalFade: true,
 
-   getInstance: function getInstance(id) {
 
-     return instances[id];
 
-   },
 
-   register: function register(id, instance) {
 
-     if (id && instance) {
 
-       instances[id] = instance;
 
-     }
 
-   },
 
-   deregister: function deregister(id) {
 
-     if (id) {
 
-       instances[id] = null;
 
-       delete instances[id];
 
-     }
 
-   },
 
-   nextZIndex: function nextZIndex() {
 
-     return PopupManager.zIndex++;
 
-   },
 
-   modalStack: [],
 
-   doOnModalClick: function doOnModalClick() {
 
-     var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
 
-     if (!topItem) return;
 
-     var instance = PopupManager.getInstance(topItem.id);
 
-     if (instance && instance.closeOnClickModal) {
 
-       instance.close();
 
-     }
 
-   },
 
-   openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
 
-     if (_vue2.default.prototype.$isServer) return;
 
-     if (!id || zIndex === undefined) return;
 
-     this.modalFade = modalFade;
 
-     var modalStack = this.modalStack;
 
-     for (var i = 0, j = modalStack.length; i < j; i++) {
 
-       var item = modalStack[i];
 
-       if (item.id === id) {
 
-         return;
 
-       }
 
-     }
 
-     var modalDom = getModal();
 
-     (0, _dom.addClass)(modalDom, 'v-modal');
 
-     if (this.modalFade && !hasModal) {
 
-       (0, _dom.addClass)(modalDom, 'v-modal-enter');
 
-     }
 
-     if (modalClass) {
 
-       var classArr = modalClass.trim().split(/\s+/);
 
-       classArr.forEach(function (item) {
 
-         return (0, _dom.addClass)(modalDom, item);
 
-       });
 
-     }
 
-     setTimeout(function () {
 
-       (0, _dom.removeClass)(modalDom, 'v-modal-enter');
 
-     }, 200);
 
-     if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
 
-       dom.parentNode.appendChild(modalDom);
 
-     } else {
 
-       document.body.appendChild(modalDom);
 
-     }
 
-     if (zIndex) {
 
-       modalDom.style.zIndex = zIndex;
 
-     }
 
-     modalDom.tabIndex = 0;
 
-     modalDom.style.display = '';
 
-     this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
 
-   },
 
-   closeModal: function closeModal(id) {
 
-     var modalStack = this.modalStack;
 
-     var modalDom = getModal();
 
-     if (modalStack.length > 0) {
 
-       var topItem = modalStack[modalStack.length - 1];
 
-       if (topItem.id === id) {
 
-         if (topItem.modalClass) {
 
-           var classArr = topItem.modalClass.trim().split(/\s+/);
 
-           classArr.forEach(function (item) {
 
-             return (0, _dom.removeClass)(modalDom, item);
 
-           });
 
-         }
 
-         modalStack.pop();
 
-         if (modalStack.length > 0) {
 
-           modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
 
-         }
 
-       } else {
 
-         for (var i = modalStack.length - 1; i >= 0; i--) {
 
-           if (modalStack[i].id === id) {
 
-             modalStack.splice(i, 1);
 
-             break;
 
-           }
 
-         }
 
-       }
 
-     }
 
-     if (modalStack.length === 0) {
 
-       if (this.modalFade) {
 
-         (0, _dom.addClass)(modalDom, 'v-modal-leave');
 
-       }
 
-       setTimeout(function () {
 
-         if (modalStack.length === 0) {
 
-           if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
 
-           modalDom.style.display = 'none';
 
-           PopupManager.modalDom = undefined;
 
-         }
 
-         (0, _dom.removeClass)(modalDom, 'v-modal-leave');
 
-       }, 200);
 
-     }
 
-   }
 
- };
 
- Object.defineProperty(PopupManager, 'zIndex', {
 
-   configurable: true,
 
-   get: function get() {
 
-     if (!hasInitZIndex) {
 
-       zIndex = zIndex || (_vue2.default.prototype.$ELEMENT || {}).zIndex || 2000;
 
-       hasInitZIndex = true;
 
-     }
 
-     return zIndex;
 
-   },
 
-   set: function set(value) {
 
-     zIndex = value;
 
-   }
 
- });
 
- var getTopPopup = function getTopPopup() {
 
-   if (_vue2.default.prototype.$isServer) return;
 
-   if (PopupManager.modalStack.length > 0) {
 
-     var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
 
-     if (!topPopup) return;
 
-     var instance = PopupManager.getInstance(topPopup.id);
 
-     return instance;
 
-   }
 
- };
 
- if (!_vue2.default.prototype.$isServer) {
 
-   // handle `esc` key when the popup is shown
 
-   window.addEventListener('keydown', function (event) {
 
-     if (event.keyCode === 27) {
 
-       var topPopup = getTopPopup();
 
-       if (topPopup && topPopup.closeOnPressEscape) {
 
-         topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
 
-       }
 
-     }
 
-   });
 
- }
 
- exports.default = PopupManager;
 
 
  |