main.js 2.3 KB

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