Files
stacjownik/src/router/index.ts
T
2024-03-11 23:43:10 +01:00

70 lines
1.6 KiB
TypeScript

import { createRouter, createWebHistory, RouteRecordRaw } from 'vue-router';
const routes: Array<RouteRecordRaw> = [
{
path: '/',
name: 'StationsView',
component: () => import('../views/StationsView.vue'),
props: (route) => ({
region: route.query.region
})
},
{
path: '/trains',
name: 'TrainsView',
component: () => import('../views/TrainsView.vue'),
props: (route) => ({
train: route.query.train,
driver: route.query.driver,
trainId: route.query.trainId,
region: route.query.region
})
},
{
path: '/scenery',
name: 'SceneryView',
component: () => import('../views/SceneryView.vue'),
props: (route) => ({
region: route.query.region,
station: route.query.station
})
},
{
path: '/journal',
redirect: '/journal/timetables'
},
{
path: '/journal/timetables',
name: 'JournalTimetables',
component: () => import('../views/JournalTimetables.vue'),
props: (route) => ({
region: route.query.region
})
},
{
path: '/journal/dispatchers',
name: 'JournalDispatchers',
component: () => import('../views/JournalDispatchers.vue'),
props: (route) => ({
region: route.query.region
})
},
{
path: '/:catchAll(.*)',
redirect: '/'
}
];
const router = createRouter({
scrollBehavior(to, from, savedPosition) {
if (to.name == 'SceneryView' && from.name !== to.name && from.query['view'] === undefined)
return { el: `.app_main` };
if (savedPosition) return savedPosition;
},
history: createWebHistory(),
routes
});
export default router;