Skip to content
Snippets Groups Projects
Commit d6403001 authored by Neuber, Eugen Ramon's avatar Neuber, Eugen Ramon :speech_balloon: Committed by Reiter, Christoph
Browse files

Add open/close button for kb element

parent 1df2d685
No related branches found
No related tags found
No related merge requests found
...@@ -37,12 +37,22 @@ class KnowledgeBaseWebPageElementViewDemo extends LitElement { ...@@ -37,12 +37,22 @@ class KnowledgeBaseWebPageElementViewDemo extends LitElement {
</div> </div>
<div class="content"> <div class="content">
<h2 class="subtitle">Deutsch</h2> <h2 class="subtitle">Deutsch</h2>
Ein Buch ausleihen...
<vpu-knowledge-base-web-page-element-view entry-point-url="${utils.getAPiUrl()}" lang="de" value="bedienstete/bibliothek/buch-ausleihen"></vpu-knowledge-base-web-page-element-view> <vpu-knowledge-base-web-page-element-view entry-point-url="${utils.getAPiUrl()}" lang="de" value="bedienstete/bibliothek/buch-ausleihen"></vpu-knowledge-base-web-page-element-view>
</div> </div>
<div class="content"> <div class="content">
<h2 class="subtitle">Englisch</h2> <h2 class="subtitle">Englisch</h2>
Borrow a book...
<vpu-knowledge-base-web-page-element-view entry-point-url="${utils.getAPiUrl()}" lang="en" value="bedienstete/bibliothek/buch-ausleihen"></vpu-knowledge-base-web-page-element-view> <vpu-knowledge-base-web-page-element-view entry-point-url="${utils.getAPiUrl()}" lang="en" value="bedienstete/bibliothek/buch-ausleihen"></vpu-knowledge-base-web-page-element-view>
</div> </div>
<hr>
<div class="content">
FAQ...
<vpu-knowledge-base-web-page-element-view lang="${this.lang}" value="abc/def/xyz"></vpu-knowledge-base-web-page-element-view>
<br>
Kontaktieren Sie uns unter...
<vpu-knowledge-base-web-page-element-view lang="${this.lang}" value="abc/def/klm"></vpu-knowledge-base-web-page-element-view>
</div>
</section> </section>
`; `;
} }
......
...@@ -16,6 +16,11 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement { ...@@ -16,6 +16,11 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
this.value = ''; this.value = '';
this.html = ''; this.html = '';
this.entryPointUrl = utils.getAPiUrl(); this.entryPointUrl = utils.getAPiUrl();
this.error = '';
this.id = String.fromCharCode(65 + Math.floor(Math.random() * 26)) + Date.now();
this.eyeClose = '';
this.eyeOpen = '';
//this.css = 'kb.css';
} }
/** /**
...@@ -27,6 +32,9 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement { ...@@ -27,6 +32,9 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
value: { type: String }, value: { type: String },
html: { type: String, attribute: false }, html: { type: String, attribute: false },
entryPointUrl: { type: String, attribute: 'entry-point-url' }, entryPointUrl: { type: String, attribute: 'entry-point-url' },
id: { type: String, attribute: false},
error: { type: String, attribute: false},
//css: { type: String },
}; };
} }
...@@ -56,20 +64,45 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement { ...@@ -56,20 +64,45 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(this.value))) + encodeURIComponent(commonUtils.base64EncodeUnicode(encodeURIComponent(this.value))) +
"?lang=" + encodeURIComponent(this.lang); "?lang=" + encodeURIComponent(this.lang);
var that = this;
fetch(apiUrl, { fetch(apiUrl, {
headers: { headers: {
'Content-Type': 'application/ld+json', 'Content-Type': 'application/ld+json',
'Authorization': 'Bearer ' + window.VPUAuthToken, 'Authorization': 'Bearer ' + window.VPUAuthToken,
}, },
}) })
.then(res => res.json()) .then(function (res) {
.then(webPageElement => { if (!res.ok) {
if (webPageElement !== undefined && webPageElement.text !== undefined) { let status_msg;
this.html = webPageElement.text; switch (res.status) {
case 403:
status_msg = that.lang === 'de' ? 'ist verboten' : 'is forbidden';
break;
case 404:
status_msg = that.lang === 'de' ? 'wurde nicht gefunden' : 'was not found';
break;
case 500:
status_msg = that.lang === 'de' ? 'macht Probleme am Server' : 'troubled server';
break;
default:
status_msg = that.lang === 'de' ? 'mit unbekanntem Problem' : 'with unknown problems';
} }
}) if (that.lang === 'de') {
// catch e.g. 404 errors that.error = html`<p>FEHLER: Information "<b>${that.value}</b>" ${status_msg} (${res.status}).</p>`;
.catch(); } else {
that.error = html`<p>ERROR: information "<b>${that.value}</b>" ${status_msg} (${res.status}).</p>`;
}
throw new Error('HTTP error: ' +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();
} }
updated(changedProperties) { updated(changedProperties) {
...@@ -77,7 +110,6 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement { ...@@ -77,7 +110,6 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
if (propName === "lang") { if (propName === "lang") {
i18n.changeLanguage(this.lang); i18n.changeLanguage(this.lang);
} }
switch(propName) { switch(propName) {
case "lang": case "lang":
case "value": case "value":
...@@ -88,21 +120,32 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement { ...@@ -88,21 +120,32 @@ class VPUKnowledgeBaseWebPageElementView extends VPULitElement {
}); });
} }
toggle(e) {
const id = this.id;
const element = this.shadowRoot.querySelector('#' + id);
const img = e.target;
const d = element.style.display;
if(d === '' || d === 'none') {
element.style.display = 'flex';
img.src = this.eyeClose;
} else {
element.style.display = 'none';
img.src = this.eyeOpen;
}
}
render() { render() {
//<link rel="stylesheet" href="${this.css}">
const id = this.id;
return html` return html`
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.7.5/css/bulma.min.css"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.7.5/css/bulma.min.css">
<style> <style>
</style> </style>
<div class="columns"> <img src='${this.eyeOpen}' @click="${this.toggle}" alt="open/close">
<div class="column"> <div class='kb' id="${id}">
Hier kann man dann etwas aufklappen. ${unsafeHTML(this.html)}
</div> ${this.error}
</div>
<div class="columns">
<div class="column">
${unsafeHTML(this.html)}
</div>
</div> </div>
`; `;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment