mirror of
https://github.com/iczer/vue-antd-admin
synced 2025-04-05 19:41:37 +08:00
parent
23b7dfe2a4
commit
ae2b7a86ef
1
.env
1
.env
@ -5,4 +5,5 @@ VUE_APP_ROLES_KEY=admin.roles
|
|||||||
VUE_APP_USER_KEY=admin.user
|
VUE_APP_USER_KEY=admin.user
|
||||||
VUE_APP_SETTING_KEY=admin.setting
|
VUE_APP_SETTING_KEY=admin.setting
|
||||||
VUE_APP_TBAS_KEY=admin.tabs
|
VUE_APP_TBAS_KEY=admin.tabs
|
||||||
|
VUE_APP_TBAS_TITLES_KEY=admin.tabs.titles
|
||||||
VUE_APP_API_BASE_URL=http://api.iczer.com
|
VUE_APP_API_BASE_URL=http://api.iczer.com
|
||||||
|
@ -60,10 +60,10 @@ export default {
|
|||||||
this.updatePageHeight(0)
|
this.updatePageHeight(0)
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapState('setting', ['layout', 'multiPage', 'pageMinHeight', 'pageWidth']),
|
...mapState('setting', ['layout', 'multiPage', 'pageMinHeight', 'pageWidth', 'customTitles']),
|
||||||
pageTitle() {
|
pageTitle() {
|
||||||
let pageTitle = this.page && this.page.title
|
let pageTitle = this.page && this.page.title
|
||||||
return pageTitle === undefined ? (this.title || this.routeName) : this.$t(pageTitle)
|
return this.customTitle || (pageTitle && this.$t(pageTitle)) || this.title || this.routeName
|
||||||
},
|
},
|
||||||
routeName() {
|
routeName() {
|
||||||
const route = this.$route
|
const route = this.$route
|
||||||
@ -96,8 +96,8 @@ export default {
|
|||||||
breadcrumb.push(this.$t(getI18nKey(path)))
|
breadcrumb.push(this.$t(getI18nKey(path)))
|
||||||
})
|
})
|
||||||
let pageTitle = this.page && this.page.title
|
let pageTitle = this.page && this.page.title
|
||||||
if (pageTitle) {
|
if (this.customTitle || pageTitle) {
|
||||||
breadcrumb[breadcrumb.length - 1] = pageTitle
|
breadcrumb[breadcrumb.length - 1] = this.customTitle || pageTitle
|
||||||
}
|
}
|
||||||
return breadcrumb
|
return breadcrumb
|
||||||
},
|
},
|
||||||
|
@ -63,7 +63,7 @@
|
|||||||
this.affixed = this.fixedTabs
|
this.affixed = this.fixedTabs
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapState('setting', ['layout', 'pageWidth', 'fixedHeader', 'fixedTabs']),
|
...mapState('setting', ['layout', 'pageWidth', 'fixedHeader', 'fixedTabs', 'customTitles']),
|
||||||
lockTitle() {
|
lockTitle() {
|
||||||
return this.$t(this.fixedTabs ? 'unlock' : 'lock')
|
return this.$t(this.fixedTabs ? 'unlock' : 'lock')
|
||||||
}
|
}
|
||||||
@ -95,7 +95,8 @@
|
|||||||
this.$emit('contextmenu', pageKey, e)
|
this.$emit('contextmenu', pageKey, e)
|
||||||
},
|
},
|
||||||
pageName(page) {
|
pageName(page) {
|
||||||
return page.title || this.$t(getI18nKey(page.keyPath))
|
const custom = this.customTitles.find(item => item.path === page.fullPath)
|
||||||
|
return (custom && custom.title) || page.title || this.$t(getI18nKey(page.keyPath))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,24 @@ const TabsPagePlugin = {
|
|||||||
$refreshPage(pageKey) {
|
$refreshPage(pageKey) {
|
||||||
const event = new CustomEvent('page:refresh', {detail:{pageKey}})
|
const event = new CustomEvent('page:refresh', {detail:{pageKey}})
|
||||||
window.dispatchEvent(event)
|
window.dispatchEvent(event)
|
||||||
|
},
|
||||||
|
$openPage(route, title) {
|
||||||
|
this.$setPageTitle(route, title)
|
||||||
|
this.$router.push(route)
|
||||||
|
},
|
||||||
|
$setPageTitle(route, title) {
|
||||||
|
if (title) {
|
||||||
|
const fullPath = typeof route === 'object' ? route.fullPath : route
|
||||||
|
this.$store.commit('setting/setCustomTitle', {path: fullPath, title})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
customTitle() {
|
||||||
|
const customTitles = this.$store.state.setting.customTitles
|
||||||
|
const fullPath = this.$route.fullPath
|
||||||
|
const custom = customTitles.find(item => item.path === fullPath)
|
||||||
|
return custom && custom.title
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -5,6 +5,8 @@ import {filterMenu} from '@/utils/authority-utils'
|
|||||||
import {getLocalSetting} from '@/utils/themeUtil'
|
import {getLocalSetting} from '@/utils/themeUtil'
|
||||||
|
|
||||||
const localSetting = getLocalSetting(true)
|
const localSetting = getLocalSetting(true)
|
||||||
|
const customTitlesStr = sessionStorage.getItem(process.env.VUE_APP_TBAS_TITLES_KEY)
|
||||||
|
const customTitles = (customTitlesStr && JSON.parse(customTitlesStr)) || []
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
namespaced: true,
|
namespaced: true,
|
||||||
@ -15,6 +17,7 @@ export default {
|
|||||||
pageMinHeight: 0,
|
pageMinHeight: 0,
|
||||||
menuData: [],
|
menuData: [],
|
||||||
activatedFirst: undefined,
|
activatedFirst: undefined,
|
||||||
|
customTitles,
|
||||||
...config,
|
...config,
|
||||||
...localSetting
|
...localSetting
|
||||||
},
|
},
|
||||||
@ -94,6 +97,17 @@ export default {
|
|||||||
},
|
},
|
||||||
setFixedTabs(state, fixedTabs) {
|
setFixedTabs(state, fixedTabs) {
|
||||||
state.fixedTabs = fixedTabs
|
state.fixedTabs = fixedTabs
|
||||||
|
},
|
||||||
|
setCustomTitle(state, {path, title}) {
|
||||||
|
if (title) {
|
||||||
|
const obj = state.customTitles.find(item => item.path === path)
|
||||||
|
if (obj) {
|
||||||
|
obj.title = title
|
||||||
|
} else {
|
||||||
|
state.customTitles.push({path, title})
|
||||||
|
}
|
||||||
|
sessionStorage.setItem(process.env.VUE_APP_TBAS_TITLES_KEY, JSON.stringify(state.customTitles))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user