componentMenu.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <template>
  2. <div :class="['componentMenuBox', this.$store.state.template.componentMenuStatus == 0 ? 'componentMenuBoxHide' : '']" id="componentMenuBox">
  3. <div class="floatArrow">
  4. <span class="el-icon-arrow-left" @click="setComponentMenuStatus(0)" v-if="this.$store.state.template.componentMenuStatus == 1"></span>
  5. <span class="el-icon-arrow-right" @click="setComponentMenuStatus(1)" v-if="this.$store.state.template.componentMenuStatus == 0"></span>
  6. </div>
  7. <div class="componentMenuTitle">
  8. <div v-if="this.$store.state.template.pageStatus == 1">首页可选板块:</div>
  9. <div v-if="this.$store.state.template.pageStatus == 2">频道页可选板块:</div>
  10. <div v-if="this.$store.state.template.pageStatus == 3">列表页可选板块:</div>
  11. <div v-if="this.$store.state.template.pageStatus == 4">详情页可选板块:</div>
  12. <div v-if="this.$store.state.template.pageStatus == 5">搜索页可选板块:</div>
  13. <div v-if="this.$store.state.template.pageStatus == 6">底部列表页可选板块:</div>
  14. <div v-if="this.$store.state.template.pageStatus == 7">底部详情页可选板块:</div>
  15. </div>
  16. <div>
  17. <el-scrollbar wrap-class="scrollbar-wrapper">
  18. <!--首页通栏-->
  19. <div v-if="this.$store.state.template.pageStatus == 1">
  20. <indexSector/>
  21. </div>
  22. <!--频道通栏-->
  23. <div v-if="this.$store.state.template.pageStatus == 2">
  24. <classSector/>
  25. </div>
  26. <!--列表通栏-->
  27. <div v-if="this.$store.state.template.pageStatus == 3">
  28. <listSector/>
  29. </div>
  30. <!--详情通栏-->
  31. <div v-if="this.$store.state.template.pageStatus == 4">
  32. <articleSector/>
  33. </div>
  34. <!--搜索通栏-->
  35. <div v-if="this.$store.state.template.pageStatus == 5">
  36. <searchSector/>
  37. </div>
  38. <!--底部列表通栏-->
  39. <div v-if="this.$store.state.template.pageStatus == 6">
  40. <sectorList/>
  41. </div>
  42. <!--底部详情通栏-->
  43. <div v-if="this.$store.state.template.pageStatus == 7">
  44. <sectorArticle/>
  45. </div>
  46. </el-scrollbar>
  47. </div>
  48. </div>
  49. </template>
  50. <script>
  51. import indexSector from './pages/index/sector.vue';
  52. import classSector from './pages/class/sector.vue';
  53. import listSector from './pages/list/sector.vue';
  54. import articleSector from './pages/article/sector.vue';
  55. import searchSector from './pages/search/sector.vue';
  56. import sectorList from './pages/about/sectorList.vue';
  57. import sectorArticle from './pages/about/sectorArticle.vue';
  58. export default {
  59. name: 'componentMenu',
  60. components:{
  61. indexSector,
  62. classSector,
  63. listSector,
  64. articleSector,
  65. searchSector,
  66. sectorList,
  67. sectorArticle
  68. },
  69. props: {
  70. },
  71. data() {
  72. return {
  73. data: null
  74. }
  75. },
  76. methods: {
  77. setComponentMenuStatus(data) {
  78. this.$store.commit('template/setComponentMenuStatus', data);
  79. }
  80. }
  81. }
  82. </script>
  83. <style scoped lang="less">
  84. .componentMenuBox {
  85. .floatArrow {
  86. position: absolute;
  87. top: 50%;
  88. right: -16px;
  89. width: 40px;
  90. height: 40px;
  91. background: #2F2F2F;
  92. border-radius: 50%;
  93. font-size: 18px;
  94. color:#fff;
  95. line-height:40px;
  96. cursor: pointer;
  97. color: #c7c7c7;
  98. box-sizing: border-box;
  99. padding-left: 16px;
  100. }
  101. transition: width 0.28s;
  102. width: 220px !important;
  103. background: #2F2F2F;
  104. height: 100%;
  105. position: fixed;
  106. font-size: 0px;
  107. top: 0;
  108. bottom: 0;
  109. left: 0;
  110. z-index: 1001;
  111. .sectorBox {
  112. height: 100%;
  113. }
  114. .el-scrollbar {
  115. height: calc(100vh - 60px);
  116. }
  117. .componentMenuTitle {
  118. padding: 37px 0 30px 0;
  119. color: #fff;
  120. font-size: 18px;
  121. font-weight: bold;
  122. div {
  123. border-left: 3px solid #5570F1;
  124. padding-left: 25px;
  125. }
  126. }
  127. }
  128. .componentMenuBoxHide {
  129. width: 10px !important;
  130. .componentMenuTitle {
  131. display: none;
  132. }
  133. .el-scrollbar {
  134. display: none;
  135. }
  136. }
  137. </style>