mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
72 lines
1.5 KiB
JavaScript
72 lines
1.5 KiB
JavaScript
import Vue from 'vue';
|
|
import Modal from './Modal';
|
|
import context from './context';
|
|
|
|
const defaultConfig = {
|
|
className: '',
|
|
customStyle: {}
|
|
};
|
|
|
|
export default {
|
|
open(vm, config) {
|
|
/* istanbul ignore next */
|
|
if (!context.stack.some(item => item.vm._popupId === vm._popupId)) {
|
|
const el = vm.$el;
|
|
const targetNode = el && el.parentNode && el.parentNode.nodeType !== 11 ? el.parentNode : document.body;
|
|
context.stack.push({ vm, config, targetNode });
|
|
this.update();
|
|
};
|
|
},
|
|
|
|
close(id) {
|
|
const { stack } = context;
|
|
|
|
if (stack.length) {
|
|
if (context.top.vm._popupId === id) {
|
|
stack.pop();
|
|
this.update();
|
|
} else {
|
|
context.stack = stack.filter(item => item.vm._popupId !== id);
|
|
}
|
|
}
|
|
},
|
|
|
|
update() {
|
|
let { modal } = context;
|
|
|
|
if (!modal) {
|
|
modal = new (Vue.extend(Modal))({
|
|
el: document.createElement('div')
|
|
});
|
|
modal.$on('click', this.onClick);
|
|
|
|
context.modal = modal;
|
|
}
|
|
|
|
if (modal.$el.parentNode) {
|
|
modal.visible = false;
|
|
}
|
|
|
|
if (context.top) {
|
|
const { targetNode, config } = context.top;
|
|
|
|
targetNode.appendChild(modal.$el);
|
|
Object.assign(modal, {
|
|
...defaultConfig,
|
|
...config,
|
|
visible: true
|
|
});
|
|
}
|
|
},
|
|
|
|
// close popup when click modal && closeOnClickOverlay is true
|
|
onClick() {
|
|
/* istanbul ignore else */
|
|
if (context.top) {
|
|
const { vm } = context.top;
|
|
vm.$emit('click-overlay');
|
|
vm.closeOnClickOverlay && vm.$emit('input', false);
|
|
}
|
|
}
|
|
};
|