多租户商城-商户端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

234 lines
6.0 KiB

2 years ago
2 years ago
2 years ago
2 years ago
  1. <template>
  2. <div class="panelBoxWarp">
  3. <div class="panelBox" :class="{'on':sidebarShow}">
  4. <!--<div class="componentList">-->
  5. <!--<ul>-->
  6. <!--<li v-for="(item, index) of componentList" :key="index" :class="{'on':componentActive == index}" @click="componentActive=index">-->
  7. <!--<i class="iconfont icon-fangkuai"></i>-->
  8. <!--<span>{{item}}</span>-->
  9. <!--</li>-->
  10. <!--</ul>-->
  11. <!--</div>-->
  12. <div class="categoryList">
  13. <div class="itemBox" v-for="(item, index) of panelShowList" :key="index">
  14. <h3>{{item.title}}</h3>
  15. <div class="childList">
  16. <draggable
  17. class="dragArea list-group"
  18. :list="item.classList"
  19. :clone="cloneItem"
  20. :group="{ name: 'pageEdit', pull: 'clone', put: false }"
  21. :options="{sort:false}"
  22. >
  23. <div @mouseover="hoverItem (classItem)" @mouseout="hoverItemOut" class="childItem list-group-item" v-for="(classItem, index) of item.classList" :key="index">
  24. <div class="childItemWarp">
  25. <div class="contentBox">
  26. <i class="iconfont" :class="classItem.iconClass"></i>
  27. <span>{{classItem.title}}</span>
  28. </div>
  29. <div class="cloneText">
  30. 组件放置区域
  31. </div>
  32. </div>
  33. </div>
  34. </draggable>
  35. </div>
  36. </div>
  37. </div>
  38. </div>
  39. <div class="btnToggle" @click="sidebarShow=!sidebarShow" :class="{'on':sidebarShow}">
  40. <i class="iconfont icon-arrow-right"></i>
  41. <i class="iconfont icon-arrow-left"></i>
  42. </div>
  43. </div>
  44. </template>
  45. <script>
  46. // 默认配置文件
  47. import panelList from './panelList'
  48. import draggable from 'vuedraggable'
  49. import { mapGetters } from 'vuex'
  50. export default {
  51. name: 'panel',
  52. components: {
  53. draggable
  54. },
  55. data () {
  56. return {
  57. sidebarShow: true,
  58. componentActive: 0,
  59. componentList: ['组件', '组件'],
  60. panelList: panelList,
  61. isHover: ''
  62. }
  63. },
  64. methods: {
  65. hoverItem (classItem) {
  66. this.isHover = classItem.title
  67. },
  68. hoverItemOut () {
  69. this.isHover = ''
  70. },
  71. cloneItem (item) {
  72. return JSON.parse(JSON.stringify(item))
  73. },
  74. },
  75. computed: {
  76. ...mapGetters([
  77. 'terminal',
  78. 'typeId'
  79. ]),
  80. panelShowList(){
  81. let _this = this
  82. var _panelList = JSON.parse(JSON.stringify(this.panelList))
  83. var mewPaneList = _panelList.filter(parent=>{
  84. let children = parent.classList.filter(child=>{
  85. return !(child.onlyApp && _this.terminal==4) &&
  86. !(child.onlyWeixin && [2,3,4].includes(_this.terminal)) &&
  87. !(child.onlyAdmin && _this.typeId==3) &&
  88. !(child.onlyMerchant && _this.typeId==1)
  89. })
  90. parent.classList = children
  91. return parent
  92. })
  93. console.log(this.panelList)
  94. return mewPaneList
  95. }
  96. }
  97. }
  98. </script>
  99. <style lang="scss" scoped>
  100. .panelBoxWarp{
  101. position: relative;
  102. height: 100%;
  103. }
  104. .panelBox {
  105. width: 0px;
  106. min-height: 100%;
  107. display: flex;
  108. overflow: hidden;
  109. transition: 0.2s width ease;
  110. &.on{
  111. width: 200px;
  112. }
  113. .componentList{
  114. width: 64px;
  115. padding: 17px 0;
  116. text-align: center;
  117. li{
  118. position: relative;
  119. margin-bottom: 18px;
  120. .iconfont{
  121. font-size: 24px;
  122. }
  123. span{
  124. font-size: 12px;
  125. display: block;
  126. }
  127. &.on,&:hover{
  128. color: $mainColor;
  129. :after{
  130. content: '';
  131. position: absolute;
  132. left: 0;
  133. top: 0;
  134. width: 2px;
  135. height: 100%;
  136. background-color: $mainColor;
  137. }
  138. }
  139. }
  140. }
  141. .categoryList {
  142. border-left: 1px solid #F0F3F4;
  143. width: 186px;
  144. padding: 20px 0 20px 10px;
  145. .itemBox {
  146. h3 {
  147. padding-left: 20px;
  148. height: 35px;
  149. line-height: 35px;
  150. font-size: 16px;
  151. color: #333333;
  152. position: relative;
  153. &:before{
  154. content: '';
  155. border-left:5px solid $mainColor;
  156. border-top:4px solid transparent;
  157. border-bottom:4px solid transparent;
  158. position: absolute;
  159. left: 10px;
  160. top: 50%;
  161. margin-top: -4px;
  162. }
  163. }
  164. .childList {
  165. font-size: 14px;
  166. color: #333333;
  167. padding: 20px 10px;
  168. .list-group{
  169. display: flex;
  170. flex-wrap: wrap;
  171. :hover {
  172. background: #FF7800;
  173. color: #ffffff;
  174. border-radius: 3px;
  175. //cursor: move;
  176. }
  177. .childItemWarp{
  178. height: 80px;
  179. }
  180. .childItem {
  181. width: 50%;
  182. .contentBox{
  183. height: 100%;
  184. display: flex;
  185. flex-flow: column;
  186. align-items: center;
  187. justify-content: center;
  188. cursor: move;
  189. .iconfont{
  190. font-size: 30px;
  191. }
  192. span {
  193. margin-top: 5px;
  194. }
  195. }
  196. .cloneText{
  197. display: none;
  198. }
  199. }
  200. }
  201. }
  202. }
  203. }
  204. }
  205. .btnToggle{
  206. width: 20px;
  207. height: 66px;
  208. background-color: #fff;
  209. border-radius: 0 20px 20px 0;
  210. position: absolute;
  211. right: -20px;
  212. top: 50%;
  213. margin-top: -33px;
  214. display: flex;
  215. align-items: center;
  216. cursor: pointer;
  217. z-index: 9;
  218. .icon-arrow-left{
  219. display: none;
  220. }
  221. &.on{
  222. .icon-arrow-left{
  223. display: block;
  224. }
  225. .icon-arrow-right{
  226. display: none;
  227. }
  228. }
  229. }
  230. </style>