123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- // import Vue from 'vue'
- // import VueRouter from 'vue-router'
- // Vue.use(VueRouter)
- import ElementUI from 'element-ui'
- // 全局修改默认配置,点击空白处不能关闭弹窗
- ElementUI.Dialog.props.closeOnClickModal.default = false
- Vue.use(ElementUI)
- import elTableInfiniteScroll from 'el-table-infinite-scroll'
- Vue.use(elTableInfiniteScroll)
- // import Vuex from 'vuex'
- // Vue.use(Vuex)
- // import echarts from 'echarts'
- import 'element-ui/lib/theme-chalk/index.css'
- // import '.././static/css/element-variables.scss'
- import App from './App'
- import store from './vuex/store'
- // import routes from './routes'
- import http from './http'
- import port from './port'
- import $ from 'jquery'
- import VDistPicker from 'v-distpicker'
- Vue.component('v-distpicker',VDistPicker)
- import './day.js' // 加载 dayjs 初始化配置
- import dayjs from 'dayjs';
- Vue.prototype.dayjs = dayjs;
- // 引入中译英js
- import i18n from '@/i18n/index'
- import Viewer from 'v-viewer' // 图片预览
- import 'viewerjs/dist/viewer.css'
- // Vue.use(Viewer)
- Vue.use(Viewer, {
- defaultOptions: {
- zIndex: 9999,
- }
- })
- Viewer.setDefaults({
- Options: { 'inline': true, 'button': true, 'navbar': true, 'title': true, 'toolbar': true, 'tooltip': true, 'movable': true, 'zoomable': true, 'rotatable': true, 'scalable': true, 'transition': true, 'fullscreen': true, 'keyboard': true, 'url': 'data-source' }
- })
- Vue.prototype.http = http
- Vue.prototype.port = port
- Vue.prototype.echarts = echarts
- import VueClipboard from 'vue-clipboard2'
- Vue.use(VueClipboard)
- // collapse 展开折叠
- import CollapseTransition from 'element-ui/lib/transitions/collapse-transition';
- Vue.component(CollapseTransition.name, CollapseTransition)
- import 'font-awesome/css/font-awesome.min.css'
- import './assets/iconfont/iconfont.css'
- import './assets/myfont/iconfont.css'
- // const router = new VueRouter({
- // routes
- // })
- import {fixedRouter, allRouters, simpleRouters } from './routes'
- import router from './routes'
-
- import NProgress from 'nprogress'
- import 'nprogress/nprogress.css'
- import Vue from 'vue'
- // 新手指导
- import VueTour from 'vue-tour'
- require('vue-tour/dist/vue-tour.css')
- Vue.use(VueTour)
- // 打印js
- import Print from './assets/js/print.js'
- Vue.use(Print)
- var addRouFlag = false;
- //角色权限对应关系
- router.beforeEach((to, from, next) => {
- NProgress.start();
- // console.log('路由跳转判定',to,from,next);
- if (to.path == '/') {
- from.name ? next(from.path) : next('/login')
- // console.log('走判定');
- return
- }
- if (to.path == '/register') {
- next();
- return;
- }
- if (to.path == '/expire') {
- next();
- return;
- }
- if (to.path != '/report') {
- sessionStorage.removeItem("from")
- }
- if (to.path == '/login') {
- sessionStorage.removeItem('user');
- }
- let user = JSON.parse(sessionStorage.getItem('user'));
- if (!user && to.path != '/login') {
- next({ path: '/login' })
- } else {
- if (!addRouFlag) {
- if(user != null) {
- addRouFlag = true;
- var getRoutes = null;
- var filterRouter = allRouters;
- // 更据当前登录的权限来显示模块
- console.log("user",user)
- console.log(filterRouter)
- var arr = []
- var arrMouter = []
- for(var i in user.moduleList) {
- for(var s in filterRouter) {
- if(user.moduleList[i].children.length > 0) {
- if(user.moduleList[i].name == filterRouter[s].name) {
- console.log('路由模块==',user.moduleList[i].name)
- var arrList = user.moduleList[i].children
- var ddList = filterRouter[s].children
- var list = []
- for(var j in arrList) {
- for(var d in ddList) {
- if(arrList[j].name == ddList[d].name) {
- list.push(ddList[d])
- }
- }
- }
- // //硬编码产品管理
- // if (user.moduleList[i].name == '产品管理') {
- // list = arrList;
-
- // // { path: '/product/:id', component: prodList, name: '产品管理',iconCls: 'iconfont firerock-iconxiangmu' },
- // for (var i=0;i<list.length; i++) {
- // list[i].component = `prodList`;
- // list[i].iconCls = 'iconfont firerock-iconxiangmu';
- // }
- // console.log('产品管理子菜单==', list);
- // }
- filterRouter[s].children = list
- arr.push(filterRouter[s])
- }
- } else {
- if(user.moduleList[i].name == filterRouter[s].name) {
- arr.push(filterRouter[s])
- }
- if(filterRouter[s].name == '计划详情' && arrMouter.length == 0) {
- arrMouter.push(filterRouter[s])
- }
- }
-
- }
- }
- arr = [...arr, ...arrMouter]
- console.log(arr, '处理后的路由')
- getRoutes = arr;
- global.antRouter = fixedRouter.concat(getRoutes);
- router.addRoutes(fixedRouter.concat(getRoutes));
- console.log(router);
- router.options.routes = fixedRouter.concat(getRoutes);
- router.push({ path: to.path })
- }
- }
- next()
- }
- })
- function baseRoleGetRouters(allRoutes, user) {
- // allRoutes是动态路由表
- // roles是取到的用户角色,数组
- let rightRoutes = allRoutes.filter((route, index) => {
- if (route.group == null || (user.company.packageProject == 1 && route.group == 'packageProject')) {
- if (route.children && route.children.length) {
- route.children = baseRoleGetRouters(route.children, user)
- }
- return true
- }
- return false
- })
- return rightRoutes
- }
- function hasPermission(route, roles) {
- if (route.meta && route.meta.roles) {
- return roles.some(role => route.meta.roles.indexOf(role) >= 0)
- } else {
- return true
- }
- }
- router.afterEach(() => {
- NProgress.done();
- })
- // 定义的方法,对文本框使用,只能输入数组, // 加 v-enter-number
- Vue.directive('enterNumber', {
- inserted: function (el) {
- el.addEventListener("keypress",function(e){
- e = e || window.event;
- let charcode = typeof e.charCode === 'number' ? e.charCode : e.keyCode;
- let re = /\d/;
- if(!re.test(String.fromCharCode(charcode)) && charcode > 9 && !e.ctrlKey){
- if(e.preventDefault){
- e.preventDefault();
- }else{
- e.returnValue = false;
- }
- }
- });
- }
- });
- new Vue({
- router,
- store,
- i18n,
- render: h => h(App)
- }).$mount('#app')
|