Files
dougal-software/lib/www/client/source/src/router/index.js

126 lines
2.9 KiB
JavaScript
Raw Normal View History

2020-08-08 23:59:13 +02:00
import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'
import Project from '../views/Project.vue'
import ProjectList from '../views/ProjectList.vue'
import ProjectSummary from '../views/ProjectSummary.vue'
import LineList from '../views/LineList.vue'
import LineSummary from '../views/LineSummary.vue'
import SequenceList from '../views/SequenceList.vue'
import SequenceSummary from '../views/SequenceSummary.vue'
import Calendar from '../views/Calendar.vue'
import Log from '../views/Log.vue'
import QC from '../views/QC.vue'
2020-08-08 23:59:13 +02:00
import Map from '../views/Map.vue'
Vue.use(VueRouter)
const routes = [
{
path: '/',
name: 'Home',
component: Home
},
{
path: '/about',
name: 'About',
// route level code-splitting
// this generates a separate chunk (about.[hash].js) for this route
// which is lazy-loaded when the route is visited.
component: () => import(/* webpackChunkName: "about" */ '../views/About.vue')
},
{
pathToRegexpOptions: { strict: true },
path: "/projects",
redirect: "/projects/"
},
{
pathToRegexpOptions: { strict: true },
path: "/projects/",
component: ProjectList,
meta: {
breadcrumbs: [
{ text: "Projects", href: "/projects", disabled: true }
]
}
},
{
pathToRegexpOptions: { strict: true },
path: "/projects/:project",
redirect: "/projects/:project/"
},
{
pathToRegexpOptions: { strict: true },
path: "/projects/:project/",
name: "Project",
component: Project,
meta: {
breadcrumbs: [
{ text: "Projects", href: "/projects" },
{
text: (ctx) => ctx.$store.state.project.projectName || "…",
href: (ctx) => `/projects/${ctx.$store.state.project.projectId || ctx.$route.params.project || ""}/`
}
]
},
children: [
{
path: "",
redirect: "summary"
},
{
path: "summary",
component: ProjectSummary
},
{
path: "lines/",
name: "LineList",
component: LineList
},
{
path: "lines/:line",
name: "Line",
component: LineSummary
},
{
path: "sequences",
component: SequenceList
},
{
path: "sequences/:sequence",
component: SequenceSummary
},
{
path: "calendar",
component: Calendar
},
{
path: "log",
component: Log,
children: [
{ path: "sequence/:sequence", name: "logBySequence" },
{ path: "date/:date0", name: "logByDate" },
{ path: "date/:date0/:date1", name: "logByDates" }
]
2020-08-08 23:59:13 +02:00
},
{
path: "qc",
component: QC
},
2020-08-08 23:59:13 +02:00
{
path: "map",
component: Map
}
]
}
]
const router = new VueRouter({
mode: 'history',
base: process.env.BASE_URL,
routes
})
export default router