editor: reset state button and error messages

This commit is contained in:
Vašek Šraier 2020-10-23 14:25:04 +02:00
parent 6bbf59c32d
commit 013f805128
2 changed files with 25 additions and 5 deletions

View file

@ -4,7 +4,7 @@
import Graph from "./Graph.svelte";
import { nonNull, saveToLocalDisk } from "./helpers";
import type { TaskDescriptor, TasksFile } from "./tasks";
import { saveTasks, getCategories, tasksToString } from "./tasks";
import { resetTasks, saveTasks, getCategories, tasksToString } from "./tasks";
import TaskDisplay from "./TaskDisplay.svelte";
import TaskDetailEditor from "./TaskDetailEditor.svelte";
import { forceSimulation } from "./force-simulation";
@ -64,7 +64,15 @@
}
async function saveCurrentState() {
await saveTasks(tasks);
await saveTasks(tasks).catch((val) => {
alert(val);
});
}
async function resetCurrentState() {
await resetTasks().catch((val) => {
alert(val);
});
}
// autosave ;)
@ -356,14 +364,15 @@
<h3>Toolbox</h3>
<div>
<button on:click={saveCurrentState}>Uložit aktuální stav</button>
<button on:click={saveLocally}>Stáhnout data</button>
<button on:click={resetCurrentState}>Resetovat aktuální stav</button>
</div>
<button on:click={saveLocally}>Stáhnout data lokálně</button>
<div class="gap" />
<div>
<button on:click={addTask}>Nový node</button>
<button
disabled={clicked.length == 0}
on:click={() => removeTask(clicked[clicked.length - 1])}>Odstranit {clicked[clicked.length - 1] ?? '???'}</button>
on:click={() => removeTask(clicked[clicked.length - 1])}>Odstranit "{clicked[clicked.length - 1] ?? '???'}"</button>
</div>
<div class="gap" />
<div>

View file

@ -74,7 +74,18 @@ export async function saveTasks(tasks: TasksFile) {
}
}
await fetch("/tasks.json", options)
const result = await fetch("/tasks.json", options)
if (result.status != 200) throw `Failed to save tasks.json. ${result.status} ${result.statusText}`
}
export async function resetTasks() {
// request options
const options = {
method: 'DELETE',
}
const result = await fetch("/tasks.json", options)
if (result.status != 200) throw `Failed to reset tasks.json. ${result.status} ${result.statusText}`
}
export function createTaskMap(tasks: TasksFile): TaskMap {