started to overhaul MardownEditor.svelte

This commit is contained in:
2025-07-11 09:07:38 +02:00
parent 713e6ff8ff
commit c37b1de1b0
3 changed files with 29 additions and 6 deletions

View File

@@ -2,8 +2,28 @@
let { editable = false, value = $bindable(null) } = $props();
let editing = $state(false);
function toggleEdit(){
editing = !editing;
let editValue = {source:value.source,rendered:value.rendered};
function applyEdit(){
value.source = editValue.source;
value.rendered = editValue.rendered;
editing = false;
}
function resetEdit(){
editing = false;
editValue = {source:value.source,rendered:value.rendered};
}
function startEdit(){
editing = editable;
}
function typed(ev){
if (ev.keyCode == 13 && ev.ctrlKey) applyEdit();
if (ev.keyCode == 27) resetEdit();
// TODO: start timer, send text to renderer, update editValue.rendered
}
</script>
@@ -15,6 +35,6 @@
</style>
{#if editable && editing}
<textarea bind:value></textarea>
<textarea bind:value={editValue.source} onkeyup={typed} autofocus></textarea>
{/if}
<div onclick={toggleEdit}>{@html value}</div>
<div onclick={startEdit}>{@html value.rendered}</div>