-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathroutes.js
71 lines (61 loc) · 1.66 KB
/
routes.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// Javascript Dependecies
import Vue from 'vue'
import VueRouter from 'vue-router'
import api from './api/auth'
import store from './vuex/store'
import _ from 'lodash'
// Lazyloading Views...
// Layouts
const MainLayout = r => require.ensure([], () => r(require('./views/Layouts/main')), 'guest')
// Pages
const Home = r => require.ensure([], () => r(require('./views/pages/home')), 'guest')
const NotFoundPage = r => require.ensure([], () => r(require('./views/errors/404.vue')), 'guest')
Vue.use(VueRouter)
// List of All Routes in Your Application
const routes = [
{
path: '/', component: MainLayout,
children: [
{
path: '/',
component: Home,
name: 'home'
}
]
},
{ path: '*', component: NotFoundPage }
]
// Vue Router Configuration
const router = new VueRouter({
routes,
mode: 'history',
// Element Ui Active Class
linkActiveClass: 'active'
})
// Hooks
router.beforeEach((to, from, next) => {
// If the next route is requires user to be Logged IN
if (to.matched.some(m => m.meta.requiresAuth)) {
return api.check().then(authenticated => {
if (!authenticated) {
return next({ path: '/login' })
}
// We check if the auth Object is Empty
// If it is Empty we Dispatch An Event to Get Auth User
if (_.isEmpty(store.getters['auth/getAuth'])) {
store.dispatch('auth/setAuth')
}
return next()
})
}
if (to.matched.some(m => m.meta.isAdmin)) {
return api.checkIsAdmin().then(admin => {
if (!admin) {
return next({ path: '/admin/dashboard' })
}
return next()
})
}
return next()
})
export default router