index.vue 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <template>
  2. <div class="drawer-container">
  3. <div>
  4. <h3 class="drawer-title">设置主题</h3>
  5. <div class="drawer-item">
  6. <span>主题颜色</span>
  7. <theme-picker
  8. style="float: right;height: 26px;margin: -3px 8px 0 0;"
  9. @change="themeChange"
  10. />
  11. </div>
  12. <div class="drawer-item">
  13. <span>打开标签卡</span>
  14. <el-switch
  15. v-model="tagsView"
  16. class="drawer-switch"
  17. />
  18. </div>
  19. <!-- <div class="drawer-item">
  20. <span>Fixed Header</span>
  21. <el-switch v-model="fixedHeader" class="drawer-switch" />
  22. </div> -->
  23. <div class="drawer-item">
  24. <span>侧边栏展示Logo</span>
  25. <el-switch
  26. v-model="sidebarLogo"
  27. class="drawer-switch"
  28. />
  29. </div>
  30. </div>
  31. </div>
  32. </template>
  33. <script>
  34. import ThemePicker from '@/components/ThemePicker'
  35. export default {
  36. components: { ThemePicker },
  37. data() {
  38. return {}
  39. },
  40. computed: {
  41. fixedHeader: {
  42. get() {
  43. return this.$store.state.settings.fixedHeader
  44. },
  45. set(val) {
  46. this.$store.dispatch('settings/changeSetting', {
  47. key: 'fixedHeader',
  48. value: val
  49. })
  50. }
  51. },
  52. tagsView: {
  53. get() {
  54. return this.$store.state.settings.tagsView
  55. },
  56. set(val) {
  57. this.$store.dispatch('settings/changeSetting', {
  58. key: 'tagsView',
  59. value: val
  60. })
  61. }
  62. },
  63. sidebarLogo: {
  64. get() {
  65. return this.$store.state.settings.sidebarLogo
  66. },
  67. set(val) {
  68. this.$store.dispatch('settings/changeSetting', {
  69. key: 'sidebarLogo',
  70. value: val
  71. })
  72. }
  73. }
  74. },
  75. methods: {
  76. themeChange(val) {
  77. this.$store.dispatch('settings/changeSetting', {
  78. key: 'theme',
  79. value: val
  80. })
  81. }
  82. }
  83. }
  84. </script>
  85. <style lang="scss" scoped>
  86. .drawer-container {
  87. padding: 24px;
  88. font-size: 14px;
  89. line-height: 1.5;
  90. word-wrap: break-word;
  91. .drawer-title {
  92. margin-bottom: 12px;
  93. color: rgba(0, 0, 0, .85);
  94. font-size: 14px;
  95. line-height: 22px;
  96. }
  97. .drawer-item {
  98. color: rgba(0, 0, 0, .65);
  99. font-size: 14px;
  100. padding: 12px 0;
  101. }
  102. .drawer-switch {
  103. float: right
  104. }
  105. }
  106. </style>