main.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  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 AdminNews from './components/Admin/News.vue';
  11. import AdminUsers from './components/Admin/Users.vue';
  12. import AdminReports from './components/Admin/Reports.vue';
  13. import AdminStations from './components/Admin/Stations.vue';
  14. import AdminSongs from './components/Admin/Songs.vue';
  15. import AdminQueueSongs from './components/Admin/QueueSongs.vue';
  16. import News from './components/pages/News.vue';
  17. import About from './components/pages/About.vue';
  18. import Terms from './components/pages/Terms.vue';
  19. import Privacy from './components/pages/Privacy.vue';
  20. import Team from './components/pages/Team.vue';
  21. import User from './components/User/Show.vue';
  22. import Settings from './components/User/Settings.vue';
  23. import ResetPassword from './components/User/ResetPassword.vue';
  24. import Login from './components/Modals/Login.vue';
  25. import Register from './components/Modals/Register.vue';
  26. Vue.use(VueRouter);
  27. let router = new VueRouter({ history: true });
  28. let _this = this;
  29. lofig.folder = '../config/default.json';
  30. lofig.get('serverDomain', function(res) {
  31. io.init(res);
  32. io.getSocket((socket) => {
  33. socket.on("ready", (status, role, username, userId) => {
  34. auth.data(status, role, username, userId);
  35. });
  36. });
  37. });
  38. document.onkeydown = event => {
  39. event = event || window.event;
  40. if (event.keyCode === 27) router.app.$dispatch('closeModal');
  41. };
  42. router.beforeEach(transition => {
  43. window.location.hash = '';
  44. if (window.stationInterval) {
  45. clearInterval(window.stationInterval);
  46. window.stationInterval = 0;
  47. }
  48. if (window.socket) {
  49. io.removeAllListeners();
  50. }
  51. io.clear();
  52. if (transition.to.loginRequired || transition.to.adminRequired) {
  53. auth.getStatus((authenticated, role) => {
  54. if (transition.to.loginRequired && !authenticated) transition.redirect('/login');
  55. else if (transition.to.adminRequired && role !== 'admin') transition.redirect('/');
  56. else transition.next();
  57. });
  58. } else {
  59. transition.next();
  60. }
  61. });
  62. router.map({
  63. '/': {
  64. component: Home
  65. },
  66. '*': {
  67. component: NotFound
  68. },
  69. '404': {
  70. component: NotFound
  71. },
  72. '/terms': {
  73. component: Terms
  74. },
  75. '/privacy': {
  76. component: Privacy
  77. },
  78. '/team': {
  79. component: Team
  80. },
  81. '/news': {
  82. component: News
  83. },
  84. '/about': {
  85. component: About
  86. },
  87. '/u/:username': {
  88. component: User
  89. },
  90. '/settings': {
  91. component: Settings,
  92. loginRequired: true
  93. },
  94. '/reset_password': {
  95. component: ResetPassword
  96. },
  97. '/login': {
  98. component: Login
  99. },
  100. '/register': {
  101. component: Register
  102. },
  103. '/admin': {
  104. component: Admin,
  105. adminRequired: true
  106. },
  107. '/admin/news': {
  108. component: AdminNews,
  109. adminRequired: true
  110. },
  111. '/admin/users': {
  112. component: AdminUsers,
  113. adminRequired: true
  114. },
  115. '/admin/reports': {
  116. component: AdminReports,
  117. adminRequired: true
  118. },
  119. '/admin/stations': {
  120. component: AdminStations,
  121. adminRequired: true
  122. },
  123. '/admin/songs': {
  124. component: AdminSongs,
  125. adminRequired: true
  126. },
  127. '/admin/queuesongs': {
  128. component: AdminQueueSongs,
  129. adminRequired: true
  130. },
  131. '/official/:id': {
  132. component: Station
  133. },
  134. '/:id': {
  135. component: Station
  136. },
  137. '/community/:id': {
  138. component: Station
  139. }
  140. });
  141. router.start(App, 'body');