53 lines
2.5 KiB
JavaScript
53 lines
2.5 KiB
JavaScript
import { createRouter, createWebHistory, createMemoryHistory } from 'vue-router'
|
|
import { routes } from '@/utils/router_menu.js'
|
|
|
|
let defaultroutes = [
|
|
{ path: '/', name: 'Home', component: () => import('@/views/Home.vue') },
|
|
{ path: '/404', name: '404', component: () => import('@/views/404.vue') },
|
|
|
|
{ path: '/login', name: 'Login', component: () => import('@/views/Login.vue') },
|
|
{ path: '/signup', name: 'Signup', component: () => import('@/views/Signup.vue') },
|
|
|
|
{ path: '/:pathMatch(.*)*', name: 'NotFound', component: () => import('@/views/404.vue') }, // Catch all 404
|
|
{
|
|
path: '/dashboard', name: 'Dashboard', component: () => import('@/views/DashBoard.vue'), meta: { requiresAuth: true }, redirect: '/dashboard/overview', children: [
|
|
{ path: 'overview', name: 'Overview', component: () => import('@/views/dashboard/Overview.vue'), meta: { title: 'Overview' } },
|
|
{ path: 'tokens', name: 'Tokens', component: () => import('@/views/dashboard/Tokens.vue'), meta: { title: 'Tokens' } },
|
|
{
|
|
path: 'manager', name: 'Manager', meta: { title: 'Manager' }, redirect: '/dashboard/manager/users', children: [
|
|
{ path: 'users', name: 'User', component: () => import('@/views/dashboard/User.vue'), meta: { title: 'Users' } },
|
|
{ path: 'users/new', name: 'UserNew', component: () => import('@/views/dashboard/UserNew.vue'), meta: { title: 'UserNew' } },
|
|
{ path: 'users/view', name: 'UserView', component: () => import('@/views/dashboard/UserView.vue'), meta: { title: 'UserView' } },
|
|
{ path: 'keys', name: 'ApiKey', component: () => import('@/views/dashboard/Keys.vue'), meta: { title: 'Keys' } },
|
|
{ path: 'keys/view', name: 'ApiKeyView', component: () => import('@/views/dashboard/KeyView.vue'), meta: { title: 'KeyView' } },
|
|
]
|
|
},
|
|
{
|
|
path: 'settings', name: 'Settings', meta: { title: 'Settings' }, redirect: '/dashboard/settings/profile', children: [
|
|
{ path: 'profile', name: 'Profile', component: () => import('@/views/dashboard/Profile.vue'), meta: { title: 'Profile' } },
|
|
]
|
|
},
|
|
]
|
|
},
|
|
]
|
|
|
|
|
|
const router = createRouter({
|
|
history: createWebHistory(),
|
|
routes,
|
|
})
|
|
|
|
// const router = createRouter({
|
|
// history: createWebHistory(process.env.BASE_URL),
|
|
// routes
|
|
// })
|
|
router.beforeEach((to, from, next) => {
|
|
const isAuthenticated = localStorage.getItem('token')
|
|
if (to.meta.requiresAuth && !isAuthenticated) {
|
|
next('/login')
|
|
} else {
|
|
next()
|
|
}
|
|
})
|
|
|
|
export default router |