Compare commits

..

3 Commits

Author SHA1 Message Date
46feef3a48 Actually use input value 2025-03-09 17:48:31 +01:00
6e7dd7a560 update clients after trackers are updated 2025-03-09 17:41:20 +01:00
7a347ed246 Merge pull request #2 from AbaTekNTNU/config-settings
Config settings
2025-03-09 17:32:46 +01:00
3 changed files with 21 additions and 10 deletions

View File

@@ -257,6 +257,8 @@ async def handle_add_tracker(request):
return web.Response(text="Tracker already exists", status=400)
trackers[tracker_id] = TrackerData(tracker_id, *START_POSITION_INTERNAL)
await update_all_clients(request.app)
return web.Response(text="OK", status=200)
except Exception as e:
return web.Response(text=f"Error: {e}", status=400)
@@ -273,6 +275,8 @@ async def handler_delete_tracker(request):
return web.Response(text="Tracker does not exist", status=400)
del trackers[tracker_id]
await update_all_clients(request.app)
return web.Response(text="OK", status=200)
except Exception as e:
return web.Response(text=f"Error: {e}", status=400)

View File

@@ -3,32 +3,34 @@
import { Button } from "$lib/components/ui/button/index.js";
import TrackerSetting from "./TrackerSetting.svelte";
const addTracker = async () => {
const addTracker = async (arg: number) => {
const response = await fetch("/tracker", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
id: 4,
id: arg,
}),
});
console.log(response);
};
const deleteTracker = async () => {
const deleteTracker = async (arg: number) => {
const response = await fetch("/tracker", {
method: "DELETE",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
id: 4,
id: arg,
}),
});
console.log(response);
};
let id = $state(0);
</script>
<Drawer.Root>
@@ -41,8 +43,12 @@
<Drawer.Description>This action cannot be undone.</Drawer.Description>
</Drawer.Header>
<div class="flex items-center justify-evenly">
<TrackerSetting action={addTracker} text="Add Tracker" />
<TrackerSetting action={deleteTracker} text="Delete Tracker" />
<TrackerSetting bind:value={id} action={addTracker} text="Add Tracker" />
<TrackerSetting
bind:value={id}
action={deleteTracker}
text="Delete Tracker"
/>
</div>
</Drawer.Content>
</Drawer.Root>

View File

@@ -4,14 +4,15 @@
type Props = {
text: string;
action: () => void;
action: (arg: number) => void;
value: number;
};
let { action, text }: Props = $props();
let { action, text, value = $bindable() }: Props = $props();
</script>
<div>
<h2>{text}</h2>
<Input placeholder={"1"} type="tel" />
<Button onclick={action}>Submit</Button>
<Input placeholder={"1"} type="tel" bind:value />
<Button onclick={() => action(value)}>Submit</Button>
</div>