From 5a3e5570dc8cfe36a04d8e163218403b93ce3ec4 Mon Sep 17 00:00:00 2001 From: scammo Date: Sun, 21 Apr 2024 12:31:17 +0200 Subject: [PATCH] after login redirect to path the user tried to visit --- frontend/src/router/index.js | 2 +- frontend/src/views/Login.vue | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/frontend/src/router/index.js b/frontend/src/router/index.js index 4500776..35ea156 100644 --- a/frontend/src/router/index.js +++ b/frontend/src/router/index.js @@ -98,7 +98,7 @@ router.beforeEach(async (to, from, next) => { setLogin(localStorageAuth.user, localStorageAuth.token) } const requiresAuth = to.matched.some((record) => record.meta.requiresAuth); - if (requiresAuth && !isLoggedIn()) next("/login"); + if (requiresAuth && !isLoggedIn()) next(`/login?redirect=${to.fullPath}`); //else if(!requiresAuth && currentUser) next("/orga"); else next(); }); diff --git a/frontend/src/views/Login.vue b/frontend/src/views/Login.vue index 0c19b42..4db335e 100644 --- a/frontend/src/views/Login.vue +++ b/frontend/src/views/Login.vue @@ -3,12 +3,13 @@ import InputText from "primevue/inputtext"; import Button from "primevue/button"; import Toast from 'primevue/toast'; import { ref } from "vue"; -import { useRouter } from "vue-router"; +import { useRouter, useRoute } from "vue-router"; import { client, setLogin } from "../lib/api"; import { useToast } from 'primevue/usetoast'; const toast = useToast(); const router = useRouter(); +const route = useRoute(); const loading = ref(false); const email = ref(import.meta.env.PROD ? "" : "root@chaostreff-flensburg.de"); @@ -24,7 +25,7 @@ const onSubmit = async () => { setLogin(response.data.user, response.data.authorization.token) - router.push('/orga') + router.push(route.query.redirect || '/orga') } catch (error) { console.error(error) toast.add({ severity: 'error', summary: 'Login war nicht erfolgreich', life: 6000 });