You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							120 lines
						
					
					
						
							2.9 KiB
						
					
					
				
			
		
		
	
	
							120 lines
						
					
					
						
							2.9 KiB
						
					
					
				| <template> | |
|     <div class="head"> | |
|         <div class="head-left"> | |
|             <el-button v-if="closeAble" class="close-aside-btn" :icon="isClose ? 'CaretRight' : 'CaretLeft'" circle | |
|                 :size="state.size.size" @click="close"></el-button> | |
|             <div class="title" v-if="isClose"> | |
|                 <el-image class="logo" v-if="logo" :src="logo" fit="fit" /> | |
|                 {{ title || t('title') }} | |
|             </div> | |
|             <slot name="left"></slot> | |
|         </div> | |
|         <div class="head-right"> | |
|             <slot></slot> | |
|             <span class="username" v-if="username">{{ username }}</span> | |
|         </div> | |
|     </div> | |
| </template> | |
| 
 | |
| <script lang="ts" setup> | |
| import { useStore } from "vuex"; | |
| import { reactive, onMounted, ref } from "vue"; | |
| import { useI18n } from "vue3-i18n"; | |
| const { t } = useI18n(); | |
| 
 | |
| const { state, commit, dispatch } = useStore(); | |
| 
 | |
| const props = defineProps({ | |
|     closeAble: { | |
|         type: Boolean, | |
|         default: false, | |
|     }, | |
|     title: { | |
|         type: String, | |
|         default: null, | |
|     }, | |
|     logo: { | |
|         type: String, | |
|         default: null, | |
|     }, | |
|     username: { | |
|         type: String, | |
|         default: null, | |
|     }, | |
| }) | |
| 
 | |
| const isClose = ref(false) | |
| const close = () => { | |
|     isClose.value = !isClose.value; | |
|     if (isClose.value) { | |
|         state.size.asideWidth = '0px'; | |
|         commit("initSize"); | |
|     } else { | |
|         state.size.asideWidth = state.size.aside + 'px'; | |
|         commit("initSize"); | |
|     } | |
| } | |
| 
 | |
| onMounted(() => { }); | |
| </script> | |
| <style lang="scss" scoped> | |
| //@import url(); 引入公共css类 | |
|  | |
| .close-aside-btn { | |
|     position: absolute; | |
|     z-index: 99; | |
|     top: v-bind('state.size.closeTop'); | |
|     left: -5px; | |
|     color: red; | |
|     background: transparent; | |
| } | |
| 
 | |
| .title { | |
|     height: v-bind('state.size.headHeight'); | |
|     // width: v-bind('state.size.asideWidth'); | |
|     text-align: center; | |
|     float: left; | |
|     font-size: v-bind('state.size.titleSize'); | |
|     line-height: v-bind('state.size.headHeight'); | |
|     font-weight: bold; | |
|     color: v-bind('state.style.titleColor'); | |
| } | |
| 
 | |
| .head-left { | |
|     float: left; | |
|     line-height: v-bind('state.size.headHeight'); | |
|     width: v-bind('state.size.headLeftWidth'); | |
|     align-items: center; | |
|     justify-content: center; | |
| } | |
| 
 | |
| .head-right { | |
|     float: right; | |
|     line-height: v-bind('state.size.headHeight'); | |
|     width: v-bind('state.size.headRightWidth'); | |
|     padding-right: 10px; | |
| 
 | |
|     align-items: center; | |
|     justify-content: center; | |
| 
 | |
|     .head-icon { | |
|         float: right; | |
|         cursor: pointer; | |
|         height: v-bind('state.size.headHeight'); | |
|         margin-right: 20px; | |
|         font-size: v-bind('state.size.headIconSize'); | |
|         align-items: center; | |
|         color: v-bind('state.style.color'); | |
|     } | |
| 
 | |
|     .username { | |
|         float: right; | |
|         height: v-bind('state.size.headHeight'); | |
|         margin-right: 20px; | |
|         font-size: v-bind('state.size.titleSize'); | |
|         font-weight: bold; | |
|         color: v-bind('state.style.color'); | |
|     } | |
| 
 | |
| } | |
| </style>
 | |
| 
 |