Create Reactive Vue Modals
npm i @simpli/vue-modal
import Vue from 'vue'
import VueModal from '@simpli/vue-modal'
Vue.use(VueModal)
On your Scss:
@import "~@simpli/vue-modal/scss/modal";
<modal name="myModal">
My Modal content
</modal>
On a Vue instance:
this.$modal.open('myModal')
Outside a Vue instance:
import {$modal} from '@simpli/vue-modal'
$modal.open('myModal')
<a @click="message = 'hello'">Hi</a>
<modal v-model="message">{{ message }}</modal>
data() {
return {
message: null
}
}
<modal
name="myModal"
title="Modal Title"
innerClass="aCssClassAppliedToTheModalWhiteFrame"
effect="vueTransitionCssClass"
backgroundEffect="vueTransitionCssClassForTheBackground"
:closable="true"
:closeOutside="true"
@open="myOpenListener"
@close="myCloseListener"
>
{{ message }}
</modal>
// opens the modal with a optional payload
$modal.open('modalName', { anyObject: 'as payload for the open event' })
// closes the modal
$modal.close('modalName')
// toggles the modal state, open-to-closed or closed-to-open
$modal.toggle('modalName', { anyObject: 'as payload for the open event' })
// closes all modals
$modal.closeAll()