Logo.vue 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <template>
  2. <div class="sidebar-logo-container" :class="{'collapse':collapse}">
  3. <transition name="sidebarLogoFade">
  4. <router-link v-if="collapse" key="collapse" class="sidebar-logo-link" to="/">
  5. <el-image v-if="logo" :src="logo_thumb" class="sidebar-logo_thumb" />
  6. <h1 v-else class="sidebar-title">{{ title }} </h1>
  7. </router-link>
  8. <router-link v-else key="expand" class="sidebar-logo-link" to="/">
  9. <el-image v-if="logo" :src="logo" class="sidebar-logo" />
  10. </router-link>
  11. </transition>
  12. </div>
  13. </template>
  14. <script>
  15. export default {
  16. name: 'SidebarLogo',
  17. props: {
  18. collapse: {
  19. type: Boolean,
  20. required: true
  21. }
  22. },
  23. data() {
  24. return {
  25. title: '安全管家',
  26. logo_thumb: require('@/assets/images/logo/thumb.png'),
  27. logo: require('@/assets/images/logo/logo.png')
  28. }
  29. }
  30. }
  31. </script>
  32. <style lang="scss" scoped>
  33. .sidebarLogoFade-enter-active {
  34. transition: opacity 1.5s;
  35. }
  36. .sidebarLogoFade-enter,
  37. .sidebarLogoFade-leave-to {
  38. opacity: 0;
  39. }
  40. .sidebar-logo-container {
  41. position: relative;
  42. width: 100%;
  43. height: 50px;
  44. line-height: 50px;
  45. background: unset;
  46. text-align: center;
  47. overflow: hidden;
  48. & .sidebar-logo-link {
  49. height: 100%;
  50. width: 100%;
  51. & .sidebar-logo {
  52. height: 26px;
  53. vertical-align: middle;
  54. margin-right: 12px;
  55. }
  56. & .sidebar-logo_thumb {
  57. height: 32px;
  58. width: 32px;
  59. vertical-align: middle;
  60. margin-right: 12px;
  61. margin-left: 12px;
  62. }
  63. & .sidebar-title {
  64. display: inline-block;
  65. margin: 0;
  66. color: #fff;
  67. font-weight: 600;
  68. line-height: 50px;
  69. font-size: 14px;
  70. font-family: Avenir, Helvetica Neue, Arial, Helvetica, sans-serif;
  71. vertical-align: middle;
  72. }
  73. }
  74. &.collapse {
  75. .sidebar-logo {
  76. margin-right: 0;
  77. }
  78. }
  79. }
  80. </style>