import Vue from 'vue' import 'dragula/dist/dragula.min.css' import 'normalize.css/normalize.css' // a modern alternative to CSS resets import Element from 'element-ui' import './styles/element-variables.scss' import Viewer from 'v-viewer' import 'viewerjs/dist/viewer.css' import preview from 'vue-photo-preview' import 'vue-photo-preview/dist/skin.css' // vue-quill-editor css import 'quill/dist/quill.core.css' import 'quill/dist/quill.snow.css' import 'quill/dist/quill.bubble.css' 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' const Plugins = [ hasPermission, hasNoPermission, hasAnyPermission ] Plugins.map((plugin) => { Vue.use(plugin) }) Vue.use(preview) Vue.use(Viewer) 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.use(Element, { i18n: (key, value) => i18n.t(key, value) }) Vue.prototype.$post = request.post Vue.prototype.$get = request.get Vue.prototype.$put = request.put Vue.prototype.$delete = request.delete 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) })