index.vue 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <template>
  2. <div :class="'logo-container-' + layout">
  3. <router-link to="/">
  4. <!-- 这里是logo变更的位置 -->
  5. <vab-remix-icon v-if="logo" class="logo" :icon-class="logo" />
  6. <span
  7. class="title"
  8. :class="{ 'hidden-xs-only': layout === 'horizontal' }"
  9. :title="title"
  10. >
  11. {{ title }}
  12. </span>
  13. </router-link>
  14. </div>
  15. </template>
  16. <script>
  17. import { mapGetters } from 'vuex'
  18. export default {
  19. name: 'VabLogo',
  20. data() {
  21. return {
  22. title: this.$baseTitle,
  23. }
  24. },
  25. computed: {
  26. ...mapGetters({
  27. logo: 'settings/logo',
  28. layout: 'settings/layout',
  29. }),
  30. },
  31. }
  32. </script>
  33. <style lang="scss" scoped>
  34. @mixin container {
  35. position: relative;
  36. height: $base-top-bar-height;
  37. overflow: hidden;
  38. line-height: $base-top-bar-height;
  39. background: $base-menu-background;
  40. }
  41. @mixin logo {
  42. display: inline-block;
  43. width: 34px;
  44. height: 34px;
  45. margin-right: 3px;
  46. color: $base-title-color;
  47. vertical-align: middle;
  48. }
  49. @mixin title {
  50. display: inline-block;
  51. overflow: hidden;
  52. font-size: 24px;
  53. line-height: 55px;
  54. color: $base-title-color;
  55. text-overflow: ellipsis;
  56. white-space: nowrap;
  57. vertical-align: middle;
  58. }
  59. .logo-container-horizontal {
  60. @include container;
  61. .logo {
  62. @include logo;
  63. }
  64. .title {
  65. @include title;
  66. }
  67. }
  68. .logo-container-vertical {
  69. @include container;
  70. height: $base-logo-height;
  71. line-height: $base-logo-height;
  72. text-align: center;
  73. .logo {
  74. @include logo;
  75. }
  76. .title {
  77. @include title;
  78. max-width: calc(#{$base-left-menu-width} - 60px);
  79. }
  80. }
  81. </style>