Routes with meta requiresAuth redirects to login page if token not set in localstorage

This commit is contained in:
2020-04-09 20:58:55 +02:00
committed by KevinMidboe
parent 73afb34964
commit e193528fe9

View File

@@ -14,11 +14,13 @@ let routes = [
{ {
name: 'activity', name: 'activity',
path: '/activity', path: '/activity',
meta: { requiresAuth: true },
component: (resolve) => require(['./components/ActivityPage.vue'], resolve) component: (resolve) => require(['./components/ActivityPage.vue'], resolve)
}, },
{ {
name: 'profile', name: 'profile',
path: '/profile', path: '/profile',
meta: { requiresAuth: true },
component: (resolve) => require(['./components/Profile.vue'], resolve) component: (resolve) => require(['./components/Profile.vue'], resolve)
}, },
{ {
@@ -46,6 +48,7 @@ let routes = [
{ {
name: 'settings', name: 'settings',
path: '/settings', path: '/settings',
meta: { requiresAuth: true },
component: (resolve) => require(['./components/Settings.vue'], resolve) component: (resolve) => require(['./components/Settings.vue'], resolve)
}, },
{ {
@@ -101,6 +104,13 @@ router.beforeEach((to, from, next) => {
document.querySelector('.nav__hamburger').classList.remove('nav__hamburger--active'); document.querySelector('.nav__hamburger').classList.remove('nav__hamburger--active');
document.querySelector('.nav__list').classList.remove('nav__list--active'); document.querySelector('.nav__list').classList.remove('nav__list--active');
} }
if (to.matched.some(record => record.meta.requiresAuth)) {
if (localStorage.getItem('token') == null) {
next({ path: '/login' });
}
}
next(); next();
}); });