<template>
|
<div class="sidebar-logo-container" :class="{ 'collapse': collapse }">
|
<transition name="sidebarLogoFade">
|
<router-link v-if="collapse" key="collapse" class="sidebar-logo-link" to="/">
|
<img v-if="logoUrl" :src="logoUrl" class="sidebar-logo" @error="handleImageError" alt="公司Logo" />
|
<h1 v-else class="sidebar-title">{{ title }}</h1>
|
</router-link>
|
<router-link v-else key="expand" class="sidebar-logo-link" to="/">
|
<img v-if="logoUrl" :src="logoUrl" class="sidebar-logo" @error="handleImageError" alt="公司Logo" />
|
<h1 v-else class="sidebar-title">{{ title }}</h1>
|
</router-link>
|
</transition>
|
</div>
|
</template>
|
|
<script setup>
|
import { ref, computed, onMounted, watch } from 'vue'
|
import useUserStore from '@/store/modules/user'
|
import defaultLogo from '@/assets/logo/logo.png' // 导入默认logo
|
|
defineProps({
|
collapse: {
|
type: Boolean,
|
required: true
|
}
|
})
|
|
const title = import.meta.env.VITE_APP_TITLE
|
const userStore = useUserStore()
|
|
// 处理工厂名称,生成合法的文件名
|
const cleanFactoryName = computed(() => {
|
if (!userStore.currentFactoryName) return ''
|
return userStore.currentFactoryName.trim()
|
})
|
|
// 动态logo路径
|
const logoUrl = ref('')
|
|
// 检查logo是否存在并设置url
|
const updateLogoUrl = () => {
|
if (!cleanFactoryName.value) {
|
logoUrl.value = defaultLogo
|
return
|
}
|
|
// 使用Vite的动态导入
|
try {
|
const dynamicLogo = import.meta.glob('/src/assets/logo/*.png', { eager: true })
|
const logoPath = `/src/assets/logo/${cleanFactoryName.value}.png`
|
|
if (dynamicLogo[logoPath]) {
|
logoUrl.value = dynamicLogo[logoPath].default
|
} else {
|
logoUrl.value = defaultLogo
|
}
|
} catch (error) {
|
console.error('加载工厂Logo失败:', error)
|
logoUrl.value = defaultLogo
|
}
|
}
|
|
// 初始化和监听变化
|
onMounted(() => {
|
updateLogoUrl()
|
|
// 监听工厂名称变化
|
watch(() => userStore.currentFactoryName, updateLogoUrl)
|
})
|
|
// 图片加载错误处理
|
const handleImageError = (event) => {
|
console.warn('Logo加载失败,使用默认Logo')
|
logoUrl.value = defaultLogo
|
}
|
</script>
|
|
<style lang="scss" scoped>
|
@import '@/assets/styles/variables.module.scss';
|
|
.sidebarLogoFade-enter-active {
|
transition: opacity 1.5s;
|
}
|
|
.sidebarLogoFade-enter,
|
.sidebarLogoFade-leave-to {
|
opacity: 0;
|
}
|
|
.sidebar-logo-container {
|
position: relative;
|
width: 100%;
|
height: 50px;
|
line-height: 50px;
|
background: #fff;
|
text-align: center;
|
overflow: hidden;
|
|
& .sidebar-logo-link {
|
height: 100%;
|
width: 100%;
|
|
& .sidebar-logo {
|
width: 100%;
|
height: 100%;
|
// height: 32px;
|
vertical-align: middle;
|
margin-right: 12px;
|
}
|
|
& .sidebar-title {
|
display: inline-block;
|
margin: 0;
|
color: v-bind(getLogoTextColor);
|
font-weight: 600;
|
line-height: 50px;
|
font-size: 14px;
|
font-family: Avenir, Helvetica Neue, Arial, Helvetica, sans-serif;
|
vertical-align: middle;
|
}
|
}
|
|
&.collapse {
|
.sidebar-logo {
|
margin-right: 0px;
|
}
|
}
|
}
|
</style>
|