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.

235 lines
7.0 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
  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. export default {
  53. data() {
  54. return {
  55. dynamicMenuRoutes: [],
  56. search: '',
  57. categoryList: [],
  58. uFavoriteList: [],
  59. favoriteList: []
  60. }
  61. },
  62. components: {
  63. SubMenu
  64. },
  65. computed: {
  66. sidebarLayoutSkin: {
  67. get() {
  68. return this.$store.state.common.sidebarLayoutSkin
  69. }
  70. },
  71. sidebarFold: {
  72. get() {
  73. return this.$store.state.common.sidebarFold
  74. }
  75. },
  76. menuList:
  77. {
  78. get() {
  79. return this.$store.state.common.menuList
  80. },
  81. set(val) {
  82. this.$store.commit('common/updateMenuList', val)
  83. }
  84. },
  85. menuActiveName: {
  86. get() {
  87. return this.$store.state.common.menuActiveName
  88. },
  89. set(val) {
  90. this.$store.commit('common/updateMenuActiveName', val)
  91. }
  92. },
  93. mainTabs: {
  94. get() {
  95. return this.$store.state.common.mainTabs
  96. },
  97. set(val) {
  98. this.$store.commit('common/updateMainTabs', val)
  99. }
  100. },
  101. mainTabsActiveName: {
  102. get() {
  103. return this.$store.state.common.mainTabsActiveName
  104. },
  105. set(val) {
  106. this.$store.commit('common/updateMainTabsActiveName', val)
  107. }
  108. }
  109. },
  110. watch: {
  111. $route: 'routeHandle'
  112. },
  113. created() {
  114. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId!=73)
  115. this.favoriteList = JSON.parse(sessionStorage.getItem('menuList') || '[]').filter(item => item.menuId==73)
  116. this.userFavorites()
  117. this.dynamicMenuRoutes = JSON.parse(sessionStorage.getItem('dynamicMenuRoutes') || '[]')
  118. this.routeHandle(this.$route)
  119. },
  120. methods: {
  121. // 用户收藏夹
  122. userFavorites(){
  123. let query = {
  124. userId:this.$store.state.user.id,
  125. languageCode:this.$i18n.locale
  126. }
  127. userFavoriteList(query).then(({data})=> {
  128. if (data.list.length>0){
  129. this.favoriteList[0].list = data.list
  130. }
  131. })
  132. },
  133. // 搜索菜单方式1 start
  134. searchMenu1() {
  135. if (this.search == "") {
  136. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]')
  137. } else {
  138. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]')
  139. // this.menuList = this.treeFindPath(this.menuList).filter(this.search)
  140. let list = this.treeFindPath(this.menuList)
  141. list = this.distinct(list, list);
  142. this.menuList = list.filter(item => item.name.indexOf(this.search) != -1)
  143. }
  144. },
  145. // 树结构菜单转换list
  146. treeFindPath(tree, path = []) {
  147. if (!tree) return []
  148. for (const data of tree) {
  149. path.push(data)
  150. if (data.list != null) {
  151. path.push(...data.list)
  152. delete data.list
  153. }
  154. this.treeFindPath(data.list, path)
  155. }
  156. return path
  157. },
  158. // 搜索菜单方式1 去重 end
  159. distinct(a, b) {
  160. return Array.from(new Set([...a, ...b]))
  161. },
  162. // 搜索菜单方式2 start
  163. searchMenu() {
  164. if (this.search == "") {
  165. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]')
  166. } else {
  167. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]')
  168. this.menuList = this.filterTree(this.menuList,this.search)
  169. console.log(this.menuList)
  170. }
  171. },
  172. filterTree (tree = [], map , arr = []) {
  173. if (!tree.length)
  174. return []
  175. for (let item of tree) {
  176. if (map.indexOf(item.name)>-1){
  177. }
  178. continue
  179. let node = {...item, list: []}
  180. arr.push(node)
  181. if (item.list && item.list.length)
  182. this.filterTree(item.list, map, node.list) }
  183. return arr
  184. },
  185. // 路由操作
  186. routeHandle(route) {
  187. if (route.meta.isTab) {
  188. // tab选中, 不存在先添加
  189. var tab = this.mainTabs.filter(item => item.name === route.name)[0]
  190. if (!tab) {
  191. if (route.meta.isDynamic) {
  192. route = this.dynamicMenuRoutes.filter(item => item.name === route.name)[0]
  193. if (!route) {
  194. return console.error('未能找到可用标签页!')
  195. }
  196. }
  197. tab = {
  198. menuId: route.meta.menuId || route.name,
  199. name: route.name,
  200. title: route.meta.title,
  201. type: isURL(route.meta.iframeUrl) ? 'iframe' : 'module',
  202. iframeUrl: route.meta.iframeUrl || '',
  203. params: route.params,
  204. query: route.query
  205. }
  206. this.mainTabs = this.mainTabs.concat(tab)
  207. }
  208. this.menuActiveName = tab.menuId + ''
  209. this.mainTabsActiveName = tab.name
  210. }
  211. }
  212. }
  213. }
  214. </script>
  215. <style >
  216. .menu .el-input__inner {
  217. background: transparent;
  218. width: 100px;
  219. font-size: 12px;
  220. color: #FFFFFF;
  221. border: #0BB2D4;
  222. }
  223. </style>