2016-07-27 14:15:02 +08:00
|
|
|
import navConfig from './nav.config.json';
|
2016-11-10 21:46:55 +08:00
|
|
|
import langs from './i18n/route.json';
|
2016-07-27 14:15:02 +08:00
|
|
|
|
2017-05-12 16:33:36 +08:00
|
|
|
const LOAD_MAP = {
|
|
|
|
'zh-CN': name => {
|
|
|
|
return r => require.ensure([], () =>
|
|
|
|
r(require(`./pages/zh-CN/${name}.vue`)),
|
|
|
|
'zh-CN');
|
|
|
|
},
|
|
|
|
'en-US': name => {
|
|
|
|
return r => require.ensure([], () =>
|
|
|
|
r(require(`./pages/en-US/${name}.vue`)),
|
|
|
|
'en-US');
|
2017-11-06 19:22:02 +08:00
|
|
|
},
|
|
|
|
'es': name => {
|
|
|
|
return r => require.ensure([], () =>
|
|
|
|
r(require(`./pages/es/${name}.vue`)),
|
|
|
|
'es');
|
2017-05-12 16:33:36 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const load = function(lang, path) {
|
|
|
|
return LOAD_MAP[lang](path);
|
|
|
|
};
|
|
|
|
|
|
|
|
const LOAD_DOCS_MAP = {
|
|
|
|
'zh-CN': path => {
|
|
|
|
return r => require.ensure([], () =>
|
|
|
|
r(require(`./docs/zh-CN${path}.md`)),
|
|
|
|
'zh-CN');
|
|
|
|
},
|
|
|
|
'en-US': path => {
|
|
|
|
return r => require.ensure([], () =>
|
|
|
|
r(require(`./docs/en-US${path}.md`)),
|
|
|
|
'en-US');
|
2017-11-06 19:22:02 +08:00
|
|
|
},
|
|
|
|
'es': path => {
|
|
|
|
return r => require.ensure([], () =>
|
2018-01-08 13:38:51 +08:00
|
|
|
r(require(`./docs/es${path}.md`)),
|
|
|
|
'es');
|
2017-05-12 16:33:36 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const loadDocs = function(lang, path) {
|
|
|
|
return LOAD_DOCS_MAP[lang](path);
|
|
|
|
};
|
|
|
|
|
2016-11-10 21:46:55 +08: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`,
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'component'),
|
2016-11-10 21:46:55 +08:00
|
|
|
children: []
|
|
|
|
});
|
|
|
|
navs.forEach(nav => {
|
2017-05-10 20:44:49 +08:00
|
|
|
if (nav.href) return;
|
2016-11-10 21:46:55 +08:00
|
|
|
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'
|
2017-05-12 16:33:36 +08:00
|
|
|
? load(lang, 'changelog')
|
|
|
|
: loadDocs(lang, page.path);
|
2016-09-14 11:15:28 +08:00
|
|
|
let child = {
|
2016-08-23 17:39:58 +08:00
|
|
|
path: page.path.slice(1),
|
|
|
|
meta: {
|
|
|
|
title: page.title || page.name,
|
2016-11-10 21:46:55 +08:00
|
|
|
description: page.description,
|
|
|
|
lang
|
2016-08-23 17:39:58 +08:00
|
|
|
},
|
2017-12-12 12:45:09 +08:00
|
|
|
name: 'component-' + lang + (page.title || page.name),
|
2016-08-23 17:39:58 +08:00
|
|
|
component: component.default || component
|
2016-09-14 11:15:28 +08:00
|
|
|
};
|
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
route[index].children.push(child);
|
2016-08-23 17:39:58 +08:00
|
|
|
}
|
2016-07-27 14:15:02 +08:00
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
return route;
|
2016-07-27 14:15:02 +08:00
|
|
|
};
|
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
let route = registerRoute(navConfig);
|
2016-07-27 14:15:02 +08:00
|
|
|
|
2016-11-13 02:34:39 +08:00
|
|
|
const generateMiscRoutes = function(lang) {
|
2016-11-10 21:46:55 +08:00
|
|
|
let guideRoute = {
|
|
|
|
path: `/${ lang }/guide`, // 指南
|
|
|
|
redirect: `/${ lang }/guide/design`,
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'guide'),
|
2016-11-10 21:46:55 +08:00
|
|
|
children: [{
|
|
|
|
path: 'design', // 设计原则
|
2016-11-22 10:22:20 +08:00
|
|
|
name: 'guide-design' + lang,
|
2016-11-10 21:46:55 +08:00
|
|
|
meta: { lang },
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'design')
|
2016-11-10 21:46:55 +08:00
|
|
|
}, {
|
|
|
|
path: 'nav', // 导航
|
2016-11-22 10:22:20 +08:00
|
|
|
name: 'guide-nav' + lang,
|
2016-11-10 21:46:55 +08:00
|
|
|
meta: { lang },
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'nav')
|
2016-11-10 21:46:55 +08:00
|
|
|
}]
|
|
|
|
};
|
2016-08-22 17:49:20 +08:00
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
let resourceRoute = {
|
|
|
|
path: `/${ lang }/resource`, // 资源
|
|
|
|
meta: { lang },
|
2016-11-22 10:22:20 +08:00
|
|
|
name: 'resource' + lang,
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'resource')
|
2016-11-10 21:46:55 +08:00
|
|
|
};
|
2016-08-22 17:49:20 +08:00
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
let indexRoute = {
|
|
|
|
path: `/${ lang }`, // 首页
|
|
|
|
meta: { lang },
|
2016-11-22 10:22:20 +08:00
|
|
|
name: 'home' + lang,
|
2017-05-12 16:33:36 +08:00
|
|
|
component: load(lang, 'index')
|
2016-11-10 21:46:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
return [guideRoute, resourceRoute, indexRoute];
|
2016-08-23 17:39:58 +08:00
|
|
|
};
|
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
langs.forEach(lang => {
|
|
|
|
route = route.concat(generateMiscRoutes(lang.lang));
|
|
|
|
});
|
2016-07-27 14:15:02 +08:00
|
|
|
|
2016-11-13 02:34:39 +08:00
|
|
|
route.push({
|
|
|
|
path: '/play',
|
|
|
|
name: 'play',
|
|
|
|
component: require('./play/index.vue')
|
|
|
|
});
|
|
|
|
|
2016-11-13 21:45:55 +08:00
|
|
|
let userLanguage = localStorage.getItem('ELEMENT_LANGUAGE') || window.navigator.language || 'en-US';
|
2016-11-11 16:58:44 +08:00
|
|
|
let defaultPath = '/en-US';
|
|
|
|
if (userLanguage.indexOf('zh-') !== -1) {
|
|
|
|
defaultPath = '/zh-CN';
|
2017-11-06 19:22:02 +08:00
|
|
|
} else if (userLanguage.indexOf('es') !== -1) {
|
|
|
|
defaultPath = '/es';
|
2016-11-11 16:58:44 +08:00
|
|
|
}
|
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
route = route.concat([{
|
|
|
|
path: '/',
|
2016-11-11 16:58:44 +08:00
|
|
|
redirect: defaultPath
|
2016-11-10 21:46:55 +08:00
|
|
|
}, {
|
2016-07-27 17:05:28 +08:00
|
|
|
path: '*',
|
2016-11-11 16:58:44 +08:00
|
|
|
redirect: defaultPath
|
2016-11-10 21:46:55 +08:00
|
|
|
}]);
|
2016-07-27 17:05:28 +08:00
|
|
|
|
2016-11-10 21:46:55 +08:00
|
|
|
export default route;
|