You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ant-design-vue/components/_util/ContainerRender.jsx

93 lines
2.2 KiB

import Vue from 'vue';
import PropTypes from './vue-types';
7 years ago
export default {
props: {
autoMount: PropTypes.bool.def(true),
autoDestroy: PropTypes.bool.def(true),
visible: PropTypes.bool,
forceRender: PropTypes.bool.def(false),
parent: PropTypes.any,
getComponent: PropTypes.func.isRequired,
getContainer: PropTypes.func.isRequired,
children: PropTypes.func.isRequired,
},
mounted() {
7 years ago
if (this.autoMount) {
this.renderComponent();
7 years ago
}
},
updated() {
7 years ago
if (this.autoMount) {
this.renderComponent();
7 years ago
}
},
beforeDestroy() {
7 years ago
if (this.autoDestroy) {
this.removeContainer();
7 years ago
}
},
methods: {
removeContainer() {
7 years ago
if (this.container) {
this._component && this._component.$destroy();
this.container.parentNode.removeChild(this.container);
this.container = null;
7 years ago
}
},
renderComponent(props = {}, ready) {
const { visible, forceRender, getContainer, parent } = this;
const self = this;
7 years ago
if (visible || parent.$refs._component || forceRender) {
let el = this.componentEl;
7 years ago
if (!this.container) {
this.container = getContainer();
el = document.createElement('div');
this.componentEl = el;
this.container.appendChild(el);
7 years ago
}
if (!this._component) {
this._component = new Vue({
data: {
comProps: props,
},
7 years ago
parent: self.parent,
el: el,
mounted() {
7 years ago
this.$nextTick(() => {
7 years ago
if (ready) {
ready.call(self);
7 years ago
}
});
7 years ago
},
updated() {
this.$nextTick(() => {
if (ready) {
ready.call(self);
}
});
},
render() {
return self.getComponent(this.comProps);
7 years ago
},
});
} else {
this._component.comProps = props;
7 years ago
}
}
},
},
render() {
7 years ago
return this.children({
renderComponent: this.renderComponent,
removeContainer: this.removeContainer,
});
7 years ago
},
};