mirror of
https://github.com/iczer/vue-antd-admin
synced 2025-04-05 07:27:06 +08:00
161 lines
4.3 KiB
Vue
161 lines
4.3 KiB
Vue
<template>
|
|
<a-layout-header :class="[headerTheme, 'global-header']">
|
|
<div :class="['global-header-wide', layout]">
|
|
<router-link v-if="isMobile || layout === 'head'" to="/" :class="['logo', isMobile ? null : 'pc', headerTheme]">
|
|
<img width="32" src="@/assets/img/logo.png" />
|
|
<h1 v-if="!isMobile">{{systemName}}</h1>
|
|
</router-link>
|
|
<a-divider v-if="isMobile" type="vertical" />
|
|
<a-icon v-if="layout === 'side'" class="trigger" :type="collapsed ? 'menu-unfold' : 'menu-fold'" @click="toggleCollapse"/>
|
|
<div v-if="layout == 'head' && !isMobile" class="global-header-menu">
|
|
<i-menu style="height: 64px; line-height: 64px;" :i18n="menuI18n" :theme="headerTheme" mode="horizontal" :options="menuData" @select="onSelect"/>
|
|
</div>
|
|
<div :class="['global-header-right', headerTheme]">
|
|
<header-search class="header-item" />
|
|
<a-tooltip class="header-item" title="帮助文档" placement="bottom" >
|
|
<a>
|
|
<a-icon type="question-circle-o" />
|
|
</a>
|
|
</a-tooltip>
|
|
<header-notice class="header-item"/>
|
|
<header-avatar class="header-item"/>
|
|
<a-dropdown class="lang header-item">
|
|
<div>
|
|
<a-icon type="global"/>
|
|
</div>
|
|
<a-menu @click="changeLang" :selected-keys="[lang]" slot="overlay">
|
|
<a-menu-item key="CN"><span >cn</span> 简体中文</a-menu-item>
|
|
<a-menu-item key="HK"><span >hk</span> 繁体中文</a-menu-item>
|
|
<a-menu-item key="US"><span >us</span> English</a-menu-item>
|
|
</a-menu>
|
|
</a-dropdown>
|
|
</div>
|
|
</div>
|
|
</a-layout-header>
|
|
</template>
|
|
|
|
<script>
|
|
import HeaderSearch from './HeaderSearch'
|
|
import HeaderNotice from './HeaderNotice'
|
|
import HeaderAvatar from './HeaderlAvatar'
|
|
import IMenu from '../components/menu/menu'
|
|
import {mapState} from 'vuex'
|
|
|
|
export default {
|
|
name: 'GlobalHeader',
|
|
components: {IMenu, HeaderAvatar, HeaderNotice, HeaderSearch},
|
|
props: ['collapsed', 'menuData'],
|
|
provide() {
|
|
return {
|
|
headerTheme: this.theme
|
|
}
|
|
},
|
|
inject: ['menuI18n'],
|
|
computed: {
|
|
...mapState('setting', ['theme', 'isMobile', 'layout', 'systemName', 'lang']),
|
|
headerTheme () {
|
|
return (this.layout == 'side' && !this.isMobile) ? 'light' : this.theme
|
|
}
|
|
},
|
|
methods: {
|
|
toggleCollapse () {
|
|
this.$emit('toggleCollapse')
|
|
},
|
|
onSelect (obj) {
|
|
this.$emit('menuSelect', obj)
|
|
},
|
|
changeLang(lang) {
|
|
this.$store.commit('setting/setLang', lang.key)
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="less" scoped>
|
|
.trigger {
|
|
font-size: 20px;
|
|
line-height: 64px;
|
|
padding: 0 24px;
|
|
cursor: pointer;
|
|
transition: color .3s;
|
|
&:hover{
|
|
color: #1890ff;
|
|
}
|
|
}
|
|
.global-header{
|
|
padding: 0;
|
|
-webkit-box-shadow: 0 1px 4px rgba(0,21,41,.08);
|
|
box-shadow: 0 1px 4px rgba(0,21,41,.08);
|
|
z-index: 1;
|
|
position: relative;
|
|
&.light{
|
|
background: #fff;
|
|
}
|
|
&.dark{
|
|
background: #001529;
|
|
.trigger{
|
|
color: white;
|
|
}
|
|
}
|
|
.global-header-wide{
|
|
&.head{
|
|
max-width: 1400px;
|
|
margin: auto;
|
|
}
|
|
&.side{
|
|
}
|
|
.logo {
|
|
height: 64px;
|
|
line-height: 58px;
|
|
vertical-align: top;
|
|
display: inline-block;
|
|
padding: 0 12px 0 24px;
|
|
cursor: pointer;
|
|
font-size: 20px;
|
|
&.pc{
|
|
padding: 0 12px 0 0;
|
|
}
|
|
img {
|
|
display: inline-block;
|
|
vertical-align: middle;
|
|
}
|
|
h1{
|
|
display: inline-block;
|
|
font-size: 16px;
|
|
}
|
|
&.dark h1{
|
|
color: #fff;
|
|
}
|
|
}
|
|
.global-header-menu{
|
|
display: inline-block;
|
|
}
|
|
.global-header-right{
|
|
float: right;
|
|
display: flex;
|
|
&.dark{
|
|
color: #fff;
|
|
a, i{
|
|
color: #fff !important;
|
|
}
|
|
.header-item:hover{
|
|
background-color: @primary-color;
|
|
}
|
|
}
|
|
.header-item{
|
|
padding: 0 12px;
|
|
cursor: pointer;
|
|
align-self: center;
|
|
&:hover{
|
|
background-color: @gray-3;
|
|
}
|
|
i{
|
|
font-size: 16px;
|
|
color: rgba(0,0,0,.65);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|