summaryrefslogtreecommitdiff
path: root/frontend/src/App.tsx
blob: 996a79427098e701d8a7be6ddbcc458c8e6186f6 (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
import React from 'react';
import { CredentialResponse, GoogleLogin } from '@react-oauth/google';

interface LoginResponse {
    id: number
}

interface User {
    id: Number,
    elements: Element[],
}

interface Element {
    id: Number,
    userId: Number,
    name: string,
    state: ElementState,
}

enum ElementState {
    HasColor,
    HasIcon,
}

function App() {
    const responseMessage = async (googleResponse: CredentialResponse) => {
        console.log(googleResponse);
        const url: string = "/auth/login";
        const body = {
            "googleToken": googleResponse.credential
        };

        const response = await fetch(url, {
            method: "POST",
            credentials: "include",
            mode: "cors",
            headers: {
                "Content-Type": "application/json"
            },
            body: JSON.stringify(body),
        });
        if (!response.ok) {
            console.log("Backend conection problem");
            return;
        }

        const user = await response.json() as LoginResponse;
        console.log(user);
    };

    return (
        <div className="App">
            <GoogleLogin onSuccess={responseMessage} />
        </div>
    );
}

export default App;