A package to allow autoinject components to use as modals instead of use them into template.
Install vue-standalone-modal with NPM
npm install vue-standalone-modal
And use it into your main file
import Vue from 'vue';
import VueStandAloneModal from 'vue-standalone-modal';
Vue.use(VueStandAloneModal);
When you want to use a component as modal, you usually do something like this:
<template>
<div>
...
<MyModalComponent :show="showModal" />
...
</div>
</template>
<script>
import MyModalComponent from 'MyModalComponent.vue';
export default {
name: 'App',
components: {
MyModalComponent
},
data: () => ({
showModal: false,
}),
};
</script>
But after installing this package, you can replace this code by this:
<script>
import MyModalComponent from 'MyModalComponent.vue';
export default {
name: 'App',
methods: {
showModal() {
this.$showModal({
parent: this, // required
component: MyModalComponent, // required
props: {
prop1: value1
},
events: {
event: (paylod) => {
}
},
innerStyle: {}, // style to use inside the main container div
innerClass: 'my-class', // to pass a class to use inside the main container
showCloseButton: true // by default true. If false, your custom component needs its own style
});
}
}
};
</script>
And avoiding to use your custom modal component into the template. See a full example here
IT'S COMPATIBLE WITH ALL LIBRARIES AND COMPONENTS FOR VueJS v2
Feel free to open a PR or create an issue to contribute to this package.