index.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565
  1. import Vue from 'vue'
  2. import Router from 'vue-router'
  3. Vue.use(Router)
  4. /* Layout */
  5. import Layout from '@/layout'
  6. /**
  7. * Note: 路由配置项
  8. *
  9. * hidden: true // 当设置 true 的时候该路由不会再侧边栏出现 如401,login等页面,或者如一些编辑页面/edit/1
  10. * alwaysShow: true // 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面
  11. * // 只有一个时,会将那个子路由当做根路由显示在侧边栏--如引导页面
  12. * // 若你想不管路由下面的 children 声明的个数都显示你的根路由
  13. * // 你可以设置 alwaysShow: true,这样它就会忽略之前定义的规则,一直显示根路由
  14. * redirect: noRedirect // 当设置 noRedirect 的时候该路由在面包屑导航中不可被点击
  15. * name:'router-name' // 设定路由的名字,一定要填写不然使用<keep-alive>时会出现各种问题
  16. * query: '{"id": 1, "name": "ry"}' // 访问路由的默认传递参数
  17. * roles: ['admin', 'common'] // 访问路由的角色权限
  18. * permissions: ['a:a:a', 'b:b:b'] // 访问路由的菜单权限
  19. * meta : {
  20. noCache: true // 如果设置为true,则不会被 <keep-alive> 缓存(默认 false)
  21. title: 'title' // 设置该路由在侧边栏和面包屑中展示的名字
  22. icon: 'svg-name' // 设置该路由的图标,对应路径src/assets/icons/svg
  23. breadcrumb: false // 如果设置为false,则不会在breadcrumb面包屑中显示
  24. activeMenu: '/system/user' // 当路由设置了该属性,则会高亮相对应的侧边栏。
  25. }
  26. */
  27. // 公共路由
  28. export const constantRoutes = [{
  29. path: '/redirect',
  30. component: Layout,
  31. hidden: true,
  32. children: [{
  33. path: '/redirect/:path(.*)',
  34. component: () => import('@/views/redirect')
  35. }]
  36. },
  37. {
  38. path: '/login',
  39. component: () => import('@/views/login'),
  40. hidden: true
  41. },
  42. {
  43. path: '/register',
  44. component: () => import('@/views/register'),
  45. hidden: true
  46. },
  47. {
  48. path: '/404',
  49. component: () => import('@/views/error/404'),
  50. hidden: true
  51. },
  52. {
  53. path: '/401',
  54. component: () => import('@/views/error/401'),
  55. hidden: true
  56. },
  57. {
  58. path: '',
  59. component: Layout,
  60. redirect: 'index',
  61. children: [{
  62. path: 'index',
  63. component: () => import('@/views/index'),
  64. name: 'Index',
  65. meta: {
  66. title: '首页',
  67. icon: 'home',
  68. affix: true
  69. }
  70. }]
  71. },
  72. {
  73. path: '/user',
  74. component: Layout,
  75. hidden: true,
  76. redirect: 'noredirect',
  77. children: [{
  78. path: 'profile',
  79. component: () => import('@/views/system/user/profile/index'),
  80. name: 'Profile',
  81. meta: {
  82. title: '个人中心',
  83. icon: 'user'
  84. }
  85. }]
  86. }
  87. ]
  88. // 动态路由,基于用户权限动态去加载
  89. export const dynamicRoutes = [{
  90. path: '/system/user-auth',
  91. component: Layout,
  92. hidden: true,
  93. permissions: ['system:user:edit'],
  94. children: [{
  95. path: 'role/:userId(\\d+)',
  96. component: () => import('@/views/system/user/authRole'),
  97. name: 'AuthRole',
  98. meta: {
  99. title: '分配角色',
  100. activeMenu: '/system/user'
  101. }
  102. }]
  103. },
  104. {
  105. path: '/system/role-auth',
  106. component: Layout,
  107. hidden: true,
  108. permissions: ['system:role:edit'],
  109. children: [{
  110. path: 'user/:roleId(\\d+)',
  111. component: () => import('@/views/system/role/authUser'),
  112. name: 'AuthUser',
  113. meta: {
  114. title: '分配用户',
  115. activeMenu: '/system/role'
  116. }
  117. }]
  118. },
  119. {
  120. path: '/system/dict-data',
  121. component: Layout,
  122. hidden: true,
  123. permissions: ['system:dict:list'],
  124. children: [{
  125. path: 'index/:dictId(\\d+)',
  126. component: () => import('@/views/system/dict/data'),
  127. name: 'Data',
  128. meta: {
  129. title: '字典数据',
  130. activeMenu: '/system/dict'
  131. }
  132. }]
  133. },
  134. {
  135. path: '/monitor/job-log',
  136. component: Layout,
  137. hidden: true,
  138. permissions: ['monitor:job:list'],
  139. children: [{
  140. path: 'index',
  141. component: () => import('@/views/monitor/job/log'),
  142. name: 'JobLog',
  143. meta: {
  144. title: '调度日志',
  145. activeMenu: '/monitor/job'
  146. }
  147. }]
  148. },
  149. {
  150. path: '/tool/gen-edit',
  151. component: Layout,
  152. hidden: true,
  153. permissions: ['tool:gen:edit'],
  154. children: [{
  155. path: 'index/:tableId(\\d+)',
  156. component: () => import('@/views/tool/gen/editTable'),
  157. name: 'GenEdit',
  158. meta: {
  159. title: '修改生成配置',
  160. activeMenu: '/tool/gen'
  161. }
  162. }]
  163. },
  164. // 内容管理
  165. // banner管理
  166. {
  167. path: '/content',
  168. component: Layout,
  169. hidden: true,
  170. permissions: ['content:banner:list'],
  171. children: [{
  172. path: 'banner/detail',
  173. component: () => import('@/views/content/banner/detail'),
  174. name: 'detail',
  175. meta: {
  176. title: 'Banner详情',
  177. activeMenu: '/content/banner'
  178. }
  179. }]
  180. },
  181. // 设备管理
  182. // 设备列表
  183. {
  184. path: '/device',
  185. component: Layout,
  186. hidden: true,
  187. permissions: ['device:list:list'],
  188. name: 'deviceList',
  189. children: [{
  190. path: 'list/detail',
  191. component: () => import('@/views/device/list/detail'),
  192. name: 'deviceListDetail',
  193. meta: {
  194. title: '设备详情',
  195. activeMenu: '/device/list'
  196. }
  197. }]
  198. },
  199. // 设备升级
  200. {
  201. path: '/device',
  202. component: Layout,
  203. hidden: true,
  204. permissions: ['device:version:list'],
  205. children: [{
  206. path: 'version/detail',
  207. component: () => import('@/views/device/version/detail'),
  208. name: 'deviceVersionDetail',
  209. meta: {
  210. title: '设备升级详情',
  211. activeMenu: '/device/version'
  212. }
  213. }]
  214. },
  215. // 设备文章
  216. {
  217. path: '/device',
  218. component: Layout,
  219. hidden: true,
  220. permissions: ['device:article:list'],
  221. name: 'article',
  222. children: [{
  223. path: 'article/detail',
  224. component: () => import('@/views/device/article/detail'),
  225. name: 'articleDetail',
  226. meta: {
  227. title: '文章详情',
  228. activeMenu: '/device/article'
  229. }
  230. }]
  231. },
  232. // 音频管理
  233. // 歌手
  234. {
  235. path: "/music",
  236. component: Layout,
  237. hidden: true,
  238. permissions: ['music:singer:list'],
  239. name: 'singer',
  240. children: [{
  241. path: 'singer/detail',
  242. component: () => import('@/views/music/singer/detail'),
  243. name: 'musicSingerDetail',
  244. meta: {
  245. title: `歌手详情`,
  246. activeMenu: '/music/singer'
  247. }
  248. }]
  249. },
  250. // 歌曲
  251. {
  252. path: '/music',
  253. component: Layout,
  254. hidden: true,
  255. permissions: ['music:list:list'],
  256. name: 'musicList',
  257. children: [{
  258. path: 'musicList/detail',
  259. component: () => import('@/views/music/list/detail'),
  260. name: 'musicListDetail',
  261. meta: {
  262. title: `歌曲详情`,
  263. activeMenu: '/music/musicList'
  264. }
  265. }]
  266. },
  267. // 歌单
  268. {
  269. path: '/music',
  270. component: Layout,
  271. hidden: true,
  272. permissions: ['music:menu:list'],
  273. name: 'musicMenu',
  274. children: [{
  275. path: 'menu/detail',
  276. component: () => import('@/views/music/menu/detail'),
  277. name: 'menu',
  278. meta: {
  279. title: `歌单详情`,
  280. activeMenu: '/music/musicMenu'
  281. }
  282. }]
  283. },
  284. // 音乐专辑
  285. {
  286. path: '/music',
  287. component: Layout,
  288. hidden: true,
  289. permissions: ['music:album:list'],
  290. name: 'album',
  291. children: [{
  292. path: 'album/detail',
  293. component: () => import('@/views/music/album/detail'),
  294. name: 'albumDetail',
  295. meta: {
  296. title: '专辑详情',
  297. activeMenu: '/music/album'
  298. }
  299. }]
  300. },
  301. // 播客专辑
  302. {
  303. path: '/music',
  304. component: Layout,
  305. hidden: true,
  306. permissions: ['music:blog:list'],
  307. name: 'blog',
  308. children: [{
  309. path: 'blog/detail',
  310. component: () => import('@/views/music/blog/detail'),
  311. name: 'blogDetail',
  312. meta: {
  313. title: `播客详情`,
  314. activeMenu: '/music/blog'
  315. }
  316. }]
  317. },
  318. // 节目
  319. {
  320. path: '/music',
  321. component: Layout,
  322. hidden: true,
  323. permissions: ['music:program:list'],
  324. name: 'program',
  325. children: [{
  326. path: 'program/detail',
  327. component: () => import('@/views/music/program/detail'),
  328. name: 'programDetail',
  329. meta: {
  330. title: `节目详情`,
  331. activeMenu: '/music/program'
  332. }
  333. }]
  334. },
  335. // 主播
  336. {
  337. path: '/music',
  338. component: Layout,
  339. hidden: true,
  340. permissions: ['music:anchor:list'],
  341. name: 'anchor',
  342. children: [{
  343. path: 'anchor/detail',
  344. component: () => import('@/views/music/anchor/detail'),
  345. name: 'anchorDetail',
  346. meta: {
  347. title: '主播详情',
  348. activeMenu: '/music/anchor'
  349. }
  350. }]
  351. },
  352. // 广播电台
  353. {
  354. path: '/music',
  355. component: Layout,
  356. hidden: true,
  357. permissions: ['music:radio:list'],
  358. name: 'radio',
  359. children: [{
  360. path: 'radio/detail',
  361. component: () => import('@/views/music/radio/detail'),
  362. name: 'radioDetail',
  363. meta: {
  364. title: `电台详情`,
  365. activeMenu: '/music/radio'
  366. }
  367. }]
  368. },
  369. // 猫王精选电台
  370. {
  371. path: '/music',
  372. component: Layout,
  373. hidden: true,
  374. permissions: ['music:choiceness:list'],
  375. name: 'choiceness',
  376. children: [{
  377. path: 'choiceness/detail',
  378. component: () => import('@/views/music/choiceness/detail'),
  379. name: 'choicenessDetail',
  380. meta: {
  381. title: '猫王精选详情',
  382. activeMenu: '/music/choiceness'
  383. }
  384. }]
  385. },
  386. // 项目管理
  387. // 项目列表
  388. {
  389. path: '/project',
  390. component: Layout,
  391. hidden: true,
  392. permissions: ['project:list:list'],
  393. children: [{
  394. path: 'projectList/detail',
  395. component: () => import('@/views/project/list/detail'),
  396. name: 'projectListDetail',
  397. meta: {
  398. title: `项目详情`,
  399. activeMenu: '/project/projectList'
  400. }
  401. }]
  402. },
  403. // 运营管理
  404. // 启动页
  405. {
  406. path: '/operation',
  407. component: Layout,
  408. hidden: true,
  409. permissions: ['operation:startPage:list'],
  410. children: [{
  411. path: 'startPage/detail',
  412. component: () => import('@/views/operation/startPage/detail'),
  413. name: 'startPageDetail',
  414. meta: {
  415. title: '启动页详情',
  416. activeMenu: '/operation/startPage'
  417. }
  418. }]
  419. },
  420. // 定制频道
  421. {
  422. path: '/operation',
  423. component: Layout,
  424. hidden: true,
  425. permissions: ['operation:channel:list'],
  426. name: 'channel',
  427. children: [{
  428. path: 'channel/detail',
  429. component: () => import('@/views/operation/channel/detail'),
  430. name: 'channelDetail',
  431. meta: {
  432. title: `频道详情`,
  433. activeMenu: '/operation/channel'
  434. }
  435. }]
  436. },
  437. // 标签分类
  438. {
  439. path: '/operation',
  440. component: Layout,
  441. hidden: true,
  442. permissions: ['operation:tag:list'],
  443. name: 'tag',
  444. children: [{
  445. path: 'tag/detail',
  446. component: () => import('@/views/operation/tag/detail'),
  447. name: 'tagDetail',
  448. meta: {
  449. title: '标签详情',
  450. activeMenu: '/operation/tag'
  451. }
  452. }]
  453. },
  454. // 唤醒音
  455. {
  456. path: '/operation',
  457. component: Layout,
  458. hidden: true,
  459. permissions: ['operation:waken:list'],
  460. name: 'waken',
  461. children: [{
  462. path: 'waken/detail',
  463. component: () => import('@/views/operation/waken/detail'),
  464. name: 'wakenDetail',
  465. meta: {
  466. title: '唤醒音详情',
  467. activeMenu: '/operation/waken'
  468. }
  469. }]
  470. },
  471. // 商品管理
  472. // 商品推荐
  473. {
  474. path: '/goods',
  475. component: Layout,
  476. hidden: true,
  477. permissions: ['goods:list:list'],
  478. children: [{
  479. path: 'goodsList/detail',
  480. component: () => import('@/views/goods/list/detail'),
  481. name: 'goodsListDetail',
  482. meta: {
  483. title: '商品详情',
  484. activeMenu: '/goods/goodsList'
  485. }
  486. }]
  487. },
  488. // 服务管理
  489. // 音乐套餐 / 流量套餐
  490. {
  491. path: '/service',
  492. component: Layout,
  493. hidden: true,
  494. permissions: ['service:package:list'],
  495. children: [{
  496. path: 'package/detail',
  497. component: () => import('@/views/service/package/detail'),
  498. name: 'packageDetail',
  499. meta: {
  500. title: '套餐详情'
  501. }
  502. }]
  503. },
  504. // 签到管理
  505. // 抽奖配置
  506. {
  507. path: '/registration',
  508. component: Layout,
  509. hidden: true,
  510. permissions: ['registration:lotteryConfig:list'],
  511. children: [{
  512. path: 'lotteryConfig/detail',
  513. component: () => import('@/views/registration/lottery/detail'),
  514. name: 'lotteryConfigDetail',
  515. meta: {
  516. title: '配置详情',
  517. activeMenu: '/registration/lotteryConfig'
  518. }
  519. }]
  520. },
  521. // 内容配置
  522. {
  523. path: '/registration',
  524. component: Layout,
  525. hidden: true,
  526. permissions: ['registration:contentConfig:list'],
  527. children: [{
  528. path: 'contentConfig/detail',
  529. component: () => import('@/views/registration/content/detail'),
  530. name: 'contentConfigDetail',
  531. meta: {
  532. title: '配置详情',
  533. activeMenu: '/registration/contentConfig'
  534. }
  535. }]
  536. },
  537. // 兑换配置
  538. {
  539. path: '/registration',
  540. component: Layout,
  541. hidden: true,
  542. permissions: ['registration:exchangeConfig:list'],
  543. children: [{
  544. path: 'exchangeConfig/detail',
  545. component: () => import('@/views/registration/exchange/detail'),
  546. name: 'exchangeConfigDetail',
  547. meta: {
  548. title: '配置详情',
  549. activeMenu: '/registration/exchangeConfig'
  550. }
  551. }]
  552. }
  553. ]
  554. export default new Router({
  555. mode: 'history', // 去掉url中的#
  556. scrollBehavior: () => ({
  557. y: 0
  558. }),
  559. routes: constantRoutes
  560. })