import EventList from '@/views/Event/EventList.vue'; import Location from '@/views/Location.vue'; import { RouteConfig } from 'vue-router'; // tslint:disable:space-in-parens const participations = () => import(/* webpackChunkName: "participations" */ '@/views/Event/Participants.vue'); const editEvent = () => import(/* webpackChunkName: "edit-event" */ '@/views/Event/Edit.vue'); const event = () => import(/* webpackChunkName: "event" */ '@/views/Event/Event.vue'); const myEvents = () => import(/* webpackChunkName: "my-events" */ '@/views/Event/MyEvents.vue'); // tslint:enable export enum EventRouteName { EVENT_LIST = 'EventList', CREATE_EVENT = 'CreateEvent', MY_EVENTS = 'MyEvents', EDIT_EVENT = 'EditEvent', PARTICIPATIONS = 'Participations', EVENT = 'Event', LOCATION = 'Location', } export const eventRoutes: RouteConfig[] = [ { path: '/events/list/:location?', name: EventRouteName.EVENT_LIST, component: EventList, meta: { requiredAuth: false }, }, { path: '/events/create', name: EventRouteName.CREATE_EVENT, component: editEvent, meta: { requiredAuth: true }, }, { path: '/events/me', name: EventRouteName.MY_EVENTS, component: myEvents, meta: { requiredAuth: true }, }, { path: '/events/edit/:eventId', name: EventRouteName.EDIT_EVENT, component: editEvent, meta: { requiredAuth: true }, props: { isUpdate: true }, }, { path: '/events/participations/:eventId', name: EventRouteName.PARTICIPATIONS, component: participations, meta: { requiredAuth: true }, props: true, }, { path: '/location/new', name: EventRouteName.LOCATION, component: Location, meta: { requiredAuth: true }, }, { path: '/events/:uuid', name: EventRouteName.EVENT, component: event, props: true, meta: { requiredAuth: false }, }, ];