main.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. import Vue from 'vue';
  2. import VueRouter from 'vue-router';
  3. import App from './App.vue';
  4. import auth from './auth';
  5. import io from './io';
  6. import NotFound from './components/404.vue';
  7. import Home from './components/pages/Home.vue';
  8. import Station from './components/Station/Station.vue';
  9. import Admin from './components/pages/Admin.vue';
  10. import News from './components/pages/News.vue';
  11. import About from './components/pages/About.vue';
  12. import Terms from './components/pages/Terms.vue';
  13. import Privacy from './components/pages/Privacy.vue';
  14. import Team from './components/pages/Team.vue';
  15. import User from './components/User/Show.vue';
  16. import Settings from './components/User/Settings.vue';
  17. import ResetPassword from './components/User/ResetPassword.vue';
  18. import Login from './components/Modals/Login.vue';
  19. Vue.use(VueRouter);
  20. let router = new VueRouter({ history: true });
  21. let _this = this;
  22. lofig.folder = '../config/default.json';
  23. lofig.get('serverDomain', function(res) {
  24. io.init(res);
  25. io.getSocket((socket) => {
  26. socket.on("ready", (status, role, username, userId) => {
  27. auth.data(status, role, username, userId);
  28. });
  29. });
  30. });
  31. document.onkeydown = event => {
  32. event = event || window.event;
  33. if (event.keyCode === 27) router.app.$dispatch('closeModal');
  34. };
  35. router.beforeEach(transition => {
  36. window.location.hash = '';
  37. if (window.stationInterval) {
  38. clearInterval(window.stationInterval);
  39. window.stationInterval = 0;
  40. }
  41. if (window.socket) {
  42. io.removeAllListeners();
  43. }
  44. io.clear();
  45. if (transition.to.loginRequired || transition.to.adminRequired) {
  46. auth.getStatus((authenticated, role) => {
  47. if (transition.to.loginRequired && !authenticated) transition.redirect('/login');
  48. else if (transition.to.adminRequired && role !== 'admin') transition.redirect('/');
  49. else transition.next();
  50. });
  51. } else {
  52. transition.next();
  53. }
  54. });
  55. router.map({
  56. '/': {
  57. component: Home
  58. },
  59. '*': {
  60. component: NotFound
  61. },
  62. '404': {
  63. component: NotFound
  64. },
  65. '/terms': {
  66. component: Terms
  67. },
  68. '/privacy': {
  69. component: Privacy
  70. },
  71. '/team': {
  72. component: Team
  73. },
  74. '/news': {
  75. component: News
  76. },
  77. '/about': {
  78. component: About
  79. },
  80. '/u/:username': {
  81. component: User
  82. },
  83. '/settings': {
  84. component: Settings,
  85. loginRequired: true
  86. },
  87. '/reset_password': {
  88. component: ResetPassword
  89. },
  90. '/login': {
  91. component: Login
  92. },
  93. '/admin': {
  94. component: Admin,
  95. adminRequired: true
  96. },
  97. '/official/:id': {
  98. component: Station
  99. },
  100. '/:id': {
  101. component: Station
  102. },
  103. '/community/:id': {
  104. component: Station
  105. }
  106. });
  107. router.start(App, 'body');