|
- <template>
- <a-config-provider :locale="locale" :get-popup-container="popContainer">
- <router-view/>
- </a-config-provider>
- </template>
-
- <script>
- import { enquireScreen } from './utils/util'
- import {mapState, mapMutations} from 'vuex'
- import themeUtil from '@/utils/themeUtil';
- import {getI18nKey} from '@/utils/routerUtil'
- import {checkAuthorization} from '@/utils/request';
-
- export default {
- name: 'App',
- data() {
- return {
- locale: {}
- }
- },
- created () {
- this.setHtmlTitle()
- this.setLanguage(this.lang)
- enquireScreen(isMobile => this.setDevice(isMobile))
- window.SYS_CONFIG = {
- OSS_Extranet_URL: {
- Name: 'oss外网访问地址',
- Code: 'OSS_Extranet_URL',
- Value: 'http://192.168.16.100:9015'
- },
- }
- },
- mounted() {
- this.setWeekModeTheme(this.weekMode)
- /* if (checkAuthorization()) {
- this.$store.dispatch('account/refreshPermissions');
- if (this.$route.path == '/loginjmp') {
- location.href = '/#/main';
- }
- } else {
- this.$router.push('/loginOA');
- }*/
- window.addEventListener('scroll', this.handleScroll, true);
- },
- watch: {
- weekMode(val) {
- this.setWeekModeTheme(val)
- },
- lang(val) {
- this.setLanguage(val)
- this.setHtmlTitle()
- },
- $route() {
- this.setHtmlTitle()
- },
- 'theme.mode': function(val) {
- let closeMessage = this.$message.loading(`您选择了主题模式 ${val}, 正在切换...`)
- themeUtil.changeThemeColor(this.theme.color, val).then(closeMessage)
- },
- 'theme.color': function(val) {
- let closeMessage = this.$message.loading(`您选择了主题色 ${val}, 正在切换...`)
- themeUtil.changeThemeColor(val, this.theme.mode).then(closeMessage)
- },
- 'layout': function() {
- window.dispatchEvent(new Event('resize'))
- }
- },
- computed: {
- ...mapState('setting', ['layout', 'theme', 'weekMode', 'lang'])
- },
- methods: {
- ...mapMutations('setting', ['setDevice']),
- handleScroll() {
- const dom = document.getElementById('popContainer');
- let scrollTop = dom.scrollTop;
- this.$bus.$emit('scrollTop', scrollTop);
- },
- setWeekModeTheme(weekMode) {
- if (weekMode) {
- document.body.classList.add('week-mode')
- } else {
- document.body.classList.remove('week-mode')
- }
- },
- setLanguage(lang) {
- this.$i18n.locale = lang
- switch (lang) {
- case 'CN':
- this.locale = require('ant-design-vue/es/locale-provider/zh_CN').default
- break
- case 'HK':
- this.locale = require('ant-design-vue/es/locale-provider/zh_TW').default
- break
- case 'US':
- default:
- this.locale = require('ant-design-vue/es/locale-provider/en_US').default
- break
- }
- },
- setHtmlTitle() {
- const route = this.$route
- const key = route.path === '/' ? 'home.name' : getI18nKey(route.matched[route.matched.length - 1].path)
- document.title = process.env.VUE_APP_NAME + ' | ' + this.$t(key)
- },
- popContainer() {
- return document.getElementById('popContainer')
- }
- },
- beforeDestroy() {
- window.removeEventListener('scroll', this.handleScroll)
- }
- }
- </script>
-
- <style lang="less" scoped>
-
- </style>
|