aboutsummaryrefslogtreecommitdiff
path: root/fe/src/lib/DataView.svelte
blob: cd7b042292a2313abc77f3b3e6a35b86c1c059b6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<script lang='ts'>
import { onMount } from 'svelte';
import { token } from '../stores/auth'
import Table from './Table.svelte';

let json;
let showAddForm: boolean = false;

async function fetchData() {
    const res = await fetch('http://localhost:8080/api/v1/stats/', {
        method: "GET",
        headers: {
            'Authorization': `Bearer ${$token}`
        }
    });
    if (res.ok) {
        json = res.json();
    } else {
        throw new Error('There was a problem with your request');
    }
}

async function submitStat() {
    const response = await fetch('http://localhost:8080/api/v1/stats/', {
        method: "POST",
        headers: {
            'Authorization': `Bearer ${$token}`
        },
        body: JSON.stringify({
            date: new Date,
            user_id: 1,
            quantity: 3
        })
    });
    fetchData();
}

function handleClick() {
    showAddForm = true;
}

function handleAddDialogSubmit (e) {
    console.log(e.keyCode)
}

onMount(() => {
    fetchData();
});

</script>
<div>
    <button on:click={submitStat}>Add Stat Test</button>
    <dialog open={showAddForm} on:submit={handleAddDialogSubmit}>
        <form method="dialog">
            <input name="date" type="date" />
            <input name="quantity" type="number" min="0" autocomplete="off"/>
            <button type="submit">Submit</button>
        </form>
    </dialog>
    <button on:click={handleClick}>Add</button>
    {#await json then data}
        <Table {data} nofooter />
    {:catch error}
        <p>{error}</p>
    {/await}
    <!-- <Chart /> -->
</div>