blob: 3cd522cb95dac397b9b293c9f8a29a2b1be5e8cd [file] [log] [blame]
{@eu.mulk.mulkcms2.benki.wiki.WikiPageRevision page}
{#include base.html}
{#title}{page.title} — Benki Wiki{/title}
{#head}
<link rel="stylesheet" type="text/css" href="/web_modules/ContentTools/build/content-tools.min.css" />
<script type="module" src="/web_modules/elix/define/ExpandablePanel.js"></script>
<style type="text/css">
#warning-panel {
background-color: lightcoral;
font-style: italic;
}
</style>
<script type="module">
import ContentTools from "/web_modules/ContentTools.js";
window.addEventListener('DOMContentLoaded', function() {
let editor = ContentTools.EditorApp.get();
editor.init('*[data-editable]', 'data-name');
editor.addEventListener('saved', async function (ev) {
document.getElementById("warning-panel").close();
let regions = ev.detail().regions;
if (Object.getOwnPropertyNames(regions).length === 0) {
// Nothing changed.
return;
}
this.busy(true);
let requestParams = new URLSearchParams();
for (let name of Object.getOwnPropertyNames(regions)) {
requestParams.append(name, regions[name]);
}
let response = await fetch("/wiki/{page.title}", {
method: 'POST',
body: requestParams
});
if (!response.ok) {
document.getElementById("warning-panel").open();
document.getElementById("warning-text").innerText = "Failed to save page: " + response.statusText;
this.busy(false);
return;
}
let status = await response.json();
if (status.status !== "ok") {
document.getElementById("warning-panel").open();
document.getElementById("warning-text").innerText = "Failed to save page: " + JSON.stringify(status);
this.busy(false);
return;
}
if (status.hasOwnProperty("content")) {
document.getElementById("wiki-content").innerHTML = status.content;
}
this.busy(false);
});
});
</script>
{/head}
{#body}
<article id="wiki-page">
<header>
<div data-editable data-name="wiki-title">
<h1>{page.title}</h1>
</div>
<elix-expandable-panel id="warning-panel"><div id="warning-text"></div></elix-expandable-panel>
</header>
<main>
<div data-editable data-name="wiki-content" id="wiki-content">
{#with page}{enrichedContent.raw}{/}
</div>
</main>
<hr>
<footer>
<a href="/wiki/{page.title}/revisions">Page revisions</a>
</footer>
</article>
{/body}
{/include}