working on project tree update upon task creation/deletion/update

This commit is contained in:
2025-12-20 15:11:18 +01:00
parent 711addd75c
commit 5a1c8e1438
4 changed files with 54 additions and 14 deletions

View File

@@ -14,6 +14,7 @@
let {
estimated_time,
lastEvent,
show_closed,
siblings,
states = {},
@@ -141,6 +142,18 @@
estimated_time.sum += task.estimated_time;
}
$effect(() => {
if (lastEvent && lastEvent.task) {
if (children && lastEvent.task.parent_task_id == task.id) {
if (lastEvent.event == 'delete'){
delete children[lastEvent.task.id];
} else {
children[lastEvent.task.id] = lastEvent.task;
}
}
}
});
onMount(loadChildren);
</script>
@@ -170,7 +183,7 @@
<button class="symbol" title={t('add_object',{object:t('subtask')})} onclick={addSubtask}></button>
<button class="symbol" title={t('timetracking')} onclick={addTime}></button>
{#if children}
<TaskList {states} tasks={children} {estimated_time} {show_closed} />
<TaskList {states} {lastEvent} tasks={children} {estimated_time} {show_closed} />
{/if}
</li>
{/if}

View File

@@ -2,14 +2,13 @@
import { t } from '../../translations.svelte.js';
import ListTask from './ListTask.svelte';
let { estimated_time, show_closed, states = {}, tasks } = $props();
let { estimated_time, lastEvent, show_closed, states = {}, tasks } = $props();
let sortedTasks = $derived.by(() => Object.values(tasks).sort((a, b) => a.name.localeCompare(b.name)));
</script>
<ul>
{#each sortedTasks as task}
<ListTask {states} {task} siblings={tasks} {estimated_time} show_closed={show_closed || task.show_closed} />
<ListTask {states} {task} {lastEvent} siblings={tasks} {estimated_time} show_closed={show_closed || task.show_closed} />
{/each}
</ul>