router.js 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. import React from 'react';
  2. import dynamic from 'dva/dynamic';
  3. import { getMenuData } from './menu';
  4. // wrapper of dynamic
  5. const dynamicWrapper = (app, models, component) => dynamic({
  6. app,
  7. // eslint-disable-next-line no-underscore-dangle
  8. models: () => models.filter(m => !app._models.some(({ namespace }) => namespace === m)).map(m => import(`../models/${m}.js`)),
  9. // add routerData prop
  10. component: () => {
  11. const p = component();
  12. return new Promise((resolve, reject) => {
  13. p.then((Comp) => {
  14. resolve(props => <Comp {...props} routerData={getRouterData(app)} />);
  15. }).catch(err => reject(err));
  16. });
  17. },
  18. });
  19. function getFlatMenuData(menus) {
  20. let keys = {};
  21. menus.forEach((item) => {
  22. if (item.children) {
  23. keys[item.path] = item.name;
  24. keys = { ...keys, ...getFlatMenuData(item.children) };
  25. } else {
  26. keys[item.path] = item.name;
  27. }
  28. });
  29. return keys;
  30. }
  31. export const getRouterData = (app) => {
  32. const routerData = {
  33. '/': {
  34. component: dynamicWrapper(app, ['user', 'login'], () => import('../layouts/BasicLayout')),
  35. },
  36. // '/help': {
  37. // component: dynamicWrapper(app, [], () => import('../routes/About')),
  38. // },
  39. '/dashboard': {
  40. component: dynamicWrapper(app, [], () => import('../routes/Dashboard')),
  41. },
  42. '/resource/gallery': {
  43. component: dynamicWrapper(app, ['resource'], () => import('../routes/Resource/gallery')),
  44. },
  45. '/resource/video': {
  46. component: dynamicWrapper(app, ['resource'], () => import('../routes/Resource/video')),
  47. },
  48. '/terminal/campus': {
  49. component: dynamicWrapper(app, ['campus', 'merchant/merchant'], () => import('../routes/Campus')),
  50. },
  51. '/terminal/user': {
  52. component: dynamicWrapper(app, ['terminal/terminal'], () => import('../routes/Terminal/List')),
  53. },
  54. '/terminal/user/add': {
  55. component: dynamicWrapper(app, ['terminal/detail', 'campus'], () => import('../routes/Terminal/Edit')),
  56. name: '添加终端',
  57. },
  58. '/terminal/user/edit/:id': {
  59. component: dynamicWrapper(app, ['terminal/detail', 'campus'], () => import('../routes/Terminal/Edit')),
  60. name: '编辑终端',
  61. },
  62. '/merchant': {
  63. component: dynamicWrapper(app, ['merchant/merchant'], () => import('../routes/Merchant/List')),
  64. },
  65. '/merchant/add': {
  66. component: dynamicWrapper(app, ['merchant/detail', 'mproduct/mproduct'], () => import('../routes/Merchant/Edit')),
  67. name: '添加厂商',
  68. },
  69. '/merchant/edit/:id': {
  70. component: dynamicWrapper(app, ['merchant/detail', 'mproduct/mproduct'], () => import('../routes/Merchant/Edit')),
  71. name: '编辑厂商',
  72. },
  73. '/tag/tagGroup': {
  74. component: dynamicWrapper(app, ['group/group', 'merchant/merchant'], () => import('../routes/TagGroup/List')),
  75. },
  76. '/tag/tagGroup/add': {
  77. component: dynamicWrapper(app, ['group/detail', 'merchant/merchant'], () => import('../routes/TagGroup/Edit')),
  78. name: '创建标签组',
  79. },
  80. '/tag/tagGroup/edit/:id': {
  81. component: dynamicWrapper(app, ['group/detail', 'merchant/merchant'], () => import('../routes/TagGroup/Edit')),
  82. name: '修改标签组',
  83. },
  84. '/tag/tagItem': {
  85. component: dynamicWrapper(app, ['tag/tag', 'merchant/merchant'], () => import('../routes/Tag/List')),
  86. },
  87. '/tag/tagItem/add': {
  88. component: dynamicWrapper(app, ['tag/detail', 'group/group'], () => import('../routes/Tag/Edit')),
  89. name: '创建标签',
  90. },
  91. '/tag/tagItem/edit/:id': {
  92. component: dynamicWrapper(app, ['tag/detail', 'group/group'], () => import('../routes/Tag/Edit')),
  93. name: '修改标签',
  94. },
  95. '/basic-product/ware': {
  96. component: dynamicWrapper(app, ['ware/ware'], () => import('../routes/Ware/List')),
  97. },
  98. '/basic-product/ware/add': {
  99. component: dynamicWrapper(app, ['ware/detail', 'resource'], () => import('../routes/Ware/Edit')),
  100. name: '创建课件',
  101. },
  102. '/basic-product/ware/edit/:id': {
  103. component: dynamicWrapper(app, ['ware/detail', 'resource'], () => import('../routes/Ware/Edit')),
  104. name: '修改课件',
  105. },
  106. '/basic-product/lesson': {
  107. component: dynamicWrapper(app, ['lesson/lesson'], () => import('../routes/Lesson/List')),
  108. },
  109. '/basic-product/lesson/add': {
  110. component: dynamicWrapper(app, ['lesson/detail', 'ware/ware'], () => import('../routes/Lesson/Edit')),
  111. name: '创建课',
  112. },
  113. '/basic-product/lesson/edit/:id': {
  114. component: dynamicWrapper(app, ['lesson/detail', 'ware/ware'], () => import('../routes/Lesson/Edit')),
  115. name: '修改课',
  116. },
  117. '/product/course': {
  118. component: dynamicWrapper(app, ['course/course'], () => import('../routes/Course/List')),
  119. },
  120. '/product/course/add': {
  121. component: dynamicWrapper(app, ['course/detail', 'resource', 'lesson/lesson', 'support/support', 'merchant/merchant'], () => import('../routes/Course/Edit')),
  122. name: '创建课程',
  123. },
  124. '/product/course/edit/:id': {
  125. component: dynamicWrapper(app, ['course/detail', 'resource', 'lesson/lesson', 'support/support', 'merchant/merchant'], () => import('../routes/Course/Edit')),
  126. name: '修改课程',
  127. },
  128. '/product/support': {
  129. component: dynamicWrapper(app, ['support/support'], () => import('../routes/Support/List')),
  130. },
  131. '/product/support/add': {
  132. component: dynamicWrapper(app, ['support/detail', 'resource', 'support/support', 'merchant/merchant'], () => import('../routes/Support/Edit')),
  133. name: '创建配套',
  134. },
  135. '/product/support/edit/:id': {
  136. component: dynamicWrapper(app, ['support/detail', 'resource', 'support/support', 'merchant/merchant'], () => import('../routes/Support/Edit')),
  137. name: '修改配套',
  138. },
  139. '/product/package': {
  140. component: dynamicWrapper(app, ['combo/combo'], () => import('../routes/Combo/List')),
  141. },
  142. '/product/package/add': {
  143. component: dynamicWrapper(app, ['combo/detail', 'product'], () => import('../routes/Combo/Edit')),
  144. name: '创建课程包',
  145. },
  146. '/product/package/edit/:id': {
  147. component: dynamicWrapper(app, ['combo/detail', 'product'], () => import('../routes/Combo/Edit')),
  148. name: '修改课程包',
  149. },
  150. '/goods': {
  151. component: dynamicWrapper(app, ['mproduct/mproduct', 'merchant/merchant'], () => import('../routes/MProduct/List')),
  152. },
  153. '/goods/add': {
  154. component: dynamicWrapper(app, ['course/course', 'support/support', 'combo/combo', 'merchant/merchant', 'mproduct/detail'], () => import('../routes/MProduct/Add')),
  155. name: '创建商品',
  156. },
  157. '/goods/edit': {
  158. component: dynamicWrapper(app, ['mproduct/detail', 'goods', 'tag/tag'], () => import('../routes/MProduct/Edit')),
  159. name: '修改商品',
  160. },
  161. '/order': {
  162. component: dynamicWrapper(app, ['order/order'], () => import('../routes/Order/List')),
  163. },
  164. '/order/add': {
  165. component: dynamicWrapper(app, ['order/detail', 'terminal/terminal', 'mproduct/mproduct'], () => import('../routes/Order/Add')),
  166. name: '新建订单',
  167. },
  168. // '/order/edit/:id': {
  169. // component: dynamicWrapper(app, ['order/detail'], () => import('../routes/Order/detail')),
  170. // name: '修改订单',
  171. // },
  172. // '/order/profile/:id': {
  173. // component: dynamicWrapper(app, ['order/detail'], () => import('../routes/Order/detail/orderProfile')),
  174. // name: '订单详情',
  175. // },
  176. '/sold': {
  177. component: dynamicWrapper(app, [], () => import('../routes/SoldProduct')),
  178. },
  179. '/user': {
  180. component: dynamicWrapper(app, [], () => import('../layouts/UserLayout')),
  181. },
  182. '/user/login': {
  183. component: dynamicWrapper(app, ['login'], () => import('../routes/Login')),
  184. },
  185. '/cms/user': {
  186. component: dynamicWrapper(app, ['cmsUser', 'merchant/merchant'], () => import('../routes/CmsUser')),
  187. },
  188. };
  189. // Get name from ./menu.js or just set it in the router data.
  190. const menuData = getFlatMenuData(getMenuData());
  191. const routerDataWithName = {};
  192. Object.keys(routerData).forEach((item) => {
  193. routerDataWithName[item] = {
  194. ...routerData[item],
  195. name: routerData[item].name || menuData[item.replace(/^\//, '')],
  196. };
  197. });
  198. return routerDataWithName;
  199. };