main.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. import Vue from 'vue';
  2. import VueRouter from 'vue-router';
  3. import App from './App.vue';
  4. import auth from './auth';
  5. import NotFound from './components/404.vue';
  6. import Home from './components/pages/Home.vue';
  7. import Station from './components/Station/Station.vue';
  8. import Admin from './components/pages/Admin.vue';
  9. import News from './components/pages/News.vue';
  10. import User from './components/User/Show.vue';
  11. import Settings from './components/User/Settings.vue';
  12. Vue.use(VueRouter);
  13. let router = new VueRouter({ history: true });
  14. let _this = this;
  15. lofig.folder = '../config/default.json';
  16. lofig.get('socket.url', function(res) {
  17. let socket = window.socket = io(window.location.protocol + '//' + res);
  18. socket.on("ready", (status, role) => {
  19. auth.data(status, role);
  20. });
  21. });
  22. router.beforeEach((transition) => {
  23. if (transition.to.loginRequired || transition.to.adminRequired) {
  24. auth.getStatus((authenticated, role) => {
  25. if (transition.to.loginRequired && !authenticated) {
  26. transition.redirect('/login')
  27. } else if (transition.to.adminRequired && role !== 'admin') {
  28. transition.redirect('/adminRequired');
  29. } else {
  30. transition.next();
  31. }
  32. });
  33. } else {
  34. transition.next()
  35. }
  36. });
  37. router.map({
  38. '/': {
  39. component: Home
  40. },
  41. '*': {
  42. component: NotFound
  43. },
  44. '/news': {
  45. component: News
  46. },
  47. '/u/:username': {
  48. component: User
  49. },
  50. '/settings': {
  51. component: Settings,
  52. loginRequired: true
  53. },
  54. '/admin': {
  55. component: Admin,
  56. adminRequired: true
  57. },
  58. '/official/:id': {
  59. component: Station
  60. },
  61. '/community/:id': {
  62. component: Station
  63. }
  64. });
  65. router.start(App, 'body');