buefy
Version:
Lightweight UI components for Vue.js (v3) based on Bulma
82 lines (79 loc) • 2.59 kB
JavaScript
import { createApp, h } from 'vue';
import { B as BLoading } from './Loading-tuQoo6TU.js';
import { getComponentFromVNode, copyAppContext } from './helpers.js';
import { a as registerComponent, r as registerComponentProgrammatic } from './plugins-B172kuKE.js';
import './ssr-C7yEpGLm.js';
import './_plugin-vue_export-helper-OJRSZE6i.js';
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
var __publicField = (obj, key, value) => __defNormalProp(obj, key + "" , value);
class LoadingProgrammatic {
constructor(app) {
__publicField(this, "app");
this.app = app;
}
open(params) {
const propsData = params;
const container = document.createElement("div");
const vueInstance = createApp({
data() {
return {
loadingVNode: null
};
},
methods: {
close() {
const loading = getComponentFromVNode(this.loadingVNode);
if (loading) {
loading.close();
}
}
},
render() {
this.loadingVNode = h(
BLoading,
__spreadProps(__spreadValues({}, propsData), {
programmatic: true,
onClose(...args) {
if (propsData.onClose) {
propsData.onClose(...args);
}
setTimeout(() => {
vueInstance.unmount();
}, 150);
}
})
);
return this.loadingVNode;
}
});
if (this.app) {
copyAppContext(this.app, vueInstance);
}
return vueInstance.mount(container);
}
}
const Plugin = {
install(Vue) {
registerComponent(Vue, BLoading);
registerComponentProgrammatic(Vue, "loading", new LoadingProgrammatic(Vue));
}
};
export { BLoading, LoadingProgrammatic, Plugin as default };