LeagueStats/client/src/router.js

51 lines
1.2 KiB
JavaScript
Raw Normal View History

2019-03-30 22:55:48 +00:00
import Vue from 'vue'
import Router from 'vue-router'
import { axios } from './plugins/axios'
2019-03-30 22:55:48 +00:00
import Home from '@/views/Home.vue'
import Summoner from '@/views/Summoner.vue'
import SummonerChampions from '@/views/SummonerChampions.vue'
2019-03-30 22:55:48 +00:00
Vue.use(Router)
const router = new Router({
2019-03-30 22:55:48 +00:00
mode: 'history',
base: process.env.BASE_URL,
routes: [
{
path: '/',
name: 'home',
component: Home,
meta: {
layout: 'Home'
}
2019-03-30 22:55:48 +00:00
},
{
2019-04-07 17:44:01 +00:00
path: '/summoner/:region/:name',
2019-03-30 22:55:48 +00:00
name: 'summoner',
component: Summoner
},
{
path: '/summoner/:region/:name/champions',
name: 'summonerChampions',
component: SummonerChampions
},
2019-03-30 22:55:48 +00:00
]
})
router.beforeEach((to, from, next) => {
if (to.params.name !== from.params.name && from.name !== null) {
// Cancel old requests
const axiosCancel = axios.defaults.axiosSource.cancel
axiosCancel('Summoner changed')
// Update cancel token
const CancelToken = axios.CancelToken
const axiosSource = CancelToken.source()
axios.defaults.axiosSource = axiosSource
axios.defaults.cancelToken = axiosSource.token
}
next()
})
export default router