PteroTheme/resources/assets/scripts/router.ts

79 lines
2.8 KiB
TypeScript
Raw Normal View History

2018-12-16 23:29:44 +00:00
import VueRouter, {Route} from 'vue-router';
import store from './store/index';
const route = require('./../../../vendor/tightenco/ziggy/src/js/route').default;
// Base Vuejs Templates
import Login from './components/auth/Login';
2018-12-30 01:00:50 +00:00
import Dashboard from './components/dashboard/Dashboard.vue';
import Account from './components/dashboard/Account.vue';
import ResetPassword from './components/auth/ResetPassword.vue';
import User from './models/user';
2018-07-16 03:03:38 +01:00
import {
Server,
ServerAllocations,
2018-07-21 06:34:30 +01:00
ConsolePage,
2018-08-04 05:32:50 +01:00
FileManagerPage,
2018-08-22 05:47:01 +01:00
DatabasesPage,
2018-07-16 03:03:38 +01:00
ServerSchedules,
ServerSettings,
2018-12-16 23:29:44 +00:00
ServerSubusers,
2018-07-16 03:03:38 +01:00
} from './components/server';
const routes = [
{name: 'login', path: '/auth/login', component: Login},
{name: 'forgot-password', path: '/auth/password', component: Login},
{name: 'checkpoint', path: '/auth/checkpoint', component: Login},
{
name: 'reset-password',
path: '/auth/password/reset/:token',
component: ResetPassword,
2018-12-16 23:29:44 +00:00
props: function (route: Route) {
return {token: route.params.token, email: route.query.email || ''};
2018-12-16 23:29:44 +00:00
},
},
{name: 'dashboard', path: '/', component: Dashboard},
{name: 'account', path: '/account', component: Account},
{name: 'account.api', path: '/account/api', component: Account},
{name: 'account.security', path: '/account/security', component: Account},
2018-12-16 23:29:44 +00:00
{
path: '/server/:id', component: Server,
2018-07-16 03:03:38 +01:00
children: [
2018-12-16 23:29:44 +00:00
{name: 'server', path: '', component: ConsolePage},
{name: 'server-files', path: 'files/:path(.*)?', component: FileManagerPage},
{name: 'server-subusers', path: 'subusers', component: ServerSubusers},
{name: 'server-schedules', path: 'schedules', component: ServerSchedules},
{name: 'server-databases', path: 'databases', component: DatabasesPage},
{name: 'server-allocations', path: 'allocations', component: ServerAllocations},
{name: 'server-settings', path: 'settings', component: ServerSettings},
],
},
];
const router = new VueRouter({
2018-12-16 23:29:44 +00:00
mode: 'history', routes,
});
// Redirect the user to the login page if they try to access a protected route and
// have no JWT or the JWT is expired and wouldn't be accepted by the Panel.
router.beforeEach((to, from, next) => {
if (to.path === route('auth.logout')) {
return window.location = route('auth.logout');
}
const user = store.getters['auth/getUser'];
// Check that if we're accessing a non-auth route that a user exists on the page.
if (!to.path.startsWith('/auth') && !(user instanceof User)) {
store.commit('auth/logout');
return window.location = route('auth.logout');
}
// Continue on through the pipeline.
return next();
});
export default router;