index.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449
  1. import Vue from 'vue'
  2. import VueRouter from 'vue-router'
  3. // import checkPower from '@/utils/check-power.vue'
  4. Vue.use(VueRouter)
  5. const routes = [
  6. {
  7. path: '/',
  8. name: 'Index',
  9. component: () => import('@/layout/index.vue'),
  10. meta: { title: 'HerTube' },
  11. children: [
  12. {
  13. path: '/',
  14. name: 'Home',
  15. component: () => import('@/views/home/index.vue'),
  16. meta: { title: 'HerTube' }
  17. },
  18. {
  19. path: '/studio',
  20. name: 'Studio',
  21. component: () => import('@/views/studio/index.vue'),
  22. meta: { title: 'Studio' },
  23. children: [
  24. {
  25. path: '/studio',
  26. name: 'Post',
  27. component: () => import('@/views/studio/post.vue'),
  28. meta: {
  29. title: '稿件列表',
  30. requireAuth: true
  31. }
  32. },
  33. {
  34. path: '/studio/upload',
  35. name: 'Upload',
  36. component: () => import('@/views/studio/upload.vue'),
  37. meta: {
  38. title: '投稿',
  39. requireAuth: true
  40. }
  41. },
  42. {
  43. path: '/studio/statistics',
  44. name: 'Statisticss',
  45. component: () => import('@/views/studio/statistics.vue'),
  46. meta: {
  47. title: '数据统计',
  48. requireAuth: true
  49. }
  50. },
  51. {
  52. path: '/studio/comment',
  53. name: 'Comment',
  54. component: () => import('@/views/studio/comment.vue'),
  55. meta: {
  56. title: '评论',
  57. requireAuth: true
  58. }
  59. },
  60. {
  61. path: '/studio/admin/invitation',
  62. name: 'invitation',
  63. component: () => import('@/views/admin/invitation.vue'),
  64. meta: {
  65. title: '邀请码',
  66. requireAuth: true
  67. }
  68. },
  69. {
  70. path: '/studio/admin/examine',
  71. name: 'Examine',
  72. component: () => import('@/views/admin/examine.vue'),
  73. meta: {
  74. title: '审核视频',
  75. requireAuth: true
  76. }
  77. },
  78. {
  79. path: '/studio/admin/userlist',
  80. name: 'Examine',
  81. component: () => import('@/views/admin/user-list.vue'),
  82. meta: {
  83. title: '用户列表',
  84. requireAuth: true
  85. }
  86. },
  87. {
  88. path: '/studio/admin/websetting',
  89. name: 'Examine',
  90. component: () => import('@/views/admin/web-setting.vue'),
  91. meta: {
  92. title: '网页设置',
  93. requireAuth: true
  94. }
  95. },
  96. {
  97. path: '/studio/admin/category',
  98. name: 'Examine',
  99. component: () => import('@/views/admin/category.vue'),
  100. meta: {
  101. title: '分区设置',
  102. requireAuth: true
  103. }
  104. }
  105. ]
  106. },
  107. {
  108. path: '/u/:userId',
  109. name: 'UserHome',
  110. component: () => import('@/views/user/home.vue'),
  111. meta: { title: '用户主页' }
  112. },
  113. {
  114. path: '/user',
  115. name: 'UserCenter',
  116. component: () => import('@/views/user/userindex.vue'),
  117. meta: {
  118. title: '个人中心',
  119. requireAuth: true
  120. },
  121. children: [
  122. {
  123. path: '/user/home',
  124. name: 'UserHome',
  125. component: () => import('@/views/user/home.vue'),
  126. meta: {
  127. title: '个人中心',
  128. requireAuth: true
  129. }
  130. },
  131. {
  132. path: '/user/setting',
  133. name: 'UserSetting',
  134. component: () => import('@/views/user/setting.vue'),
  135. meta: {
  136. title: '账户设置',
  137. requireAuth: true
  138. }
  139. },
  140. {
  141. path: '/user/favlist',
  142. name: 'UserFavlist',
  143. component: () => import('@/views/user/favlist.vue'),
  144. meta: { title: '收藏列表',
  145. requireAuth: true }
  146. },
  147. {
  148. path: '/user/playlist',
  149. name: 'UserPlaylist',
  150. component: () => import('@/views/user/playlist.vue'),
  151. meta: { title: '稍后再看',
  152. requireAuth: true }
  153. },
  154. {
  155. path: '/user/hislist',
  156. name: 'UserHislist',
  157. component: () => import('@/views/user/hislist.vue'),
  158. meta: { title: '历史记录',
  159. requireAuth: true }
  160. },
  161. {
  162. path: '/user/follow',
  163. name: 'UserFollow',
  164. component: () => import('@/views/user/follow.vue'),
  165. meta: { title: '关注管理',
  166. requireAuth: true }
  167. },
  168. {
  169. path: '/user/vip',
  170. name: 'UserVip',
  171. component: () => import('@/views/user/vip.vue'),
  172. meta: { title: '小会员',
  173. requireAuth: true }
  174. },
  175. {
  176. path: '/user/loginhistory',
  177. name: 'LoginHistory',
  178. component: () => import('@/views/user/LoginHistory.vue'),
  179. meta: { title: '登录历史',
  180. requireAuth: true }
  181. }
  182. ]
  183. },
  184. /*
  185. {
  186. path: '/user',
  187. name: 'User',
  188. component: () => import('@/views/user/index.vue')
  189. },
  190. {
  191. path: '/user/studio',
  192. name: 'StudioIndex',
  193. component: () => import('@/views/studio/index.vue'),
  194. meta: {
  195. title: '个人中心',
  196. requireAuth: true
  197. }
  198. },
  199. {
  200. path: '/user/upload',
  201. name: 'Upload',
  202. component: () => import('@/views/studio/upload.vue'),
  203. meta: {
  204. title: '投稿',
  205. requireAuth: true
  206. }
  207. },
  208. {
  209. path: '/user/post',
  210. name: 'Post',
  211. component: () => import('@/views/studio/post.vue'),
  212. meta: {
  213. title: '稿件列表',
  214. requireAuth: true
  215. }
  216. },
  217. {
  218. path: '/user/comment',
  219. name: 'Comment',
  220. component: () => import('@/views/studio/comment.vue'),
  221. meta: {
  222. title: '评论',
  223. requireAuth: true
  224. }
  225. },
  226. {
  227. path: '/user/admin/invitation',
  228. name: 'invitation',
  229. component: () => import('@/views/admin/invitation.vue'),
  230. meta: {
  231. title: '邀请码',
  232. requireAuth: true
  233. }
  234. },
  235. {
  236. path: '/user/admin/examine',
  237. name: 'Examine',
  238. component: () => import('@/views/admin/examine.vue'),
  239. meta: {
  240. title: '审核视频',
  241. requireAuth: true
  242. }
  243. },
  244. {
  245. path: '/user/admin/userlist',
  246. name: 'Examine',
  247. component: () => import('@/views/admin/user-list.vue'),
  248. meta: {
  249. title: '用户列表',
  250. requireAuth: true
  251. }
  252. },
  253. {
  254. path: '/user/admin/websetting',
  255. name: 'Examine',
  256. component: () => import('@/views/admin/web-setting.vue'),
  257. meta: {
  258. title: '网页设置',
  259. requireAuth: true
  260. }
  261. },
  262. {
  263. path: '/user/admin/category',
  264. name: 'Examine',
  265. component: () => import('@/views/admin/category.vue'),
  266. meta: {
  267. title: '分区设置',
  268. requireAuth: true
  269. }
  270. }*/
  271. {
  272. path: '/message',
  273. name: 'Message',
  274. component: () => import('@/views/message/index.vue'),
  275. meta: { title: 'Message' },
  276. children: [
  277. {
  278. path: '/message',
  279. name: 'Message',
  280. component: () => import('@/views/message/home.vue'),
  281. meta: { title: '消息主页' }
  282. },
  283. {
  284. path: '/message/setting',
  285. name: 'MessageSetting',
  286. component: () => import('@/views/message/setting.vue'),
  287. meta: { title: '消息设置' }
  288. }
  289. ]
  290. },
  291. {
  292. path: '/live',
  293. name: 'Live',
  294. component: () => import('@/views/home/live.vue'),
  295. meta: { title: 'HerTube 直播' }
  296. },
  297. {
  298. path: '/channel',
  299. name: 'Channel',
  300. component: () => import('@/views/home/channel.vue'),
  301. meta: { title: 'HerTube 分区' }
  302. },
  303. {
  304. path: '/mblog',
  305. name: 'Mblog',
  306. component: () => import('@/views/home/mblog.vue'),
  307. meta: { title: 'HerTube 状态' }
  308. },
  309. {
  310. path: '/zhihu',
  311. name: 'Zhihu',
  312. component: () => import('@/views/home/zhihu.vue'),
  313. meta: { title: 'HerTube 知乎' }
  314. },
  315. {
  316. path: '/playlist',
  317. name: 'Playlist',
  318. component: () => import('@/views/home/playlist.vue'),
  319. meta: { title: 'HerTube 稍后再看' }
  320. },
  321. {
  322. path: '/search/result',
  323. name: 'SearchResult',
  324. component: () => import('@/views/home/search-result.vue'),
  325. meta: { title: 'HerTube 搜索结果' }
  326. },
  327. {
  328. path: '/video/:id',
  329. name: 'Vide',
  330. component: () => import('@/views/video/video.vue'),
  331. meta: { title: '播放' }
  332. },
  333. {
  334. path: '/vip',
  335. name: 'VIP',
  336. component: () => import('@/views/vip/index.vue'),
  337. meta: {
  338. title: 'VIP'
  339. }
  340. },
  341. {
  342. path: '/vip/pay',
  343. name: 'VipPay',
  344. component: () => import('@/views/vip/pay.vue'),
  345. meta: {
  346. title: 'VIP'
  347. }
  348. },
  349. {
  350. path: '/live',
  351. name: 'live',
  352. component: () => import('@/views/live/index.vue'),
  353. meta: { title: '直播1' }
  354. }
  355. ]
  356. },
  357. {
  358. path: '/login',
  359. name: 'Login',
  360. component: () => import('@/views/login.vue'),
  361. meta: {
  362. title: '登录'
  363. }
  364. },
  365. {
  366. path: '*',
  367. name: '404',
  368. component: () => import('@/views/404.vue'),
  369. meta: {
  370. title: '404'
  371. }
  372. }
  373. ]
  374. const router = new VueRouter({
  375. mode: 'history',
  376. routes
  377. })
  378. // 路由导航守卫
  379. router.beforeEach((to, from, next) => {
  380. // const token = window.localStorage.getItem('user')
  381. // console.log(this.$store.state.webInfo.name)
  382. // router.app.$options.store
  383. // 获取网页信息
  384. /*
  385. // TODO 网站信息暂时不从后端获取
  386. if (router.app.$options.store.state.webInfo.name == null) {
  387. fetch(`/api/media/web/info`, {
  388. headers: {
  389. 'Content-Type': 'application/json; charset=UTF-8'
  390. },
  391. method: 'GET',
  392. credentials: 'include'
  393. }).then(response => response.json())
  394. .then(json => {
  395. router.app.$options.store.state.webInfo = json.data
  396. })
  397. .catch(e => {
  398. return null
  399. })
  400. }*/
  401. // 路由发生变化修改页面 title
  402. if (to.meta.title) {
  403. document.title = to.meta.title
  404. }
  405. const vuexStore = router.app.$options.store
  406. // router.app.$options.store 就是 this.$store
  407. /* if (checkPower.updateUserRole(vuexStore.state.user.userInfo)) {
  408. vuexStore.state.user.userInfo.role = 'ROLE_USER'
  409. vuexStore.commit('SET_USER_INFO', vuexStore.state.user.userInfo)
  410. }*/
  411. // const date = new Date().getTime()
  412. if (vuexStore.state.user.userInfo != null) {
  413. if (to.path === '/login') {
  414. return next({ path: '/' })
  415. }
  416. return next()
  417. // TODO 不判断用户是否过期
  418. /* if (vuexStore.state.user.userInfo.expireTime > date) {
  419. if (to.path === '/login') {
  420. return next({ path: '/' })
  421. }
  422. return next()
  423. } else {
  424. vuexStore.commit('user/SET_USER_INFO', null)
  425. return next({
  426. path: '/login',
  427. query: { redirect: to.fullPath }
  428. })
  429. }*/
  430. } else {
  431. if (to.meta.requireAuth) {
  432. return next({
  433. path: '/login',
  434. query: { redirect: to.fullPath }
  435. })
  436. } else {
  437. return next()
  438. }
  439. }
  440. })
  441. export default router