|
@@ -0,0 +1,216 @@
|
|
|
+import { createElement } from 'react';
|
|
|
+import dynamic from 'dva/dynamic';
|
|
|
+import pathToRegexp from 'path-to-regexp';
|
|
|
+import { getMenuData } from './menu';
|
|
|
+
|
|
|
+let routerDataCache;
|
|
|
+
|
|
|
+const modelNotExisted = (app, model) => (
|
|
|
+
|
|
|
+ !app._models.some(({ namespace }) => {
|
|
|
+ return namespace === model.substring(model.lastIndexOf('/') + 1);
|
|
|
+ })
|
|
|
+);
|
|
|
+
|
|
|
+
|
|
|
+const dynamicWrapper = (app, models, component) => {
|
|
|
+
|
|
|
+
|
|
|
+ if (component.toString().indexOf('.then(') < 0) {
|
|
|
+ models.forEach((model) => {
|
|
|
+ if (modelNotExisted(app, model)) {
|
|
|
+
|
|
|
+ app.model(require(`../models/${model}`).default);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ return (props) => {
|
|
|
+ if (!routerDataCache) {
|
|
|
+ routerDataCache = getRouterData(app);
|
|
|
+ }
|
|
|
+ return createElement(component().default, {
|
|
|
+ ...props,
|
|
|
+ routerData: routerDataCache,
|
|
|
+ });
|
|
|
+ };
|
|
|
+ }
|
|
|
+
|
|
|
+ return dynamic({
|
|
|
+ app,
|
|
|
+ models: () => models.filter(
|
|
|
+ model => modelNotExisted(app, model)).map(m => import(`../models/${m}.js`)
|
|
|
+ ),
|
|
|
+
|
|
|
+ component: () => {
|
|
|
+ if (!routerDataCache) {
|
|
|
+ routerDataCache = getRouterData(app);
|
|
|
+ }
|
|
|
+ return component().then((raw) => {
|
|
|
+ const Component = raw.default || raw;
|
|
|
+ return props => createElement(Component, {
|
|
|
+ ...props,
|
|
|
+ routerData: routerDataCache,
|
|
|
+ });
|
|
|
+ });
|
|
|
+ },
|
|
|
+ });
|
|
|
+};
|
|
|
+
|
|
|
+function getFlatMenuData(menus) {
|
|
|
+ let keys = {};
|
|
|
+ menus.forEach((item) => {
|
|
|
+ if (item.children) {
|
|
|
+ keys[item.path] = { ...item };
|
|
|
+ keys = { ...keys, ...getFlatMenuData(item.children) };
|
|
|
+ } else {
|
|
|
+ keys[item.path] = { ...item };
|
|
|
+ }
|
|
|
+ });
|
|
|
+ return keys;
|
|
|
+}
|
|
|
+
|
|
|
+export const getRouterData = (app) => {
|
|
|
+ const routerConfig = {
|
|
|
+ '/': {
|
|
|
+ component: dynamicWrapper(app, ['user', 'login'], () => import('../layouts/BasicLayout')),
|
|
|
+ },
|
|
|
+ '/resource/image': {
|
|
|
+ component: dynamicWrapper(app, ['resource'], () => import('../routes/Resource/PictureList')),
|
|
|
+ },
|
|
|
+ '/resource/imageCreate': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Resource/PictureCreate')),
|
|
|
+ },
|
|
|
+ '/resource/imageCreate/single': {
|
|
|
+ component: dynamicWrapper(app, ['resource'], () => import('../routes/Resource/PictureCreateSingle')),
|
|
|
+ name: '单图上传'
|
|
|
+ },
|
|
|
+ '/resource/imageCreate/multiple': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Resource/PictureCreateMultiple')),
|
|
|
+ name: '多图上传'
|
|
|
+ },
|
|
|
+ '/resource/video': {
|
|
|
+ component: dynamicWrapper(app, ['resource'], () => import('../routes/Resource/VideoList')),
|
|
|
+ },
|
|
|
+ '/dashboard/analysis': {
|
|
|
+ component: dynamicWrapper(app, ['chart'], () => import('../routes/Dashboard/Analysis')),
|
|
|
+ },
|
|
|
+ '/dashboard/monitor': {
|
|
|
+ component: dynamicWrapper(app, ['monitor'], () => import('../routes/Dashboard/Monitor')),
|
|
|
+ },
|
|
|
+ '/dashboard/workplace': {
|
|
|
+ component: dynamicWrapper(app, ['project', 'activities', 'chart'], () => import('../routes/Dashboard/Workplace')),
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ },
|
|
|
+ '/form/basic-form': {
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/BasicForm')),
|
|
|
+ },
|
|
|
+ '/form/step-form': {
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/StepForm')),
|
|
|
+ },
|
|
|
+ '/form/step-form/info': {
|
|
|
+ name: '分步表单(填写转账信息)',
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/StepForm/Step1')),
|
|
|
+ },
|
|
|
+ '/form/step-form/confirm': {
|
|
|
+ name: '分步表单(确认转账信息)',
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/StepForm/Step2')),
|
|
|
+ },
|
|
|
+ '/form/step-form/result': {
|
|
|
+ name: '分步表单(完成)',
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/StepForm/Step3')),
|
|
|
+ },
|
|
|
+ '/form/advanced-form': {
|
|
|
+ component: dynamicWrapper(app, ['form'], () => import('../routes/Forms/AdvancedForm')),
|
|
|
+ },
|
|
|
+ '/list/table-list': {
|
|
|
+ component: dynamicWrapper(app, ['rule'], () => import('../routes/List/TableList')),
|
|
|
+ },
|
|
|
+ '/list/basic-list': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/BasicList')),
|
|
|
+ },
|
|
|
+ '/list/card-list': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/CardList')),
|
|
|
+ },
|
|
|
+ '/list/search': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/List')),
|
|
|
+ },
|
|
|
+ '/list/search/projects': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/Projects')),
|
|
|
+ },
|
|
|
+ '/list/search/applications': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/Applications')),
|
|
|
+ },
|
|
|
+ '/list/search/articles': {
|
|
|
+ component: dynamicWrapper(app, ['list'], () => import('../routes/List/Articles')),
|
|
|
+ },
|
|
|
+ '/profile/basic': {
|
|
|
+ component: dynamicWrapper(app, ['profile'], () => import('../routes/Profile/BasicProfile')),
|
|
|
+ },
|
|
|
+ '/profile/advanced': {
|
|
|
+ component: dynamicWrapper(app, ['profile'], () => import('../routes/Profile/AdvancedProfile')),
|
|
|
+ },
|
|
|
+ '/result/success': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Result/Success')),
|
|
|
+ },
|
|
|
+ '/result/fail': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Result/Error')),
|
|
|
+ },
|
|
|
+ '/exception/403': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Exception/403')),
|
|
|
+ },
|
|
|
+ '/exception/404': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Exception/404')),
|
|
|
+ },
|
|
|
+ '/exception/500': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/Exception/500')),
|
|
|
+ },
|
|
|
+ '/exception/trigger': {
|
|
|
+ component: dynamicWrapper(app, ['error'], () => import('../routes/Exception/triggerException')),
|
|
|
+ },
|
|
|
+ '/user': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../layouts/UserLayout')),
|
|
|
+ },
|
|
|
+ '/user/login': {
|
|
|
+ component: dynamicWrapper(app, ['login'], () => import('../routes/User/Login')),
|
|
|
+ },
|
|
|
+ '/user/register': {
|
|
|
+ component: dynamicWrapper(app, ['register'], () => import('../routes/User/Register')),
|
|
|
+ },
|
|
|
+ '/user/register-result': {
|
|
|
+ component: dynamicWrapper(app, [], () => import('../routes/User/RegisterResult')),
|
|
|
+ },
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ };
|
|
|
+
|
|
|
+ const menuData = getFlatMenuData(getMenuData());
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ const routerData = {};
|
|
|
+
|
|
|
+ Object.keys(routerConfig).forEach((path) => {
|
|
|
+
|
|
|
+
|
|
|
+ const pathRegexp = pathToRegexp(path);
|
|
|
+ const menuKey = Object.keys(menuData).find(key => pathRegexp.test(`${key}`));
|
|
|
+ let menuItem = {};
|
|
|
+
|
|
|
+ if (menuKey) {
|
|
|
+ menuItem = menuData[menuKey];
|
|
|
+ }
|
|
|
+ let router = routerConfig[path];
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ router = {
|
|
|
+ ...router,
|
|
|
+ name: router.name || menuItem.name,
|
|
|
+ authority: router.authority || menuItem.authority,
|
|
|
+ };
|
|
|
+ routerData[path] = router;
|
|
|
+ });
|
|
|
+ return routerData;
|
|
|
+};
|