From d935e5089d9611e6a2ccdcc8de747a45e5241024 Mon Sep 17 00:00:00 2001
From: Christoph Reiter <reiter.christoph@gmail.com>
Date: Wed, 22 Apr 2020 15:30:00 +0200
Subject: [PATCH] Port to scoped elements

---
 .../package.json                              |   4 +-
 .../rollup.config.js                          |  12 +-
 .../src/demo.js                               |   1 -
 .../src/index.js                              |   3 +
 .../knowledge-base-web-page-element-view.js   | 184 ++++++++++++++++++
 ...owledge-base-web-page-element-view-demo.js |  18 +-
 ...pu-knowledge-base-web-page-element-view.js | 180 +----------------
 .../test/unit.js                              |   2 +-
 .../vendor/auth                               |   2 +-
 .../vendor/common                             |   2 +-
 10 files changed, 216 insertions(+), 192 deletions(-)
 delete mode 100644 packages/knowledge-base-web-page-element-view/src/demo.js
 create mode 100644 packages/knowledge-base-web-page-element-view/src/index.js
 create mode 100644 packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js

diff --git a/packages/knowledge-base-web-page-element-view/package.json b/packages/knowledge-base-web-page-element-view/package.json
index b8823697..b31f40c3 100644
--- a/packages/knowledge-base-web-page-element-view/package.json
+++ b/packages/knowledge-base-web-page-element-view/package.json
@@ -1,7 +1,7 @@
 {
   "name": "vpu-knowledge-base-web-page-element-view",
   "version": "1.0.0",
-  "main": "src/vpu-knowledge-base-web-page-element-view.js",
+  "main": "src/index.js",
   "devDependencies": {
     "chai": "^4.2.0",
     "i18next-scanner": "^2.10.2",
@@ -18,7 +18,6 @@
     "rollup-plugin-copy": "^3.1.0",
     "rollup-plugin-delete": "^1.1.0",
     "rollup-plugin-json": "^4.0.0",
-    "rollup-plugin-multi-entry": "^2.1.0",
     "rollup-plugin-node-resolve": "^5.2.0",
     "rollup-plugin-postcss": "^2.0.3",
     "rollup-plugin-replace": "^2.2.0",
@@ -29,6 +28,7 @@
     "vpu-common": "file:./vendor/common"
   },
   "dependencies": {
+    "@open-wc/scoped-elements": "^1.0.9",
     "i18next": "^17.0.3",
     "lit-element": "^2.1.0",
     "lit-html": "^1.1.1",
diff --git a/packages/knowledge-base-web-page-element-view/rollup.config.js b/packages/knowledge-base-web-page-element-view/rollup.config.js
index 4fb9bf0e..a766344c 100644
--- a/packages/knowledge-base-web-page-element-view/rollup.config.js
+++ b/packages/knowledge-base-web-page-element-view/rollup.config.js
@@ -1,3 +1,4 @@
+import glob from 'glob';
 import path from 'path';
 import resolve from 'rollup-plugin-node-resolve';
 import commonjs from 'rollup-plugin-commonjs';
@@ -5,7 +6,6 @@ import copy from 'rollup-plugin-copy';
 import {terser} from "rollup-plugin-terser";
 import json from 'rollup-plugin-json';
 import serve from 'rollup-plugin-serve';
-import multiEntry from 'rollup-plugin-multi-entry';
 import url from "rollup-plugin-url";
 import consts from 'rollup-plugin-consts';
 import del from 'rollup-plugin-delete';
@@ -14,7 +14,7 @@ const build = (typeof process.env.BUILD !== 'undefined') ? process.env.BUILD : '
 console.log("build: " + build);
 
 export default {
-    input: (build != 'test') ? ['src/vpu-knowledge-base-web-page-element-view.js', 'src/vpu-knowledge-base-web-page-element-view-demo.js'] : 'test/**/*.js',
+    input: (build != 'test') ? ['src/vpu-knowledge-base-web-page-element-view.js', 'src/vpu-knowledge-base-web-page-element-view-demo.js'] : glob.sync('test/**/*.js'),
     output: {
         dir: 'dist',
         entryFileNames: '[name].js',
@@ -22,11 +22,17 @@ export default {
         format: 'esm',
         sourcemap: true
     },
+    onwarn: function (warning, warn) {
+        // keycloak bundled code uses eval
+        if (warning.code === 'EVAL') {
+          return;
+        }
+        warn(warning);
+    },
     plugins: [
         del({
             targets: 'dist/*'
         }),
-        (build == 'test') ? multiEntry() : false,
         consts({
             environment: build,
         }),
diff --git a/packages/knowledge-base-web-page-element-view/src/demo.js b/packages/knowledge-base-web-page-element-view/src/demo.js
deleted file mode 100644
index e176fe1e..00000000
--- a/packages/knowledge-base-web-page-element-view/src/demo.js
+++ /dev/null
@@ -1 +0,0 @@
-import './vpu-knowledge-base-web-page-element-view-demo.js';
\ No newline at end of file
diff --git a/packages/knowledge-base-web-page-element-view/src/index.js b/packages/knowledge-base-web-page-element-view/src/index.js
new file mode 100644
index 00000000..2d9635ee
--- /dev/null
+++ b/packages/knowledge-base-web-page-element-view/src/index.js
@@ -0,0 +1,3 @@
+import {KnowledgeBaseWebPageElementView} from './knowledge-base-web-page-element-view.js';
+
+export {KnowledgeBaseWebPageElementView};
\ No newline at end of file
diff --git a/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js b/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js
new file mode 100644
index 00000000..7991c14d
--- /dev/null
+++ b/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js
@@ -0,0 +1,184 @@
+import {i18n} from './i18n';
+import {html} from 'lit-element';
+import VPULitElement from 'vpu-common/vpu-lit-element'
+import {ScopedElementsMixin} from '@open-wc/scoped-elements';
+import {MiniSpinner} from 'vpu-common';
+import * as commonUtils from "vpu-common/utils";
+import {unsafeHTML} from 'lit-html/directives/unsafe-html.js';
+
+/**
+ * KnowledgeBaseWebPageElementView web component
+ */
+export class KnowledgeBaseWebPageElementView extends ScopedElementsMixin(VPULitElement) {
+    constructor() {
+        super();
+        this.lang = 'de';
+        this.value = '';
+        this.html = '';
+        this.entryPointUrl = commonUtils.getAPiUrl();
+        this.error = '';
+        this.eyeClose = '';
+        this.eyeOpen = '';
+        //this.css = 'kb.css';
+        this.text = '';
+        this.class = '';
+    }
+
+    static get scopedElements() {
+        return {
+          'vpu-mini-spinner': MiniSpinner,
+        };
+    }
+
+    /**
+     * See: https://lit-element.polymer-project.org/guide/properties#initialize
+     */
+    static get properties() {
+        return {
+            lang: { type: String },
+            value: { type: String },
+            html: { type: String, attribute: false },
+            entryPointUrl: { type: String, attribute: 'entry-point-url' },
+            id: { type: String, attribute: false},
+            error: { type: String, attribute: false},
+            //css: { type: String },
+            text: { type: String },
+        };
+    }
+
+    /*
+    connectedCallback() {
+        super.connectedCallback();
+        const that = this;
+
+        // JSONLD.initialize(this.entryPointUrl, function (jsonld) {
+        //     const apiUrl = jsonld.getApiUrlForEntityName("KnowledgeBaseWebPageElement") + '/' +
+        //         encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(that.value)));
+        // });
+
+        // disabled, load first on toggle to visible
+        window.addEventListener("vpu-auth-init", () => that.loadWebPageElement());
+    }
+    */
+
+    /**
+     * Loads the data from the web page element
+     */
+    loadWebPageElement() {
+        if (window.VPUAuthToken === undefined || window.VPUAuthToken === "") {
+            return;
+        }
+
+        // sadly there there is no entity url without "collectionOperations" in entity KnowledgeBaseWebPageElement!
+        const apiUrl = this.entryPointUrl + "/web_page_elements/knowledge_base_web_page_elements/" +
+            encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(this.value))) +
+            "?lang=" + encodeURIComponent(this.lang);
+
+        var that = this;
+        fetch(apiUrl, {
+            headers: {
+                'Content-Type': 'application/ld+json',
+                'Authorization': 'Bearer ' + window.VPUAuthToken,
+            },
+        })
+        .then(function (res) {
+            if (!res.ok) {
+                let status_msg;
+                switch (res.status) {
+                    case 403:
+                        status_msg = i18n.t('is-forbidden');
+                        break;
+                    case 404:
+                        status_msg = i18n.t('was-not-found');
+                        break;
+                    case 500:
+                        status_msg = i18n.t('troubled-server');
+                        break;
+                    default:
+                        status_msg = i18n.t('unknown-problems');
+                }
+                const error_head = i18n.t('error-head');
+                that.error = html`<p>${error_head} "<b>${that.value}</b>" ${status_msg} (${res.status}).</p>`;
+                that.html = "";
+                throw new Error('HTTP ' + error_head + ' ' + that.value + ' ' + status_msg + ', status = ' + res.status);
+            }
+            return res.json();
+        })
+        .then(webPageElement => {
+            if (webPageElement !== undefined && webPageElement.text !== undefined) {
+                that.html = webPageElement.text;
+            }
+        })
+        // catch e.g. 404 errors
+        .catch();
+    }
+
+    update(changedProperties) {
+        changedProperties.forEach((oldValue, propName) => {
+            if (propName === "lang") {
+                i18n.changeLanguage(this.lang);
+            }
+
+            switch(propName) {
+                case "lang":
+                case "value":
+                case "entry-point-url":
+                    this.html = '';
+                    const img = this._('#A2');
+                    if (img !== null) {
+                        img.src = this.eyeOpen;
+                    }
+                    const div = this._('#A1');
+                    if (div !== null) {
+                        div.style.display = 'none';
+                    }
+                    break;
+                case "text":
+                    this.class = this.text !== '' ? 'has-text' : '';
+                    break;
+            }
+        });
+
+        super.update(changedProperties);
+    }
+
+    toggle(e) {
+        const div = this._('#A1');
+        const img = this._('#A2');
+        const d = div.style.display;
+        if(d === '' || d === 'none') {
+            div.style.display = 'block';
+            img.src = this.eyeClose;
+        } else {
+            div.style.display = 'none';
+            img.src = this.eyeOpen;
+        }
+        if (this.html === '' && div.style.display !== 'none') {
+            this.html = "<vpu-mini-spinner></vpu-mini-spinner>";
+            this.loadWebPageElement();
+        }
+    }
+
+    render() {
+        commonUtils.initAssetBaseURL('vpu-knowledge-base-web-page-element-view-src');
+
+        return html`
+            <style>
+                .kb {
+                    display: none;
+                    border-radius: var(--KBBorderRadius, 0);
+                    border: var(--KBBorder, 0);
+                    margin: var(--KBMargin, 0);
+                    padding: var(--KBPadding, 0);
+                }
+                span.has-text img {margin-left: 5px}
+                span.with-pointer { cursor: pointer; }
+            </style>
+            <span class="with-pointer ${this.class}" @click="${this.toggle}">${this.text}<img src="${this.eyeOpen}" id="A2" alt="open/close"></span>
+            <div class='kb' id="A1">
+                ${unsafeHTML(this.html)}
+                ${this.error}
+            </div>
+        `;
+    }
+}
\ No newline at end of file
diff --git a/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view-demo.js b/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view-demo.js
index f40e936e..636b8901 100644
--- a/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view-demo.js
+++ b/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view-demo.js
@@ -1,17 +1,25 @@
 import {i18n} from './i18n';
 import {css, html, LitElement} from 'lit-element';
-import 'vpu-auth';
-import './vpu-knowledge-base-web-page-element-view.js';
+import {ScopedElementsMixin} from '@open-wc/scoped-elements';
+import {Auth} from 'vpu-auth';
+import {KnowledgeBaseWebPageElementView} from './knowledge-base-web-page-element-view.js';
 import * as commonUtils from 'vpu-common/utils';
 import * as commonStyles from 'vpu-common/styles';
 
-class KnowledgeBaseWebPageElementViewDemo extends LitElement {
+class KnowledgeBaseWebPageElementViewDemo extends ScopedElementsMixin(LitElement) {
     constructor() {
         super();
         this.lang = 'de';
         this.noAuth = false;
     }
 
+    static get scopedElements() {
+        return {
+          'vpu-knowledge-base-web-page-element-view' : KnowledgeBaseWebPageElementView,
+          'vpu-auth': Auth,
+        };
+    }
+
     static get properties() {
         return {
             lang: { type: String },
@@ -38,13 +46,13 @@ class KnowledgeBaseWebPageElementViewDemo extends LitElement {
             h1.title {margin-bottom: 1em;}
             div.container {margin-bottom: 1.5em;}
 
-            vpu-knowledge-base-web-page-element-view.clean {
+            .clean {
                 --KBBorder: initial;
                 --KBBorderRadius: initial;
                 --KBMargin: initial;
                 --KBPadding: initial;
             }
-            vpu-knowledge-base-web-page-element-view.opt {
+            .opt {
                 --KBBorder: 2px solid blue;
             }
         `;
diff --git a/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view.js b/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view.js
index a4f532c3..f11e7a53 100644
--- a/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view.js
+++ b/packages/knowledge-base-web-page-element-view/src/vpu-knowledge-base-web-page-element-view.js
@@ -1,180 +1,4 @@
-import {i18n} from './i18n';
-import {html} from 'lit-element';
-// import JSONLD from 'vpu-common/jsonld';
-import VPULitElement from 'vpu-common/vpu-lit-element'
-import "vpu-common/vpu-mini-spinner.js";
 import * as commonUtils from "vpu-common/utils";
-import {unsafeHTML} from 'lit-html/directives/unsafe-html.js';
+import {KnowledgeBaseWebPageElementView} from './knowledge-base-web-page-element-view.js';
 
-/**
- * KnowledgeBaseWebPageElementView web component
- */
-class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
-    constructor() {
-        super();
-        this.lang = 'de';
-        this.value = '';
-        this.html = '';
-        this.entryPointUrl = commonUtils.getAPiUrl();
-        this.error = '';
-        this.eyeClose = '';
-        this.eyeOpen = '';
-        //this.css = 'kb.css';
-        this.text = '';
-        this.class = '';
-    }
-
-    /**
-     * See: https://lit-element.polymer-project.org/guide/properties#initialize
-     */
-    static get properties() {
-        return {
-            lang: { type: String },
-            value: { type: String },
-            html: { type: String, attribute: false },
-            entryPointUrl: { type: String, attribute: 'entry-point-url' },
-            id: { type: String, attribute: false},
-            error: { type: String, attribute: false},
-            //css: { type: String },
-            text: { type: String },
-        };
-    }
-
-    /*
-    connectedCallback() {
-        super.connectedCallback();
-        const that = this;
-
-        // JSONLD.initialize(this.entryPointUrl, function (jsonld) {
-        //     const apiUrl = jsonld.getApiUrlForEntityName("KnowledgeBaseWebPageElement") + '/' +
-        //         encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(that.value)));
-        // });
-
-        // disabled, load first on toggle to visible
-        window.addEventListener("vpu-auth-init", () => that.loadWebPageElement());
-    }
-    */
-
-    /**
-     * Loads the data from the web page element
-     */
-    loadWebPageElement() {
-        if (window.VPUAuthToken === undefined || window.VPUAuthToken === "") {
-            return;
-        }
-
-        // sadly there there is no entity url without "collectionOperations" in entity KnowledgeBaseWebPageElement!
-        const apiUrl = this.entryPointUrl + "/web_page_elements/knowledge_base_web_page_elements/" +
-            encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(this.value))) +
-            "?lang=" + encodeURIComponent(this.lang);
-
-        var that = this;
-        fetch(apiUrl, {
-            headers: {
-                'Content-Type': 'application/ld+json',
-                'Authorization': 'Bearer ' + window.VPUAuthToken,
-            },
-        })
-        .then(function (res) {
-            if (!res.ok) {
-                let status_msg;
-                switch (res.status) {
-                    case 403:
-                        status_msg = i18n.t('is-forbidden');
-                        break;
-                    case 404:
-                        status_msg = i18n.t('was-not-found');
-                        break;
-                    case 500:
-                        status_msg = i18n.t('troubled-server');
-                        break;
-                    default:
-                        status_msg = i18n.t('unknown-problems');
-                }
-                const error_head = i18n.t('error-head');
-                that.error = html`<p>${error_head} "<b>${that.value}</b>" ${status_msg} (${res.status}).</p>`;
-                that.html = "";
-                throw new Error('HTTP ' + error_head + ' ' + that.value + ' ' + status_msg + ', status = ' + res.status);
-            }
-            return res.json();
-        })
-        .then(webPageElement => {
-            if (webPageElement !== undefined && webPageElement.text !== undefined) {
-                that.html = webPageElement.text;
-            }
-        })
-        // catch e.g. 404 errors
-        .catch();
-    }
-
-    update(changedProperties) {
-        changedProperties.forEach((oldValue, propName) => {
-            if (propName === "lang") {
-                i18n.changeLanguage(this.lang);
-            }
-
-            switch(propName) {
-                case "lang":
-                case "value":
-                case "entry-point-url":
-                    this.html = '';
-                    const img = this._('#A2');
-                    if (img !== null) {
-                        img.src = this.eyeOpen;
-                    }
-                    const div = this._('#A1');
-                    if (div !== null) {
-                        div.style.display = 'none';
-                    }
-                    break;
-                case "text":
-                    this.class = this.text !== '' ? 'has-text' : '';
-                    break;
-            }
-        });
-
-        super.update(changedProperties);
-    }
-
-    toggle(e) {
-        const div = this._('#A1');
-        const img = this._('#A2');
-        const d = div.style.display;
-        if(d === '' || d === 'none') {
-            div.style.display = 'block';
-            img.src = this.eyeClose;
-        } else {
-            div.style.display = 'none';
-            img.src = this.eyeOpen;
-        }
-        if (this.html === '' && div.style.display !== 'none') {
-            this.html = "<vpu-mini-spinner></vpu-mini-spinner>";
-            this.loadWebPageElement();
-        }
-    }
-
-    render() {
-        commonUtils.initAssetBaseURL('vpu-knowledge-base-web-page-element-view-src');
-
-        return html`
-            <style>
-                .kb {
-                    display: none;
-                    border-radius: var(--KBBorderRadius, 0);
-                    border: var(--KBBorder, 0);
-                    margin: var(--KBMargin, 0);
-                    padding: var(--KBPadding, 0);
-                }
-                span.has-text img {margin-left: 5px}
-                span.with-pointer { cursor: pointer; }
-            </style>
-            <span class="with-pointer ${this.class}" @click="${this.toggle}">${this.text}<img src="${this.eyeOpen}" id="A2" alt="open/close"></span>
-            <div class='kb' id="A1">
-                ${unsafeHTML(this.html)}
-                ${this.error}
-            </div>
-        `;
-    }
-}
-
-commonUtils.defineCustomElement('vpu-knowledge-base-web-page-element-view', VPUKnowledgeBaseWebPageElementView);
+commonUtils.defineCustomElement('vpu-knowledge-base-web-page-element-view', KnowledgeBaseWebPageElementView);
diff --git a/packages/knowledge-base-web-page-element-view/test/unit.js b/packages/knowledge-base-web-page-element-view/test/unit.js
index 1dd031e8..b2682060 100644
--- a/packages/knowledge-base-web-page-element-view/test/unit.js
+++ b/packages/knowledge-base-web-page-element-view/test/unit.js
@@ -1,5 +1,5 @@
 import '../src/vpu-knowledge-base-web-page-element-view.js';
-import '../src/demo.js';
+import '../src/vpu-knowledge-base-web-page-element-view-demo.js';
 
 describe('vpu-knowledge-base-web-page-element-view basics', () => {
   let node;
diff --git a/packages/knowledge-base-web-page-element-view/vendor/auth b/packages/knowledge-base-web-page-element-view/vendor/auth
index 0d2610ce..b9fbe487 160000
--- a/packages/knowledge-base-web-page-element-view/vendor/auth
+++ b/packages/knowledge-base-web-page-element-view/vendor/auth
@@ -1 +1 @@
-Subproject commit 0d2610cee764128529a71629c2adb1922e2849ed
+Subproject commit b9fbe487a8a6117ae90a423a8ba318a0321bf51b
diff --git a/packages/knowledge-base-web-page-element-view/vendor/common b/packages/knowledge-base-web-page-element-view/vendor/common
index 833dd224..9c6dc1fd 160000
--- a/packages/knowledge-base-web-page-element-view/vendor/common
+++ b/packages/knowledge-base-web-page-element-view/vendor/common
@@ -1 +1 @@
-Subproject commit 833dd224c7ecab1caf509d83f58211c2346e8b19
+Subproject commit 9c6dc1fd5e004eba32e31adf8e4485a26c345fe0
-- 
GitLab