| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
 | | import Menu from 'ant-design-vue/es/menu' |  | import Icon from 'ant-design-vue/es/icon' |  |   |  | const { Item, SubMenu } = Menu |  |   |  | export default { |  |   name: 'SMenu', |  |   props: { |  |     menu: { |  |       type: Array, |  |       required: true |  |     }, |  |     theme: { |  |       type: String, |  |       required: false, |  |       default: 'dark' |  |     }, |  |     mode: { |  |       type: String, |  |       required: false, |  |       default: 'inline' |  |     }, |  |     collapsed: { |  |       type: Boolean, |  |       required: false, |  |       default: false |  |     } |  |   }, |  |   data () { |  |     return { |  |       openKeys: [], |  |       selectedKeys: [], |  |       cachedOpenKeys: [] |  |     } |  |   }, |  |   computed: { |  |     rootSubmenuKeys: vm => { |  |       const keys = [] |  |       vm.menu.forEach(item => keys.push(item.path)) |  |       return keys |  |     } |  |   }, |  |   created () { |  |     this.updateMenu() |  |   }, |  |   watch: { |  |     collapsed (val) { |  |       if (val) { |  |         this.cachedOpenKeys = this.openKeys.concat() |  |         this.openKeys = [] |  |       } else { |  |         this.openKeys = this.cachedOpenKeys |  |       } |  |     }, |  |     $route: function () { |  |       this.updateMenu() |  |     } |  |   }, |  |   methods: { |  |     renderIcon: function (h, icon) { |  |       if (icon === 'none' || icon === undefined) { |  |         return null |  |       } |  |       const props = {} |  |       typeof (icon) === 'object' ? props.component = icon : props.type = icon |  |       return h(Icon, { props: { ...props } }) |  |     }, |  |     renderMenuItem: function (h, menu, pIndex, index) { |  |       const target = menu.meta.target || null |  |       return h(Item, { key: menu.path ? menu.path : 'item_' + pIndex + '_' + index }, [ |  |         h('router-link', { attrs: { to: { name: menu.name }, target: target } }, [ |  |           this.renderIcon(h, menu.meta.icon), |  |           h('span', [menu.meta.title]) |  |         ]) |  |       ]) |  |     }, |  |     renderSubMenu: function (h, menu, pIndex, index) { |  |       const this2_ = this |  |       const subItem = [h('span', { slot: 'title' }, [this.renderIcon(h, menu.meta.icon), h('span', [menu.meta.title])])] |  |       const itemArr = [] |  |       const pIndex_ = pIndex + '_' + index |  |       if (!menu.hideChildrenInMenu) { |  |         menu.children.forEach(function (item, i) { |  |           itemArr.push(this2_.renderItem(h, item, pIndex_, i)) |  |         }) |  |       } |  |       return h(SubMenu, { key: menu.path ? menu.path : 'submenu_' + pIndex + '_' + index }, subItem.concat(itemArr)) |  |     }, |  |     renderItem: function (h, menu, pIndex, index) { |  |       if (!menu.hidden) { |  |         return menu.children && !menu.hideChildrenInMenu |  |           ? this.renderSubMenu(h, menu, pIndex, index) |  |           : this.renderMenuItem(h, menu, pIndex, index) |  |       } |  |     }, |  |     renderMenu: function (h, menuTree) { |  |       const this2_ = this |  |       const menuArr = [] |  |       menuTree.forEach(function (menu, i) { |  |         if (!menu.hidden) { |  |           menuArr.push(this2_.renderItem(h, menu, '0', i)) |  |         } |  |       }) |  |       return menuArr |  |     }, |  |     onOpenChange (openKeys) { |  |       const latestOpenKey = openKeys.find(key => !this.openKeys.includes(key)) |  |       if (!this.rootSubmenuKeys.includes(latestOpenKey)) { |  |         this.openKeys = openKeys |  |       } else { |  |         this.openKeys = latestOpenKey ? [latestOpenKey] : [] |  |       } |  |     }, |  |     updateMenu () { |  |       const routes = this.$route.matched.concat() |  |   |  |       if (routes.length >= 4 && this.$route.meta.hidden) { |  |         routes.pop() |  |         this.selectedKeys = [routes[2].path] |  |       } else { |  |         this.selectedKeys = [routes.pop().path] |  |       } |  |   |  |       const openKeys = [] |  |       if (this.mode === 'inline') { |  |         routes.forEach(item => { |  |           openKeys.push(item.path) |  |         }) |  |       } |  |   |  |       this.collapsed ? (this.cachedOpenKeys = openKeys) : (this.openKeys = openKeys) |  |     } |  |   }, |  |   render (h) { |  |     return h( |  |       Menu, |  |       { |  |         props: { |  |           theme: this.$props.theme, |  |           mode: this.$props.mode, |  |           openKeys: this.openKeys, |  |           selectedKeys: this.selectedKeys |  |         }, |  |         on: { |  |           openChange: this.onOpenChange, |  |           select: obj => { |  |             this.selectedKeys = obj.selectedKeys |  |             this.$emit('select', obj) |  |           } |  |         } |  |       }, |  |       this.renderMenu(h, this.menu) |  |     ) |  |   } |  | } | 
 |