2019-04-15 16:50:38 +02:00
|
|
|
import Vue from 'vue'
|
|
|
|
import Router from 'vue-router'
|
2020-05-22 11:41:48 +02:00
|
|
|
import Dashboard from '@/views/Dashboard.vue'
|
|
|
|
import Login from '@/views/Login.vue'
|
2020-05-24 11:50:21 +02:00
|
|
|
import { isAuthenticated } from '@/services/auth.js'
|
2019-04-15 16:50:38 +02:00
|
|
|
|
|
|
|
Vue.use(Router)
|
|
|
|
|
2020-05-24 11:50:21 +02:00
|
|
|
const router = new Router({
|
2020-12-30 11:11:40 +01:00
|
|
|
base: process.env.BASE_URL,
|
|
|
|
routes: [
|
|
|
|
{
|
|
|
|
path: '/',
|
|
|
|
name: 'dashboard',
|
|
|
|
component: Dashboard
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: '/login',
|
|
|
|
name: 'login',
|
|
|
|
component: Login,
|
|
|
|
meta: {
|
|
|
|
public: true, // Allow access to even if not logged in
|
|
|
|
onlyWhenLoggedOut: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
2019-04-15 16:50:38 +02:00
|
|
|
})
|
2020-05-22 11:41:48 +02:00
|
|
|
|
2020-05-24 11:50:21 +02:00
|
|
|
router.beforeEach(async (to, from, next) => {
|
2020-12-30 11:11:40 +01:00
|
|
|
const isPublic = to.matched.some(record => record.meta.public)
|
|
|
|
const onlyWhenLoggedOut = to.matched.some(
|
|
|
|
record => record.meta.onlyWhenLoggedOut
|
|
|
|
)
|
|
|
|
const authenticated = isAuthenticated()
|
2020-05-24 11:50:21 +02:00
|
|
|
|
2020-12-30 11:11:40 +01:00
|
|
|
if (!isPublic && !authenticated) {
|
|
|
|
return next({
|
|
|
|
path: '/login',
|
|
|
|
// Store the full path to redirect the user to after login
|
|
|
|
query: { redirect: to.fullPath }
|
|
|
|
})
|
|
|
|
}
|
2020-05-24 11:50:21 +02:00
|
|
|
|
2020-12-30 11:11:40 +01:00
|
|
|
// Do not allow user to visit login page or register page
|
|
|
|
// if they are logged in
|
|
|
|
if (authenticated && onlyWhenLoggedOut) {
|
|
|
|
return next('/')
|
|
|
|
}
|
2020-05-22 11:41:48 +02:00
|
|
|
|
2020-12-30 11:11:40 +01:00
|
|
|
next()
|
2020-05-24 11:50:21 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
export default router
|