import Vue from 'vue' import 'normalize.css/normalize.css' // a modern alternative to CSS resets import Element from 'element-ui' import './styles/element-variables.scss' import '@/styles/index.scss' // global css import App from './App' import store from './store' import router from './router' import i18n from './lang' // internationalization import './icons' // icon import './utils/error-log' // error log import request from '@/utils/request' import * as filters from './filters' // global filters import { hasPermission, hasNoPermission, hasAnyPermission } from './utils/permissionDirect' import Selectuser from './views/user/selectuser' import Selectdept from './views/user/selectdept' import uploadfj from './views/yunpan/uploadfj' import { selectDictLabel } from './utils/ruoyi' import { getDicts } from './api/data' const Plugins = [ hasPermission, hasNoPermission, hasAnyPermission, getDicts ] Plugins.map((plugin) => { Vue.use(plugin) }) Vue.use(Element, { i18n: (key, value) => i18n.t(key, value) }) Vue.component('Selectuser', Selectuser) Vue.component('Selectdept', Selectdept) Vue.component('uploadfj', uploadfj) Vue.prototype.getDicts = getDicts Vue.prototype.$post = request.post Vue.prototype.$get = request.get Vue.prototype.$put = request.put Vue.prototype.$delete = request.delete Vue.prototype.selectDictLabel = selectDictLabel Vue.prototype.$download = request.download Vue.prototype.$upload = request.upload Vue.prototype.$login = request.login // register global utility filters Object.keys(filters).forEach(key => { Vue.filter(key, filters[key]) }) Vue.config.productionTip = false new Vue({ el: '#app', router, store, i18n, render: h => h(App) })