surwiki/templates/article_revision.html

135 lines
3.7 KiB
HTML
Raw Normal View History

2017-09-01 17:34:24 +03:00
<header>
2017-08-20 23:17:16 +03:00
<h1>{{title}}</h1>
2017-09-01 17:34:24 +03:00
</header>
<article>
2017-09-02 16:32:59 +03:00
<div class="rendered">
{{{rendered}}}
</div>
<div class="editor">
<form action="" method="POST">
2017-09-05 18:07:57 +03:00
<input type=hidden name=base_revision value="{{revision}}">
<textarea autocomplete=off name=body>{{raw}}</textarea>
<textarea autocomplete=off class="shadow-control"></textarea>
<div class="editor-controls">
2017-09-06 12:07:01 +03:00
<a class="cancel" href="{{article_id}}">Cancel</a>
<button type=submit>Save</button>
</div>
2017-09-02 16:32:59 +03:00
</form>
</div>
2017-09-01 17:34:24 +03:00
</article>
<footer>
<p><a id="openEditor" href="?editor">Edit</a></p>
2017-09-01 17:34:24 +03:00
<dl>
<dt>Article ID</dt>
<dd>{{article_id}}</dd>
<dt>Revision</dt>
2017-09-05 18:07:57 +03:00
<dd class="revision">{{revision}}</dd>
2017-09-01 17:34:24 +03:00
<dt>Last updated</dt>
2017-09-05 18:07:57 +03:00
<dd class="last-updated">{{created}}</dd>
2017-09-01 17:34:24 +03:00
</dl>
</footer>
2017-09-02 16:32:59 +03:00
<script>
function autosizeTextarea(textarea, shadow) {
shadow.style.width = textarea.clientWidth + "px";
shadow.value = textarea.value;
textarea.style.height = shadow.scrollHeight + "px";
}
function queryArgsFromForm(form) {
const items = [];
for (const {name, value} of form.elements) {
if (!name) continue;
items.push(encodeURIComponent(name) + '=' + encodeURIComponent(value));
}
return items.join('&');
}
2017-09-05 18:07:57 +03:00
let hasBeenOpen = false;
2017-09-02 16:32:59 +03:00
function openEditor() {
const article = document.querySelector("article");
2017-09-06 12:07:01 +03:00
const rendered = article.querySelector(".rendered");
const editor = article.querySelector(".editor");
const textarea = editor.querySelector('textarea[name="body"]');
const shadow = editor.querySelector('textarea.shadow-control');
2017-09-05 18:07:57 +03:00
const form = editor.querySelector("form");
2017-09-06 12:07:01 +03:00
const cancel = editor.querySelector('.cancel');
const footer = document.querySelector("footer");
const revision = footer.querySelector(".revision");
const lastUpdated = footer.querySelector(".last-updated");
2017-09-02 16:32:59 +03:00
textarea.style.height = rendered.clientHeight + "px";
article.classList.add('edit');
2017-09-02 16:32:59 +03:00
autosizeTextarea(textarea, shadow);
2017-09-05 18:07:57 +03:00
textarea.focus();
if (hasBeenOpen) return;
hasBeenOpen = true;
textarea.addEventListener('input', () => autosizeTextarea(textarea, shadow));
window.addEventListener('resize', () => autosizeTextarea(textarea, shadow));
form.addEventListener("submit", function (ev) {
2017-09-06 12:07:01 +03:00
ev.preventDefault();
ev.stopPropagation();
2017-09-06 12:07:01 +03:00
(async function () {
const body = queryArgsFromForm(form);
textarea.disabled = true;
const response = await fetch(
form.getAttribute("action"),
{
method: 'PUT',
headers: {
"Content-Type": "application/x-www-form-urlencoded"
},
body: body,
}
);
if (!response.ok) throw new Error("Unexpected status code (" + response.status + ")");
2017-09-02 16:32:59 +03:00
2017-09-05 18:07:57 +03:00
const result = await response.json();
form.elements.base_revision.value = result.revision;
2017-09-06 12:07:01 +03:00
revision.textContent = result.revision;
lastUpdated.textContent = result.created;
2017-09-05 18:07:57 +03:00
rendered.innerHTML = result.rendered;
article.classList.remove('edit');
textarea.disabled = false;
}()
.catch(err => {
textarea.disabled = false;
console.error(err);
alert(err);
}));
2017-09-02 16:32:59 +03:00
});
2017-09-06 12:07:01 +03:00
cancel.addEventListener('click', function (ev) {
ev.preventDefault();
ev.stopPropagation();
article.classList.remove('edit');
form.reset();
2017-09-07 00:22:34 +03:00
});
2017-09-02 16:32:59 +03:00
}
document
.getElementById("openEditor")
.addEventListener("click", function (ev) {
ev.preventDefault();
ev.stopPropagation();
openEditor();
})
</script>