From bb9cb9aac93f27afc753e5b6436761c1d247739a Mon Sep 17 00:00:00 2001 From: Armin Jazi Date: Tue, 7 May 2024 14:25:47 +0200 Subject: [PATCH] use custom element --- src/main.ts | 41 +++++++++++++++++++++++++++++++++++++---- 1 file changed, 37 insertions(+), 4 deletions(-) diff --git a/src/main.ts b/src/main.ts index 2425c0f..f9ac1be 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,5 +1,38 @@ -import { createApp } from 'vue' -import './style.css' -import App from './App.vue' +import "@openreply/pattern-library/styles"; +import "@obi-dbs/customer-ui-components/styles"; -createApp(App).mount('#app') +import { App as VueApp, createApp } from "vue"; + +import App from "./App.vue"; +const elementName = "page-module-share-vue"; +class PageModuleShareVue extends HTMLElement { + private app: VueApp | null = null; + private mountPoint: HTMLElement | null = null; + + static get observedAttributes() { + return ["user-type"]; + } + + connectedCallback() { + this.mountPoint = document.querySelector(elementName); + this.setup(); + } + + setup() { + if (this.app) this.app.unmount(); + + if (this.mountPoint) { + this.app = createApp(App); + this.app.mount(this.mountPoint); + console.log("page-module-share-vue: Mounted"); + } else { + console.log("page-module-share-vue: Mount point not found"); + } + } +} + +if (!window.customElements.get(elementName)) { + window.customElements.define(elementName, PageModuleShareVue); +} else { + console.warn(`${elementName}: Custom element already defined`); +}