diff --git a/client/src/components/NavBar.vue b/client/src/components/NavBar.vue index e11af91..64a6d6e 100644 --- a/client/src/components/NavBar.vue +++ b/client/src/components/NavBar.vue @@ -1,5 +1,14 @@ \ No newline at end of file + diff --git a/client/src/state.ts b/client/src/state.ts index 67c0955..9e08abb 100644 --- a/client/src/state.ts +++ b/client/src/state.ts @@ -2,6 +2,7 @@ import { reactive } from "vue" import { Track } from "./track" import { Tick } from './ticks' import { error } from "./error" +import { getCookie } from "./util"; enum State { Unfetched, @@ -31,6 +32,8 @@ class AppState { constructor() { this.tracks = new Array this.state = State.Unfetched + const name = getCookie("name") + if (name) this.user = { name } } streamUpdatesFromServer() { const source = new EventSource("/api/v1/updates") diff --git a/client/src/util.ts b/client/src/util.ts new file mode 100644 index 0000000..ebbda1c --- /dev/null +++ b/client/src/util.ts @@ -0,0 +1,8 @@ +export function getCookie(key: string): string | null { + const start = document.cookie.indexOf(key + '=') + if(start === -1) return null + let end: number | undefined = document.cookie.indexOf(';', start) + if(end === -1) + end = undefined + return document.cookie.substring(start + key.length + 1, end) +} \ No newline at end of file diff --git a/client/src/views/Login.vue b/client/src/views/Login.vue index 9f21ab0..a50bf9d 100644 --- a/client/src/views/Login.vue +++ b/client/src/views/Login.vue @@ -1,13 +1,18 @@