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.

261 lines
7.3 KiB

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