UNPKG

buefy

Version:

Lightweight UI components for Vue.js based on Bulma

208 lines (183 loc) 6.33 kB
'use strict'; var __chunk_2 = require('./chunk-59b91990.js'); var __chunk_3 = require('./chunk-e45e0329.js'); var __chunk_6 = require('./chunk-3b066933.js'); // var script = { name: 'BModal', props: { active: Boolean, component: [Object, Function], content: String, programmatic: Boolean, props: Object, events: Object, width: { type: [String, Number], default: 960 }, hasModalCard: Boolean, animation: { type: String, default: 'zoom-out' }, canCancel: { type: [Array, Boolean], default: function _default() { return __chunk_3.config.defaultModalCanCancel; } }, onCancel: { type: Function, default: function _default() {} }, scroll: { type: String, default: function _default() { return __chunk_3.config.defaultModalScroll ? __chunk_3.config.defaultModalScroll : 'clip'; }, validator: function validator(value) { return ['clip', 'keep'].indexOf(value) >= 0; } }, fullScreen: Boolean, customClass: String }, data: function data() { return { isActive: this.active || false, savedScrollTop: null, newWidth: typeof this.width === 'number' ? this.width + 'px' : this.width }; }, computed: { cancelOptions: function cancelOptions() { return typeof this.canCancel === 'boolean' ? this.canCancel ? __chunk_3.config.defaultModalCanCancel : [] : this.canCancel; }, showX: function showX() { return this.cancelOptions.indexOf('x') >= 0; }, customStyle: function customStyle() { if (!this.fullScreen) { return { maxWidth: this.newWidth }; } return null; } }, watch: { active: function active(value) { this.isActive = value; }, isActive: function isActive() { this.handleScroll(); } }, methods: { handleScroll: function handleScroll() { if (typeof window === 'undefined') return; if (this.scroll === 'clip') { if (this.isActive) { document.documentElement.classList.add('is-clipped'); } else { document.documentElement.classList.remove('is-clipped'); } return; } this.savedScrollTop = !this.savedScrollTop ? document.documentElement.scrollTop : this.savedScrollTop; if (this.isActive) { document.body.classList.add('is-noscroll'); } else { document.body.classList.remove('is-noscroll'); } if (this.isActive) { document.body.style.top = "-".concat(this.savedScrollTop, "px"); return; } document.documentElement.scrollTop = this.savedScrollTop; document.body.style.top = null; this.savedScrollTop = null; }, /** * Close the Modal if canCancel and call the onCancel prop (function). */ cancel: function cancel(method) { if (this.cancelOptions.indexOf(method) < 0) return; this.onCancel.apply(null, arguments); this.close(); }, /** * Call the onCancel prop (function). * Emit events, and destroy modal if it's programmatic. */ close: function close() { var _this = this; this.$emit('close'); this.$emit('update:active', false); // Timeout for the animation complete before destroying if (this.programmatic) { this.isActive = false; setTimeout(function () { _this.$destroy(); __chunk_2.removeElement(_this.$el); }, 150); } }, /** * Keypress event that is bound to the document. */ keyPress: function keyPress(event) { // Esc key if (this.isActive && event.keyCode === 27) this.cancel('escape'); } }, created: function created() { if (typeof window !== 'undefined') { document.addEventListener('keyup', this.keyPress); } }, beforeMount: function beforeMount() { // Insert the Modal component in body tag // only if it's programmatic this.programmatic && document.body.appendChild(this.$el); }, mounted: function mounted() { if (this.programmatic) this.isActive = true;else if (this.isActive) this.handleScroll(); }, beforeDestroy: function beforeDestroy() { if (typeof window !== 'undefined') { document.removeEventListener('keyup', this.keyPress); // reset scroll document.documentElement.classList.remove('is-clipped'); var savedScrollTop = !this.savedScrollTop ? document.documentElement.scrollTop : this.savedScrollTop; document.body.classList.remove('is-noscroll'); document.documentElement.scrollTop = savedScrollTop; document.body.style.top = null; } } }; /* script */ const __vue_script__ = script; /* template */ var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('transition',{attrs:{"name":_vm.animation}},[(_vm.isActive)?_c('div',{staticClass:"modal is-active",class:[{'is-full-screen': _vm.fullScreen}, _vm.customClass]},[_c('div',{staticClass:"modal-background",on:{"click":function($event){_vm.cancel('outside');}}}),_vm._v(" "),_c('div',{staticClass:"animation-content",class:{ 'modal-content': !_vm.hasModalCard },style:(_vm.customStyle)},[(_vm.component)?_c(_vm.component,_vm._g(_vm._b({tag:"component",on:{"close":_vm.close}},'component',_vm.props,false),_vm.events)):(_vm.content)?_c('div',{domProps:{"innerHTML":_vm._s(_vm.content)}}):_vm._t("default")],2),_vm._v(" "),(_vm.showX)?_c('button',{staticClass:"modal-close is-large",attrs:{"type":"button"},on:{"click":function($event){_vm.cancel('x');}}}):_vm._e()]):_vm._e()])}; var __vue_staticRenderFns__ = []; /* style */ const __vue_inject_styles__ = undefined; /* scoped */ const __vue_scope_id__ = undefined; /* module identifier */ const __vue_module_identifier__ = undefined; /* functional template */ const __vue_is_functional_template__ = false; /* style inject */ /* style inject SSR */ var Modal = __chunk_6.__vue_normalize__( { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ }, __vue_inject_styles__, __vue_script__, __vue_scope_id__, __vue_is_functional_template__, __vue_module_identifier__, undefined, undefined ); exports.Modal = Modal;