element/examples/route.config.js

103 lines
2.5 KiB
JavaScript
Raw Normal View History

2016-07-27 06:15:02 +00:00
import navConfig from './nav.config.json';
import langs from './i18n/route.json';
2016-07-27 06:15:02 +00:00
const registerRoute = (navConfig) => {
let route = [];
Object.keys(navConfig).forEach((lang, index) => {
let navs = navConfig[lang];
route.push({
path: `/${ lang }/component`,
redirect: `/${ lang }/component/installation`,
component: require(`./pages/${ lang }/component.vue`),
children: []
});
navs.forEach(nav => {
if (nav.groups) {
nav.groups.forEach(group => {
group.list.forEach(nav => {
addRoute(nav, lang, index);
});
});
} else if (nav.children) {
nav.children.forEach(nav => {
addRoute(nav, lang, index);
});
} else {
addRoute(nav, lang, index);
}
});
});
function addRoute(page, lang, index) {
const component = page.path === '/changelog'
? require(`./pages/${ lang }/changelog.vue`)
: require(`./docs/${ lang }${page.path}.md`);
2016-09-14 03:15:28 +00:00
let child = {
2016-08-23 09:39:58 +00:00
path: page.path.slice(1),
meta: {
title: page.title || page.name,
description: page.description,
lang
2016-08-23 09:39:58 +00:00
},
component: component.default || component
2016-09-14 03:15:28 +00:00
};
route[index].children.push(child);
2016-08-23 09:39:58 +00:00
}
2016-07-27 06:15:02 +00:00
return route;
2016-07-27 06:15:02 +00:00
};
let route = registerRoute(navConfig);
2016-07-27 06:15:02 +00:00
function generateMiscRoutes(lang) {
let guideRoute = {
path: `/${ lang }/guide`, // 指南
redirect: `/${ lang }/guide/design`,
component: require(`./pages/${ lang }/guide.vue`),
children: [{
path: 'design', // 设计原则
meta: { lang },
component: require(`./pages/${ lang }/design.vue`)
}, {
path: 'nav', // 导航
meta: { lang },
component: require(`./pages/${ lang }/nav.vue`)
}]
};
2016-08-22 09:49:20 +00:00
let resourceRoute = {
path: `/${ lang }/resource`, // 资源
meta: { lang },
component: require(`./pages/${ lang }/resource.vue`)
};
2016-08-22 09:49:20 +00:00
let indexRoute = {
path: `/${ lang }`, // 首页
meta: { lang },
name: 'home',
component: require(`./pages/${ lang }/index.vue`)
};
return [guideRoute, resourceRoute, indexRoute];
2016-08-23 09:39:58 +00:00
};
langs.forEach(lang => {
route = route.concat(generateMiscRoutes(lang.lang));
});
2016-07-27 06:15:02 +00:00
2016-11-11 08:58:44 +00:00
let userLanguage = localStorage.getItem('ELEMENT_LANGUAGE') || window.navigator.language;
let defaultPath = '/en-US';
if (userLanguage.indexOf('zh-') !== -1) {
defaultPath = '/zh-CN';
}
route = route.concat([{
path: '/',
2016-11-11 08:58:44 +00:00
redirect: defaultPath
}, {
2016-07-27 09:05:28 +00:00
path: '*',
2016-11-11 08:58:44 +00:00
redirect: defaultPath
}]);
2016-07-27 09:05:28 +00:00
export default route;