cpolis/web/templates/editor.html

78 lines
2.5 KiB
HTML
Raw Normal View History

{{define "page-content"}}
2024-02-24 09:54:25 +01:00
<h2>Editor</h2>
2024-04-07 18:57:03 +02:00
<form id="edit-area">
2024-04-01 14:22:59 +02:00
<div class="flex flex-col gap-y-1">
<label for="article-title">Titel</label>
2024-09-28 12:17:03 +02:00
<input name="article-title" type="text" value="{{.Article.Title}}" />
2024-04-01 14:22:59 +02:00
</div>
<div class="flex flex-col gap-y-1">
2024-04-01 14:22:59 +02:00
<label for="article-description">Beschreibung</label>
2024-09-28 12:17:03 +02:00
<textarea name="article-description">{{.Article.Description}}</textarea>
2024-04-01 14:22:59 +02:00
</div>
<div class="flex flex-col gap-y-1">
<label for="easyMDE">Artikel</label>
2024-08-08 21:09:38 +02:00
<textarea id="easyMDE">{{.Content}}</textarea>
2024-09-28 12:17:03 +02:00
<input id="article-content" name="article-content" type="hidden" value="{{.Content}}" />
2024-03-28 08:41:38 +01:00
</div>
<div>
<span>Tags</span>
<div class="flex flex-wrap gap-x-4">
<div>
2024-09-28 12:17:03 +02:00
<input id="issue" name="issue" type="checkbox" {{if .Article.IsInIssue}}checked{{end}} />
<label for="issue">Orient Express</label>
</div>
2024-07-17 23:25:57 +02:00
{{range .Tags}}
<div>
2024-09-28 12:17:03 +02:00
<input id="tag-{{.Name}}" name="tags" type="checkbox" value="{{.ID}}" {{if index $.Selected
.ID}}checked{{end}} />
<label for="tag-{{.Name}}">{{.Name}}</label>
</div>
{{end}}
2024-03-28 08:41:38 +01:00
</div>
</div>
2024-04-01 14:22:59 +02:00
<div class="btn-area">
2024-09-28 12:17:03 +02:00
<input class="action-btn" type="submit" value="Senden" hx-post="/article/{{.Action}}"
hx-target="#page-content" />
<button class="btn" hx-get="/hub" hx-target="#page-content">Abbrechen</button>
2024-04-01 14:22:59 +02:00
</div>
</form>
2024-03-28 08:41:38 +01:00
<script>
2024-08-08 21:09:38 +02:00
var easyMDE = new EasyMDE({
element: document.getElementById('easyMDE'),
hideIcons: ['image'],
imageTexts: {sbInit: ''},
showIcons: ["code", "table", "upload-image"],
uploadImage: true,
2024-08-08 21:09:38 +02:00
imageUploadFunction: function (file, onSuccess, onError) {
var formData = new FormData();
formData.append('article-image', file);
fetch('/article/upload-image', {
2024-08-08 21:09:38 +02:00
method: 'POST',
body: formData
})
.then(response => response.json())
.then(data => {
onSuccess(data);
})
.catch(error => {
htmx.trigger(htmx.find('#notification'), 'htmx:responseError', {xhr: {responseText: error.message}});
2024-08-08 21:09:38 +02:00
onError(error);
});
},
});
2024-08-08 21:09:38 +02:00
easyMDE.codemirror.on("change", () => {
document.getElementById('article-content').value = easyMDE.value();
});
</script>
{{end}}