page/login: update cookie from useCookie on login/logout
I think this fixes an issue where auth token cookie gets deleted when page is not being refreshed after login.
This commit is contained in:
parent
eabb7b89c7
commit
f11b4c9a75
1 changed files with 8 additions and 3 deletions
|
@ -1,8 +1,9 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { ref, watch } from "vue";
|
import { ref, watch } from "vue";
|
||||||
import { VForm } from "vuetify/components";
|
import { VForm } from "vuetify/components";
|
||||||
|
import { type CookieRef } from "#app";
|
||||||
import { cookieSettings } from "~/utils/cookieSettings";
|
import { cookieSettings } from "~/utils/cookieSettings";
|
||||||
import { definePageMeta, navigateTo, useCookie, useFetch, useRoute, useRequestFetch } from "#imports";
|
import { definePageMeta, navigateTo, useCookie, useFetch, useRoute, useRequestFetch, useRequestEvent } from "#imports";
|
||||||
|
|
||||||
const route = useRoute();
|
const route = useRoute();
|
||||||
const fetch = useRequestFetch();
|
const fetch = useRequestFetch();
|
||||||
|
@ -12,7 +13,10 @@ const password = ref("");
|
||||||
const loading = ref(false);
|
const loading = ref(false);
|
||||||
const error = ref<true | string>(true);
|
const error = ref<true | string>(true);
|
||||||
const form = ref<VForm | null>(null);
|
const form = ref<VForm | null>(null);
|
||||||
const loggedIn = ref<boolean>(useCookie("token", cookieSettings).value != null);
|
const tokenCookie = useCookie("token", cookieSettings) as CookieRef<string | undefined>;
|
||||||
|
const loggedIn = ref<boolean>(tokenCookie.value !== undefined);
|
||||||
|
|
||||||
|
watch(tokenCookie, (v) => { loggedIn.value = v !== undefined; });
|
||||||
|
|
||||||
const redirectTo = ref(route.redirectedFrom);
|
const redirectTo = ref(route.redirectedFrom);
|
||||||
|
|
||||||
|
@ -29,7 +33,7 @@ async function submit() {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
});
|
});
|
||||||
console.log(result);
|
console.log(result);
|
||||||
loggedIn.value = true;
|
tokenCookie.value = result.token;
|
||||||
password.value = "";
|
password.value = "";
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.log(typeof e);
|
console.log(typeof e);
|
||||||
|
@ -47,6 +51,7 @@ async function logout() {
|
||||||
await fetch("/api/logout");
|
await fetch("/api/logout");
|
||||||
loggedIn.value = false;
|
loggedIn.value = false;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
tokenCookie.value = undefined;
|
||||||
console.error(e);
|
console.error(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue