import {createRouter, createWebHistory} from "vue-router"; import MenuBar from "@/components/MenuBar.vue"; import SingleAssignment from "@/views/assignments/SingleAssignment.vue"; import SingleClass from "@/views/classes/SingleClass.vue"; import SingleDiscussion from "@/views/discussions/SingleDiscussion.vue"; import NotFound from "@/components/errors/NotFound.vue"; import CreateClass from "@/views/classes/CreateClass.vue"; import CreateAssignment from "@/views/assignments/CreateAssignment.vue"; import CreateDiscussion from "@/views/discussions/CreateDiscussion.vue"; import CallbackPage from "@/views/CallbackPage.vue"; import UserDiscussions from "@/views/discussions/UserDiscussions.vue"; import UserClasses from "@/views/classes/UserClasses.vue"; import UserAssignments from "@/views/assignments/UserAssignments.vue"; import authState from "@/services/auth/auth-service.ts"; import UserHomePage from "@/views/homepage/UserHomePage.vue"; import SingleTheme from "@/views/SingleTheme.vue"; const router = createRouter({ history: createWebHistory(import.meta.env.BASE_URL), routes: [ { path: "/", name: "home", component: () => import("../views/HomePage.vue"), meta: {requiresAuth: false}, }, { path: "/login", name: "LoginPage", component: () => import("../views/LoginPage.vue"), meta: {requiresAuth: false}, }, { path: "/callback", component: CallbackPage, meta: {requiresAuth: false}, }, { path: "/user", component: MenuBar, meta: {requiresAuth: true}, children: [ { path: "", name: "UserHomePage", component: UserHomePage, }, { path: "assignment", name: "UserAssignments", component: UserAssignments, }, { path: "class", name: "UserClasses", component: UserClasses, }, { path: "discussion", name: "UserDiscussions", component: UserDiscussions, }, ], }, { path: "/theme/:id", name: "Theme", component: SingleTheme, meta: {requiresAuth: true}, }, { path: "/assignment", component: MenuBar, meta: {requiresAuth: true}, children: [ { path: "create", name: "CreateAssigment", component: CreateAssignment, }, { path: ":id", name: "SingleAssigment", component: SingleAssignment, }, ] }, { path: "/class/create", name: "CreateClass", component: CreateClass, meta: {requiresAuth: true}, }, { path: "/class/:id", name: "SingleClass", component: SingleClass, meta: {requiresAuth: true}, }, { path: "/discussion/create", name: "CreateDiscussion", component: CreateDiscussion, meta: {requiresAuth: true}, }, { path: "/discussion/:id", name: "SingleDiscussion", component: SingleDiscussion, meta: {requiresAuth: true}, }, { path: "/:catchAll(.*)", name: "NotFound", component: NotFound, meta: {requiresAuth: false}, }, ], }); router.beforeEach(async (to, from, next) => { // Verify if user is logged in before accessing certain routes if (to.meta.requiresAuth) { if (!authState.isLoggedIn.value) { //Next("/login"); next(); } else { next(); } } else { next(); } }); export default router;