From 85951cd67ef37cfcd5c400d5803d3f8d7799e40a Mon Sep 17 00:00:00 2001 From: guerler Date: Sat, 1 Jun 2024 09:54:35 +0300 Subject: [PATCH] Add pinia to manually mounted vue components --- client/src/utils/mountVueComponent.js | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/client/src/utils/mountVueComponent.js b/client/src/utils/mountVueComponent.js index 0e0ee949728d..2adedbba5d1f 100644 --- a/client/src/utils/mountVueComponent.js +++ b/client/src/utils/mountVueComponent.js @@ -4,8 +4,12 @@ import BootstrapVue from "bootstrap-vue"; import { iconPlugin, localizationPlugin, vueRxShortcutPlugin } from "components/plugins"; +import { createPinia, PiniaVuePlugin } from "pinia"; import Vue from "vue"; +// Load Pinia +Vue.use(PiniaVuePlugin); + // Bootstrap components Vue.use(BootstrapVue); @@ -18,15 +22,18 @@ Vue.use(vueRxShortcutPlugin); // font-awesome svg icon registration/loading Vue.use(iconPlugin); +// Create Pinia +const pinia = createPinia(); + export const mountVueComponent = (ComponentDefinition) => { const component = Vue.extend(ComponentDefinition); - return (propsData, el) => new component({ propsData, el }); + return (propsData, el) => new component({ propsData, el, pinia }); }; export const replaceChildrenWithComponent = (el, ComponentDefinition, propsData = {}) => { const container = document.createElement("div"); el.replaceChildren(container); const component = Vue.extend(ComponentDefinition); - const mountFn = (propsData, el) => new component({ propsData, el }); + const mountFn = (propsData, el) => new component({ propsData, el, pinia }); return mountFn(propsData, container); };