From 2207d61f34aafe4d2ee6fb4cb15047bad2d67371 Mon Sep 17 00:00:00 2001 From: Mike Date: Thu, 23 Jun 2022 15:16:33 -0400 Subject: [PATCH] OIA-39: Update Plugin Example & Test with Vue-Router (#60) * support vue-router in plugin test app * update sample plugin with pinia/router/ability to run itself * externalze vue-router to dedup --- sample/src/main/resources/ui-ext/style.css | 2 +- .../main/resources/ui-ext/uiextension.es.js | 119 ++++++++++-------- ui-extension-test/package.json | 3 +- ui-extension-test/src/App.vue | 27 +--- ui-extension-test/src/Plugin.vue | 25 ++++ ui-extension-test/src/main.ts | 17 ++- ui-extension-test/src/router/index.ts | 19 +++ ui-extension/package.json | 18 +-- ui-extension/src/App.vue | 8 +- ui-extension/src/components/HelloWorld.vue | 5 +- ui-extension/src/composables/useRouter.ts | 9 ++ ui-extension/src/main.ts | 10 ++ ui-extension/src/router/index.ts | 25 ++++ ui-extension/tsconfig.json | 6 +- ui-extension/vite.config.dev.ts | 6 + ui-extension/vite.config.ts | 18 +-- 16 files changed, 210 insertions(+), 107 deletions(-) create mode 100644 ui-extension-test/src/Plugin.vue create mode 100644 ui-extension-test/src/router/index.ts create mode 100644 ui-extension/src/composables/useRouter.ts create mode 100644 ui-extension/src/router/index.ts create mode 100644 ui-extension/vite.config.dev.ts diff --git a/sample/src/main/resources/ui-ext/style.css b/sample/src/main/resources/ui-ext/style.css index ef16f817..b10923a5 100644 --- a/sample/src/main/resources/ui-ext/style.css +++ b/sample/src/main/resources/ui-ext/style.css @@ -1 +1 @@ -a[data-v-00b50fea]{color:#42b983}code[data-v-00b50fea]{background-color:#eee;padding:2px 4px;border-radius:4px;color:#304455}table[data-v-00b50fea],th[data-v-00b50fea],td[data-v-00b50fea]{border:2px solid black;border-collapse:collapse}th[data-v-00b50fea]{background-color:#228b22}#app[data-v-1408d3e1]{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50;margin-top:60px} +#app[data-v-a62ce854]{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50;margin-top:60px}a[data-v-5ac905a0]{color:#42b983}code[data-v-5ac905a0]{background-color:#eee;padding:2px 4px;border-radius:4px;color:#304455}table[data-v-5ac905a0],th[data-v-5ac905a0],td[data-v-5ac905a0]{border:2px solid black;border-collapse:collapse}th[data-v-5ac905a0]{background-color:#228b22} diff --git a/sample/src/main/resources/ui-ext/uiextension.es.js b/sample/src/main/resources/ui-ext/uiextension.es.js index d85648ff..7fa0ce82 100644 --- a/sample/src/main/resources/ui-ext/uiextension.es.js +++ b/sample/src/main/resources/ui-ext/uiextension.es.js @@ -1,5 +1,5 @@ var _imports_0 = ""; -var HelloWorld_vue_vue_type_style_index_0_scoped_true_lang = ""; +var App_vue_vue_type_style_index_0_scoped_true_lang = /* @__PURE__ */ (() => "#app[data-v-a62ce854]{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50;margin-top:60px}\n")(); var _export_sfc = (sfc, props) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props) { @@ -7,81 +7,100 @@ var _export_sfc = (sfc, props) => { } return target; }; -const _defineComponent$1 = window["Vue"].defineComponent; -const _toDisplayString = window["Vue"].toDisplayString; +const _sfc_main$1 = {}; const _createElementVNode$1 = window["Vue"].createElementVNode; -const _createTextVNode = window["Vue"].createTextVNode; +const _resolveComponent = window["Vue"].resolveComponent; +const _createVNode = window["Vue"].createVNode; const _Fragment$1 = window["Vue"].Fragment; const _openBlock$1 = window["Vue"].openBlock; const _createElementBlock$1 = window["Vue"].createElementBlock; const _pushScopeId$1 = window["Vue"].pushScopeId; const _popScopeId$1 = window["Vue"].popScopeId; -const _withScopeId$1 = (n) => (_pushScopeId$1("data-v-00b50fea"), n = n(), _popScopeId$1(), n); -const _hoisted_1$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ _createElementVNode$1("p", null, [ +const _withScopeId$1 = (n) => (_pushScopeId$1("data-v-a62ce854"), n = n(), _popScopeId$1(), n); +const _hoisted_1$1 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ _createElementVNode$1("img", { + alt: "Vue logo", + src: _imports_0 +}, null, -1)); +function _sfc_render(_ctx, _cache) { + const _component_router_view = _resolveComponent("router-view"); + return _openBlock$1(), _createElementBlock$1(_Fragment$1, null, [ + _hoisted_1$1, + _createVNode(_component_router_view) + ], 64); +} +var App = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render], ["__scopeId", "data-v-a62ce854"]]); +var HelloWorld_vue_vue_type_style_index_0_scoped_true_lang = /* @__PURE__ */ (() => "a[data-v-5ac905a0]{color:#42b983}code[data-v-5ac905a0]{background-color:#eee;padding:2px 4px;border-radius:4px;color:#304455}table[data-v-5ac905a0],th[data-v-5ac905a0],td[data-v-5ac905a0]{border:2px solid black;border-collapse:collapse}th[data-v-5ac905a0]{background-color:#228b22}\n")(); +const _defineComponent = window["Vue"].defineComponent; +const _createElementVNode = window["Vue"].createElementVNode; +const _createTextVNode = window["Vue"].createTextVNode; +const _toDisplayString = window["Vue"].toDisplayString; +const _Fragment = window["Vue"].Fragment; +const _openBlock = window["Vue"].openBlock; +const _createElementBlock = window["Vue"].createElementBlock; +const _pushScopeId = window["Vue"].pushScopeId; +const _popScopeId = window["Vue"].popScopeId; +const _withScopeId = (n) => (_pushScopeId("data-v-5ac905a0"), n = n(), _popScopeId(), n); +const _hoisted_1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ _createElementVNode("h1", null, "This is an example UI Extension component plugin installed at runtime as a Karaf feature", -1)); +const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ _createElementVNode("p", null, [ /* @__PURE__ */ _createTextVNode(" For more information: "), - /* @__PURE__ */ _createElementVNode$1("a", { + /* @__PURE__ */ _createElementVNode("a", { href: "https://github.com/OpenNMS/opennms-integration-api", target: "_blank" }, "OpenNMS Integration API") ], -1)); -const _hoisted_2 = /* @__PURE__ */ _withScopeId$1(() => /* @__PURE__ */ _createElementVNode$1("table", { style: { "width": "60%" } }, [ - /* @__PURE__ */ _createElementVNode$1("tr", null, [ - /* @__PURE__ */ _createElementVNode$1("th", { style: { "width": "20%" } }, "Product"), - /* @__PURE__ */ _createElementVNode$1("th", { style: { "width": "40%" } }, "Description") +const _hoisted_3 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ _createElementVNode("table", { style: { "width": "60%" } }, [ + /* @__PURE__ */ _createElementVNode("tr", null, [ + /* @__PURE__ */ _createElementVNode("th", { style: { "width": "20%" } }, "Product"), + /* @__PURE__ */ _createElementVNode("th", { style: { "width": "40%" } }, "Description") ]), - /* @__PURE__ */ _createElementVNode$1("tr", null, [ - /* @__PURE__ */ _createElementVNode$1("td", null, "Horizon"), - /* @__PURE__ */ _createElementVNode$1("td", null, "Our free community-driven project includes the latest technology and features delivered through a rapid release cycle.") + /* @__PURE__ */ _createElementVNode("tr", null, [ + /* @__PURE__ */ _createElementVNode("td", null, "Horizon"), + /* @__PURE__ */ _createElementVNode("td", null, "Our free community-driven project includes the latest technology and features delivered through a rapid release cycle.") ]), - /* @__PURE__ */ _createElementVNode$1("tr", null, [ - /* @__PURE__ */ _createElementVNode$1("td", null, "Meridian"), - /* @__PURE__ */ _createElementVNode$1("td", null, "Meridian is a subscription-based, optimized and stable version of the OpenNMS platform.") + /* @__PURE__ */ _createElementVNode("tr", null, [ + /* @__PURE__ */ _createElementVNode("td", null, "Meridian"), + /* @__PURE__ */ _createElementVNode("td", null, "Meridian is a subscription-based, optimized and stable version of the OpenNMS platform.") ]) ], -1)); const ref = window["Vue"].ref; -const _sfc_main$1 = /* @__PURE__ */ _defineComponent$1({ - props: { - msg: null - }, +const _sfc_main = /* @__PURE__ */ _defineComponent({ + __name: "HelloWorld", setup(__props) { const count = ref(0); return (_ctx, _cache) => { - return _openBlock$1(), _createElementBlock$1(_Fragment$1, null, [ - _createElementVNode$1("h1", null, _toDisplayString(__props.msg), 1), - _hoisted_1$1, - _createElementVNode$1("button", { + return _openBlock(), _createElementBlock(_Fragment, null, [ + _hoisted_1, + _hoisted_2, + _createElementVNode("button", { type: "button", onClick: _cache[0] || (_cache[0] = ($event) => count.value++) }, "count is: " + _toDisplayString(count.value), 1), - _hoisted_2 + _hoisted_3 ], 64); }; } }); -var HelloWorld = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-00b50fea"]]); -var App_vue_vue_type_style_index_0_scoped_true_lang = ""; -const _defineComponent = window["Vue"].defineComponent; -const _createElementVNode = window["Vue"].createElementVNode; -const _createVNode = window["Vue"].createVNode; -const _Fragment = window["Vue"].Fragment; -const _openBlock = window["Vue"].openBlock; -const _createElementBlock = window["Vue"].createElementBlock; -const _pushScopeId = window["Vue"].pushScopeId; -const _popScopeId = window["Vue"].popScopeId; -const _withScopeId = (n) => (_pushScopeId("data-v-1408d3e1"), n = n(), _popScopeId(), n); -const _hoisted_1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ _createElementVNode("img", { - alt: "Vue logo", - src: _imports_0 -}, null, -1)); -const _sfc_main = /* @__PURE__ */ _defineComponent({ - setup(__props) { - return (_ctx, _cache) => { - return _openBlock(), _createElementBlock(_Fragment, null, [ - _hoisted_1, - _createVNode(HelloWorld, { msg: "This is an example UI Extension component plugin installed at runtime as a Karaf feature" }) - ], 64); - }; +var HelloWorld = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-5ac905a0"]]); +const createRouter = window["VueRouter"].createRouter; +const createWebHistory = window["VueRouter"].createWebHistory; +const routes = [ + { + path: "/", + name: "hello", + component: HelloWorld + } +]; +const VRouter = window.VRouter; +if (VRouter) { + for (const route of routes) { + const { path, name, component } = route; + VRouter.addRoute("Plugin", { path: path.slice(1), name, component }); } +} +createRouter({ + history: createWebHistory(), + routes }); -var App = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-1408d3e1"]]); +window["Vue"].createApp; +window["Pinia"].createPinia; window["uiextension"] = App; diff --git a/ui-extension-test/package.json b/ui-extension-test/package.json index 9f9b3f93..af043e63 100644 --- a/ui-extension-test/package.json +++ b/ui-extension-test/package.json @@ -12,7 +12,8 @@ "pinia": "^2.0.14", "sass": "^1.49.7", "sass-loader": "^12.4.0", - "vue": "^3.2.25" + "vue": "^3.2.25", + "vue-router": "^4.0.16" }, "devDependencies": { "@vitejs/plugin-vue": "^2.0.0", diff --git a/ui-extension-test/src/App.vue b/ui-extension-test/src/App.vue index ca3cb66b..e8d5b4a9 100644 --- a/ui-extension-test/src/App.vue +++ b/ui-extension-test/src/App.vue @@ -1,31 +1,6 @@ diff --git a/ui-extension-test/src/Plugin.vue b/ui-extension-test/src/Plugin.vue new file mode 100644 index 00000000..d4ed9e69 --- /dev/null +++ b/ui-extension-test/src/Plugin.vue @@ -0,0 +1,25 @@ + + + diff --git a/ui-extension-test/src/main.ts b/ui-extension-test/src/main.ts index 86d50966..6cc1d713 100644 --- a/ui-extension-test/src/main.ts +++ b/ui-extension-test/src/main.ts @@ -1,6 +1,21 @@ import { createApp } from 'vue' import App from './App.vue' import { createPinia } from 'pinia' +import * as Vue from 'vue/dist/vue.esm-bundler' +import * as Pinia from 'pinia' +import * as VueRouter from 'vue-router' +import externalComponent from './utils/externalComponent' +import Router from './router' -createApp(App).use(createPinia()).mount('#app') +(window as any)['VRouter'] = Router; +(window as any).Vue = Vue; +(window as any).Pinia = Pinia; +(window as any).VueRouter = VueRouter; + +await externalComponent('http://localhost:5002/uiextension.es.js') + +createApp(App) + .use(createPinia()) + .use(Router) + .mount('#app') diff --git a/ui-extension-test/src/router/index.ts b/ui-extension-test/src/router/index.ts new file mode 100644 index 00000000..4082d579 --- /dev/null +++ b/ui-extension-test/src/router/index.ts @@ -0,0 +1,19 @@ +import { createRouter, createWebHistory } from 'vue-router' +import PluginVue from '../Plugin.vue' + +const router = createRouter({ + history: createWebHistory(), + routes: [ + { + path: '/', + name: 'Plugin', + component: PluginVue, + }, + { + path: '/:pathMatch(.*)*', // catch other paths and redirect + redirect: '/' + } + ] +}) + +export default router diff --git a/ui-extension/package.json b/ui-extension/package.json index 2accd06f..e272e6c8 100644 --- a/ui-extension/package.json +++ b/ui-extension/package.json @@ -1,9 +1,9 @@ { "name": "ui-extension", "version": "0.0.0", - "files" : [ - "dist" - ], + "files": [ + "dist" + ], "main": "./dist/uiextension.umd.js", "module": "./dist/uiextension.es.js", "exports": { @@ -12,20 +12,22 @@ "require": "./dist/uiextension.umd.js" } }, - "scripts": { - "dev": "vite", + "dev": "vite --config vite.config.dev.ts", "build": "vue-tsc --noEmit && vite build", "preview": "vite preview --port 5002" }, "dependencies": { - "vue": "^3.2.25", - "vite-plugin-externals": "^0.3.4" + "pinia": "^2.0.14", + "vite-plugin-externals": "^0.5.0", + "vue": "^3.2.37", + "vue-router": "^4.0.16" }, "devDependencies": { + "@types/node": "^18.0.0", "@vitejs/plugin-vue": "^2.2.0", "typescript": "^4.5.4", "vite": "^2.8.0", - "vue-tsc": "^0.29.8" + "vue-tsc": "^0.38.1" } } diff --git a/ui-extension/src/App.vue b/ui-extension/src/App.vue index 4b762436..093687d9 100644 --- a/ui-extension/src/App.vue +++ b/ui-extension/src/App.vue @@ -1,12 +1,8 @@ - +