@ntohq/buefy-next
Version:
Lightweight UI components for Vue.js (v3) based on Bulma
84 lines (81 loc) • 2.6 kB
JavaScript
import { createApp, h } from 'vue';
import { B as BLoading } from './Loading-Unr63Ud0.js';
import { getComponentFromVNode, copyAppContext } from './helpers.js';
import { a as registerComponent, r as registerComponentProgrammatic } from './plugins-y-E4hvZJ.js';
import './ssr-fOdpiQf0.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, typeof key !== "symbol" ? key + "" : key, value);
return 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 };