/vue-standalone-modal

A package to allow autoinject components to use as modals instead of use them into template.

Primary LanguageVueMIT LicenseMIT

Vue Standalone Modal

A package to allow autoinject components to use as modals instead of use them into template.

Installation

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);

Example

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

Author

Feel free to open a PR or create an issue to contribute to this package.