main.js 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import babelpolyfill from 'babel-polyfill'
  2. import Vue from 'vue'
  3. import App from './App'
  4. import VueRouter from 'vue-router'
  5. import ElementUI from 'element-ui'
  6. import 'element-ui/lib/theme-chalk/index.css'
  7. //import 'element-ui/lib/theme-default/index.css'
  8. //import './assets/theme/theme-green/index.css'
  9. import store from './vuex/store'
  10. import Vuex from 'vuex'
  11. //import NProgress from 'nprogress'
  12. //import 'nprogress/nprogress.css'
  13. import routes from './routes'
  14. // import Mock from './mock'
  15. // Mock.bootstrap();
  16. import http from './http'
  17. Vue.prototype.http = http
  18. import port from './port'
  19. Vue.prototype.port = port
  20. import 'font-awesome/css/font-awesome.min.css'
  21. import './assets/iconfont/iconfont.css'
  22. Vue.use(ElementUI)
  23. Vue.use(VueRouter)
  24. Vue.use(Vuex)
  25. //NProgress.configure({ showSpinner: false });
  26. const router = new VueRouter({
  27. routes
  28. })
  29. router.beforeEach((to, from, next) => {
  30. //NProgress.start();
  31. if (to.path == '/login') {
  32. sessionStorage.removeItem('user');
  33. }
  34. let user = JSON.parse(sessionStorage.getItem('user'));
  35. if (!user && to.path != '/login') {
  36. next({ path: '/login' })
  37. } else {
  38. if(user){
  39. for(var i in routes){
  40. if(routes[i].name == "基础管理" && user.parentId != 0){
  41. routes[i].hidden = true
  42. } else if(routes[i].name == "基础管理"){
  43. routes[i].hidden = false
  44. }
  45. if(routes[i].name == "项目管理" && user.parentId > 1){
  46. var children = routes[i].children;
  47. for(var j in children){
  48. if(children[j].name == "人员管理"){
  49. children[j].hidden = true
  50. }
  51. if(children[j].name == "权限管理"){
  52. children[j].hidden = true
  53. }
  54. }
  55. } else if(routes[i].name == "项目管理") {
  56. var children = routes[i].children;
  57. for(var j in children){
  58. children[j].hidden = false
  59. }
  60. }
  61. }
  62. }
  63. next()
  64. }
  65. })
  66. // router.afterEach(transition => {
  67. // NProgress.done();
  68. // });
  69. new Vue({
  70. //el: '#app',
  71. //template: '<App/>',
  72. router,
  73. store,
  74. //components: { App }
  75. render: h => h(App)
  76. }).$mount('#app')