康鲁杰
2025-03-31 9cbbd2531ed5e950fe51a652c1994eb17da8cc45
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<script lang="ts" setup>
import { computed, onMounted, ref, unref, watch } from 'vue'
import { useAppStore } from '@/store/modules/app'
import { useDesign } from '@/hooks/web/useDesign'
 
defineOptions({ name: 'Logo' })
 
const { getPrefixCls } = useDesign()
 
const prefixCls = getPrefixCls('logo')
 
const appStore = useAppStore()
 
const show = ref(true)
 
const title = computed(() => appStore.getTitle)
 
const layout = computed(() => appStore.getLayout)
 
const collapse = computed(() => appStore.getCollapse)
 
onMounted(() => {
  if (unref(collapse)) show.value = false
})
 
watch(
  () => collapse.value,
  (collapse: boolean) => {
    if (unref(layout) === 'topLeft' || unref(layout) === 'cutMenu') {
      show.value = true
      return
    }
    if (!collapse) {
      setTimeout(() => {
        show.value = !collapse
      }, 400)
    } else {
      show.value = !collapse
    }
  }
)
 
watch(
  () => layout.value,
  (layout) => {
    if (layout === 'top' || layout === 'cutMenu') {
      show.value = true
    } else {
      if (unref(collapse)) {
        show.value = false
      } else {
        show.value = true
      }
    }
  }
)
</script>
 
<template>
  <div>
    <router-link
      style="padding: 0"
      :class="[
        prefixCls,
        layout !== 'classic' ? `${prefixCls}__Top` : '',
        'flex !h-[var(--logo-height)] items-center cursor-pointer pl-8px relative decoration-none overflow-hidden'
      ]"
      to="/"
    >
      <img
        style="width: 200px;height: 50px;margin-left: -10px"
        src="@/assets/imgs/logo.png"
      />
<!--      <div-->
<!--        v-if="show"-->
<!--        :class="[-->
<!--          'ml-10px text-16px font-700',-->
<!--          {-->
<!--            'text-[var(&#45;&#45;logo-title-text-color)]': layout === 'classic',-->
<!--            'text-[var(&#45;&#45;top-header-text-color)]':-->
<!--              layout === 'topLeft' || layout === 'top' || layout === 'cutMenu'-->
<!--          }-->
<!--        ]"-->
<!--      >-->
<!--        {{ title }}-->
<!--      </div>-->
    </router-link>
  </div>
</template>