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.

252 lines
7.6 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. <template>
  2. <aside class="site-sidebar" :class="'site-sidebar--' + sidebarLayoutSkin">
  3. <div class="site-sidebar__inner">
  4. <el-menu
  5. :default-active="menuActiveName || 'home'"
  6. :collapse="sidebarFold"
  7. :collapseTransition="false"
  8. class="site-sidebar__menu">
  9. <el-menu-item style=" padding-left: 15px;" class="menu">
  10. <span slot="title"> <el-input v-model="search" placeholder="搜索"
  11. @keyup.enter.native="searchMenu1"></el-input></span>
  12. <i type="primary" class="el-icon-search" @click="searchMenu1()"></i>
  13. </el-menu-item>
  14. <el-menu-item index="home" @click="$router.push({ name: 'home' })">
  15. <icon-svg name="shouye" class="site-sidebar__menu-icon"></icon-svg>
  16. <span slot="title">{{ $t('commonhomePage') }}</span>
  17. </el-menu-item>
  18. <!-- <el-submenu index="demo">-->
  19. <!-- <template slot="title">-->
  20. <!-- <icon-svg name="shoucang" class="site-sidebar__menu-icon"></icon-svg>-->
  21. <!-- <span>demo</span>-->
  22. <!-- </template>-->
  23. <!-- <el-menu-item index="demo-echarts" @click="$router.push({ name: 'demo-echarts' })">-->
  24. <!-- <icon-svg name="tubiao" class="site-sidebar__menu-icon"></icon-svg>-->
  25. <!-- <span slot="title">echarts</span>-->
  26. <!-- </el-menu-item>-->
  27. <!-- <el-menu-item index="demo-ueditor" @click="$router.push({ name: 'demo-ueditor' })">-->
  28. <!-- <icon-svg name="editor" class="site-sidebar__menu-icon"></icon-svg>-->
  29. <!-- <span slot="title">ueditor</span>-->
  30. <!-- </el-menu-item>-->
  31. <!-- </el-submenu>-->
  32. <sub-menu
  33. v-for="menu in menuList"
  34. :key="menu.menuId"
  35. :menu="menu"
  36. :dynamicMenuRoutes="dynamicMenuRoutes">
  37. </sub-menu>
  38. <sub-menu
  39. v-for="menu in this.favoriteList"
  40. :key="menu.menuId"
  41. :menu="menu"
  42. :dynamicMenuRoutes="dynamicMenuRoutes">
  43. </sub-menu>
  44. </el-menu>
  45. </div>
  46. </aside>
  47. </template>
  48. <script>
  49. import SubMenu from './main-sidebar-sub-menu'
  50. import {isURL} from '@/utils/validate'
  51. import {userFavoriteList} from '@/api/userFavorite.js'
  52. import {treeDataTranslate} from '@/utils'
  53. export default {
  54. data() {
  55. return {
  56. dynamicMenuRoutes: [],
  57. search: '',
  58. categoryList: [],
  59. uFavoriteList: [],
  60. favoriteList: [],
  61. newMenuList: [],
  62. list: []
  63. }
  64. },
  65. components: {
  66. SubMenu
  67. },
  68. computed: {
  69. sidebarLayoutSkin: {
  70. get() {
  71. return this.$store.state.common.sidebarLayoutSkin
  72. }
  73. },
  74. sidebarFold: {
  75. get() {
  76. return this.$store.state.common.sidebarFold
  77. }
  78. },
  79. menuList:
  80. {
  81. get() {
  82. return this.$store.state.common.menuList
  83. },
  84. set(val) {
  85. this.$store.commit('common/updateMenuList', val)
  86. }
  87. },
  88. menuActiveName: {
  89. get() {
  90. return this.$store.state.common.menuActiveName
  91. },
  92. set(val) {
  93. this.$store.commit('common/updateMenuActiveName', val)
  94. }
  95. },
  96. mainTabs: {
  97. get() {
  98. return this.$store.state.common.mainTabs
  99. },
  100. set(val) {
  101. this.$store.commit('common/updateMainTabs', val)
  102. }
  103. },
  104. mainTabsActiveName: {
  105. get() {
  106. return this.$store.state.common.mainTabsActiveName
  107. },
  108. set(val) {
  109. this.$store.commit('common/updateMainTabsActiveName', val)
  110. }
  111. }
  112. },
  113. watch: {
  114. $route: 'routeHandle'
  115. },
  116. created() {
  117. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId != 73)
  118. this.favoriteList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId == 73)
  119. this.userFavorites()
  120. this.dynamicMenuRoutes = JSON.parse(sessionStorage.getItem('dynamicMenuRoutes') || '[]')
  121. this.routeHandle(this.$route)
  122. },
  123. methods: {
  124. // 用户收藏夹
  125. userFavorites() {
  126. let query = {
  127. userId: this.$store.state.user.id,
  128. languageCode: this.$i18n.locale
  129. }
  130. userFavoriteList(query).then(({data}) => {
  131. if (data.list.length > 0) {
  132. this.favoriteList[0].list = data.list
  133. }
  134. })
  135. },
  136. // 更具 当前节点id 获取上级节点
  137. getParent(val, sum) {
  138. if (val == 0) {
  139. return;
  140. }
  141. let parent = this.list.filter(item => item.menuId == val)
  142. if (parent.length > 0) {
  143. parent[0].list.length = 0
  144. sum.push(parent[0])
  145. this.getParent(parent[0].parentId, sum)
  146. }
  147. },
  148. // 搜索菜单方式1 start
  149. searchMenu1() {
  150. if (this.search == "") {
  151. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId != 73)
  152. } else {
  153. let menuPlus = []
  154. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId != 73)
  155. // this.menuList = this.treeFindPath(this.menuList).filter(this.search)
  156. // 转换成list
  157. this.list = this.treeFindPath(this.menuList)
  158. let list = this.treeFindPath(this.menuList)
  159. list = this.distinct(list, list);
  160. // list中获取菜单
  161. this.menuList = list.filter(item => item.name.indexOf(this.search) != -1)
  162. let menuSum = []
  163. for (let data of this.menuList) {
  164. menuSum.push(data)
  165. this.getParent(data.parentId, menuSum)
  166. }
  167. menuSum = Array.from(new Set([...menuSum]))
  168. if (menuSum.length > 0) {
  169. let menuList = menuSum.filter(item => item.parentId == 0);
  170. this.menuList=menuList
  171. this.treeList(menuList,menuSum)
  172. }
  173. }
  174. },
  175. // 封装树形结构
  176. treeList(menuList,menuSum) {
  177. for (let m1 of menuList) {
  178. for (let m2 of menuSum) {
  179. if (m1.menuId == m2.parentId){
  180. m1.list.push(m2)
  181. this.treeList( m1.list,menuSum)
  182. }
  183. }
  184. }
  185. },
  186. // 搜索菜单方式1 树结构菜单转换list
  187. treeFindPath(tree, path = []) {
  188. if (!tree) return []
  189. for (const data of tree) {
  190. path.push(data)
  191. // if (data.list != null) {
  192. // path.push(...data.list)
  193. // delete data.list
  194. // }
  195. this.treeFindPath(data.list, path)
  196. }
  197. return path
  198. },
  199. // 搜索菜单方式1 去重
  200. distinct(a, b) {
  201. return Array.from(new Set([...a, ...b]))
  202. },
  203. // 路由操作
  204. routeHandle(route) {
  205. if (route.meta.isTab) {
  206. // tab选中, 不存在先添加
  207. var tab = this.mainTabs.filter(item => item.name === route.name)[0]
  208. if (!tab) {
  209. if (route.meta.isDynamic) {
  210. route = this.dynamicMenuRoutes.filter(item => item.name === route.name)[0]
  211. if (!route) {
  212. return console.error('未能找到可用标签页!')
  213. }
  214. }
  215. tab = {
  216. menuId: route.meta.menuId || route.name,
  217. name: route.name,
  218. title: route.meta.title,
  219. type: isURL(route.meta.iframeUrl) ? 'iframe' : 'module',
  220. iframeUrl: route.meta.iframeUrl || '',
  221. params: route.params,
  222. query: route.query
  223. }
  224. this.mainTabs = this.mainTabs.concat(tab)
  225. }
  226. this.menuActiveName = tab.menuId + ''
  227. this.mainTabsActiveName = tab.name
  228. }
  229. }
  230. }
  231. }
  232. </script>
  233. <style>
  234. .menu .el-input__inner {
  235. background: transparent;
  236. width: 195px;
  237. font-size: 12px;
  238. color: #FFFFFF;
  239. border: #0BB2D4;
  240. }
  241. </style>