eoss-ui 0.6.53 → 0.6.55

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (260) hide show
  1. package/lib/checkbox-group.js +3 -3
  2. package/lib/data-table.js +6 -6
  3. package/lib/eoss-ui.common.js +817 -708
  4. package/lib/flow-list.js +95 -92
  5. package/lib/flow.js +280 -280
  6. package/lib/form.js +4 -4
  7. package/lib/index.js +1 -1
  8. package/lib/input.js +1 -1
  9. package/lib/login.js +3 -3
  10. package/lib/main.js +280 -215
  11. package/lib/menu.js +46 -10
  12. package/lib/qr-code.js +13 -13
  13. package/lib/radio-group.js +3 -3
  14. package/lib/select-ganged.js +1 -1
  15. package/lib/select.js +3 -1
  16. package/lib/selector-panel.js +3 -3
  17. package/lib/steps.js +3 -3
  18. package/lib/theme-chalk/flow.css +1 -1
  19. package/lib/theme-chalk/index.css +1 -1
  20. package/lib/theme-chalk/main.css +1 -1
  21. package/lib/theme-chalk/simplicity.css +1 -1
  22. package/lib/tips.js +3 -3
  23. package/lib/tree.js +3 -3
  24. package/lib/upload.js +20 -17
  25. package/package.json +159 -159
  26. package/packages/.DS_Store +0 -0
  27. package/packages/button/index.js +5 -5
  28. package/packages/button/src/main.vue +418 -418
  29. package/packages/button-group/index.js +5 -5
  30. package/packages/button-group/src/main.vue +298 -298
  31. package/packages/calendar/index.js +5 -5
  32. package/packages/card/index.js +5 -5
  33. package/packages/card/src/main.vue +156 -156
  34. package/packages/cascader/index.js +5 -5
  35. package/packages/cascader/src/main.vue +168 -168
  36. package/packages/checkbox-group/index.js +5 -5
  37. package/packages/checkbox-group/src/main.vue +333 -333
  38. package/packages/clients/index.js +5 -5
  39. package/packages/clients/src/main.vue +144 -144
  40. package/packages/data-table/.DS_Store +0 -0
  41. package/packages/data-table/index.js +5 -5
  42. package/packages/data-table/src/children.vue +39 -39
  43. package/packages/data-table/src/column.vue +989 -989
  44. package/packages/data-table/src/main.vue +1822 -1822
  45. package/packages/data-table/src/sizer.vue +195 -195
  46. package/packages/data-table-form/.DS_Store +0 -0
  47. package/packages/data-table-form/index.js +5 -5
  48. package/packages/data-table-form/src/checkbox.vue +101 -101
  49. package/packages/data-table-form/src/colgroup.vue +17 -17
  50. package/packages/data-table-form/src/main.vue +181 -181
  51. package/packages/data-table-form/src/radio.vue +65 -65
  52. package/packages/data-table-form/src/table.vue +233 -233
  53. package/packages/data-table-form/src/tbody.vue +336 -336
  54. package/packages/data-table-form/src/thead.vue +68 -68
  55. package/packages/date-picker/index.js +5 -5
  56. package/packages/date-picker/src/main.vue +236 -236
  57. package/packages/dialog/index.js +5 -5
  58. package/packages/enable-drag/index.js +5 -5
  59. package/packages/enterprise/index.js +5 -5
  60. package/packages/enterprise/src/main.vue +66 -66
  61. package/packages/error-page/.DS_Store +0 -0
  62. package/packages/error-page/index.js +5 -5
  63. package/packages/error-page/src/main.vue +44 -44
  64. package/packages/flow/.DS_Store +0 -0
  65. package/packages/flow/index.js +5 -5
  66. package/packages/flow/src/component/CommonOpinions.vue +345 -345
  67. package/packages/flow/src/component/CustomPreset.vue +322 -322
  68. package/packages/flow/src/component/FileList.vue +99 -99
  69. package/packages/flow/src/component/Preset.vue +255 -255
  70. package/packages/flow/src/component/SendMsg.vue +229 -229
  71. package/packages/flow/src/component/TimeLimit.vue +190 -190
  72. package/packages/flow/src/component/taskUnionExamine.vue +611 -611
  73. package/packages/flow/src/form.vue +121 -121
  74. package/packages/flow/src/freeStartFlow.vue +2843 -2843
  75. package/packages/flow/src/main.vue +3131 -3131
  76. package/packages/flow/src/processForm.vue +1031 -1031
  77. package/packages/flow/src/processReject.vue +293 -293
  78. package/packages/flow/src/reset.vue +900 -900
  79. package/packages/flow/src/startTaskRead.vue +641 -641
  80. package/packages/flow/src/supervise.vue +138 -138
  81. package/packages/flow/src/table.vue +58 -58
  82. package/packages/flow-group/.DS_Store +0 -0
  83. package/packages/flow-group/index.js +5 -5
  84. package/packages/flow-group/src/main.vue +688 -688
  85. package/packages/flow-list/index.js +5 -5
  86. package/packages/flow-list/src/main.vue +1437 -1434
  87. package/packages/form/.DS_Store +0 -0
  88. package/packages/form/index.js +5 -5
  89. package/packages/form/src/main.vue +3583 -3583
  90. package/packages/form/src/table.vue +1426 -1426
  91. package/packages/handle-user/index.js +5 -5
  92. package/packages/handle-user/src/main.vue +138 -138
  93. package/packages/handler/.DS_Store +0 -0
  94. package/packages/handler/index.js +5 -5
  95. package/packages/handler/src/main.vue +493 -493
  96. package/packages/icon/index.js +5 -5
  97. package/packages/icon/src/main.vue +101 -101
  98. package/packages/icons/index.js +5 -5
  99. package/packages/icons/src/main.vue +81 -81
  100. package/packages/input/index.js +5 -5
  101. package/packages/input/src/main.vue +356 -356
  102. package/packages/input-number/index.js +5 -5
  103. package/packages/input-number/src/main.vue +106 -106
  104. package/packages/label/index.js +5 -5
  105. package/packages/label/src/main.vue +457 -457
  106. package/packages/layout/index.js +5 -5
  107. package/packages/layout/src/item.vue +152 -152
  108. package/packages/layout/src/main.vue +31 -31
  109. package/packages/login/.DS_Store +0 -0
  110. package/packages/login/index.js +5 -5
  111. package/packages/login/src/main.vue +1935 -1935
  112. package/packages/login/src/resetPassword.vue +562 -562
  113. package/packages/main/.DS_Store +0 -0
  114. package/packages/main/index.js +5 -5
  115. package/packages/main/src/.DS_Store +0 -0
  116. package/packages/main/src/default/message.vue +249 -249
  117. package/packages/main/src/default/notice.vue +157 -157
  118. package/packages/main/src/default/userinfo.vue +503 -503
  119. package/packages/main/src/public/online.vue +89 -89
  120. package/packages/main/src/public/search.vue +462 -466
  121. package/packages/main/src/public/settings.vue +221 -221
  122. package/packages/main/src/simplicity/apps.vue +388 -388
  123. package/packages/main/src/simplicity/avatar.vue +82 -82
  124. package/packages/main/src/simplicity/handler.vue +259 -259
  125. package/packages/main/src/simplicity/index.vue +2076 -2064
  126. package/packages/main/src/simplicity/lists.vue +84 -84
  127. package/packages/main/src/simplicity/menu-list.vue +135 -128
  128. package/packages/main/src/simplicity/message.vue +259 -259
  129. package/packages/main/src/simplicity/notice.vue +190 -190
  130. package/packages/main/src/simplicity/router-page.vue +45 -45
  131. package/packages/main/src/simplicity/sub-menu.vue +263 -241
  132. package/packages/main/src/simplicity/user.vue +257 -257
  133. package/packages/main/src/simplicity/userinfo.vue +312 -312
  134. package/packages/menu/index.js +5 -5
  135. package/packages/menu/src/main.vue +580 -536
  136. package/packages/nav/index.js +5 -5
  137. package/packages/nav/src/main.vue +351 -351
  138. package/packages/notify/index.js +5 -5
  139. package/packages/notify/src/main.vue +538 -538
  140. package/packages/page/index.js +5 -5
  141. package/packages/page/src/main.vue +167 -167
  142. package/packages/pagination/index.js +5 -5
  143. package/packages/pagination/src/main.vue +96 -96
  144. package/packages/player/index.js +5 -5
  145. package/packages/player/src/main.vue +194 -194
  146. package/packages/qr-code/index.js +5 -5
  147. package/packages/qr-code/src/main.vue +170 -170
  148. package/packages/radio-group/index.js +6 -6
  149. package/packages/radio-group/src/main.vue +319 -319
  150. package/packages/retrial-auth/.DS_Store +0 -0
  151. package/packages/retrial-auth/index.js +5 -5
  152. package/packages/retrial-auth/src/main.vue +280 -280
  153. package/packages/select/.DS_Store +0 -0
  154. package/packages/select/index.js +5 -5
  155. package/packages/select/src/main.vue +778 -776
  156. package/packages/select-ganged/index.js +5 -5
  157. package/packages/select-ganged/src/main.vue +724 -724
  158. package/packages/selector/.DS_Store +0 -0
  159. package/packages/selector/index.js +5 -5
  160. package/packages/selector/src/main.vue +687 -687
  161. package/packages/selector-panel/.DS_Store +0 -0
  162. package/packages/selector-panel/index.js +5 -5
  163. package/packages/selector-panel/src/main.vue +1027 -1027
  164. package/packages/selector-panel/src/selection.vue +177 -177
  165. package/packages/selector-panel/src/tree.vue +129 -129
  166. package/packages/sizer/.DS_Store +0 -0
  167. package/packages/sizer/index.js +5 -5
  168. package/packages/sizer/src/main.vue +254 -254
  169. package/packages/steps/index.js +5 -5
  170. package/packages/steps/src/main.vue +181 -181
  171. package/packages/switch/index.js +5 -5
  172. package/packages/switch/src/main.vue +154 -154
  173. package/packages/table-form/index.js +5 -5
  174. package/packages/tabs/.DS_Store +0 -0
  175. package/packages/tabs/index.js +5 -5
  176. package/packages/tabs/src/main.vue +788 -788
  177. package/packages/tabs-panel/index.js +5 -5
  178. package/packages/tabs-panel/src/main.vue +29 -29
  179. package/packages/theme-chalk/lib/flow.css +1 -1
  180. package/packages/theme-chalk/lib/index.css +1 -1
  181. package/packages/theme-chalk/lib/main.css +1 -1
  182. package/packages/theme-chalk/lib/simplicity.css +1 -1
  183. package/packages/theme-chalk/src/.DS_Store +0 -0
  184. package/packages/theme-chalk/src/base.scss +260 -260
  185. package/packages/theme-chalk/src/button-group.scss +175 -175
  186. package/packages/theme-chalk/src/button.scss +24 -24
  187. package/packages/theme-chalk/src/calendar.scss +113 -113
  188. package/packages/theme-chalk/src/card.scss +99 -99
  189. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  190. package/packages/theme-chalk/src/clients.scss +87 -87
  191. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  192. package/packages/theme-chalk/src/data-table.scss +293 -293
  193. package/packages/theme-chalk/src/date-picker.scss +7 -7
  194. package/packages/theme-chalk/src/dialog.scss +77 -77
  195. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  196. package/packages/theme-chalk/src/enterprise.scss +5 -5
  197. package/packages/theme-chalk/src/error-page.scss +18 -18
  198. package/packages/theme-chalk/src/flow-group.scss +110 -110
  199. package/packages/theme-chalk/src/flow-list.scss +36 -36
  200. package/packages/theme-chalk/src/flow.scss +336 -335
  201. package/packages/theme-chalk/src/form.scss +496 -496
  202. package/packages/theme-chalk/src/handle-user.scss +40 -40
  203. package/packages/theme-chalk/src/handler.scss +143 -143
  204. package/packages/theme-chalk/src/icon.scss +1789 -1789
  205. package/packages/theme-chalk/src/icons.scss +99 -99
  206. package/packages/theme-chalk/src/input.scss +9 -9
  207. package/packages/theme-chalk/src/label.scss +24 -24
  208. package/packages/theme-chalk/src/layout.scss +46 -46
  209. package/packages/theme-chalk/src/login.scss +969 -969
  210. package/packages/theme-chalk/src/main.scss +663 -663
  211. package/packages/theme-chalk/src/menu.scss +222 -222
  212. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  213. package/packages/theme-chalk/src/nav.scss +111 -111
  214. package/packages/theme-chalk/src/page.scss +3 -3
  215. package/packages/theme-chalk/src/pagination.scss +29 -29
  216. package/packages/theme-chalk/src/player.scss +9 -9
  217. package/packages/theme-chalk/src/qr-code.scss +17 -17
  218. package/packages/theme-chalk/src/radio-group.scss +9 -9
  219. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  220. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  221. package/packages/theme-chalk/src/select.scss +8 -8
  222. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  223. package/packages/theme-chalk/src/selector.scss +91 -91
  224. package/packages/theme-chalk/src/simplicity.scss +1343 -1265
  225. package/packages/theme-chalk/src/sizer.scss +36 -36
  226. package/packages/theme-chalk/src/steps.scss +88 -88
  227. package/packages/theme-chalk/src/switch.scss +3 -3
  228. package/packages/theme-chalk/src/table-form.scss +1 -1
  229. package/packages/theme-chalk/src/tabs.scss +87 -87
  230. package/packages/theme-chalk/src/tips.scss +7 -7
  231. package/packages/theme-chalk/src/toolbar.scss +179 -179
  232. package/packages/theme-chalk/src/tree-group.scss +72 -72
  233. package/packages/theme-chalk/src/tree.scss +165 -165
  234. package/packages/theme-chalk/src/upload.scss +168 -168
  235. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  236. package/packages/tips/index.js +5 -5
  237. package/packages/tips/src/main.vue +141 -141
  238. package/packages/toolbar/index.js +5 -5
  239. package/packages/toolbar/src/main.vue +430 -430
  240. package/packages/tree/index.js +5 -5
  241. package/packages/tree/src/main.vue +2 -2
  242. package/packages/tree-group/index.js +5 -5
  243. package/packages/upload/.DS_Store +0 -0
  244. package/packages/upload/index.js +5 -5
  245. package/packages/upload/src/main.vue +1347 -1343
  246. package/packages/upload/src/picture.js +15 -15
  247. package/packages/wujie/index.js +5 -5
  248. package/packages/wujie/src/main.vue +145 -145
  249. package/packages/wxlogin/index.js +5 -5
  250. package/packages/wxlogin/src/main.vue +128 -128
  251. package/src/.DS_Store +0 -0
  252. package/src/config/api.js +281 -281
  253. package/src/config/image.js +2 -2
  254. package/src/index.js +160 -160
  255. package/src/utils/bus.js +3 -3
  256. package/src/utils/date-util.js +312 -312
  257. package/src/utils/http.js +50 -50
  258. package/src/utils/rules.js +18 -18
  259. package/src/utils/store.js +21 -21
  260. package/src/utils/webSocket.js +107 -107
@@ -1,2064 +1,2076 @@
1
- <template>
2
- <div class="es-main">
3
- <div class="es-simplicity-side">
4
- <img class="es-simplicity-logo" v-if="mainLogo" :src="mainLogo" />
5
- <div
6
- class="es-simplicity-org-name es-text-ellipsis-row2"
7
- :title="simpleUserInfo.orgShortName || simpleUserInfo.orgName"
8
- >
9
- {{ simpleUserInfo.orgShortName || simpleUserInfo.orgName }}
10
- </div>
11
- <el-popover
12
- class="es-simplicity-user-popover"
13
- placement="right-start"
14
- width="360"
15
- trigger="click"
16
- >
17
- <!-- 用户信息 -->
18
- <user
19
- :user="user"
20
- :notifyList="notifyList"
21
- :notify="notify"
22
- :contents="userInfoContents"
23
- @success="handleSuccess"
24
- @change="handleChangeConfig"
25
- @close="handlerClose"
26
- ></user>
27
- <avatar slot="reference" :user="user" :size="56"> </avatar>
28
- <!-- 用户信息 end -->
29
- </el-popover>
30
- <div class="es-simplicity-side-Application">
31
- <!-- 常用应用 -->
32
- <el-scrollbar>
33
- <div
34
- class="es-simplicity-side-app"
35
- v-for="item in userApps"
36
- :class="{ 'is-active': active == item.id }"
37
- :key="item.id"
38
- :title="item.text || item.name"
39
- @click="handlerClickApp(item)"
40
- >
41
- <el-badge
42
- class="es-simplicity-side-app-badge"
43
- v-bind="getBadge(item)"
44
- >
45
- <es-icon
46
- class="es-simplicity-side-app-icon"
47
- :contents="item.icons || item.icon || menuIcon"
48
- ></es-icon>
49
- <div class="es-simplicity-side-app-text">
50
- {{ item.text || item.name }}
51
- </div>
52
- </el-badge>
53
- </div>
54
- <div
55
- class="es-simplicity-side-app"
56
- @click="handlerClickApp()"
57
- v-show="menus.length"
58
- >
59
- <es-icon
60
- class="es-simplicity-side-app-icon"
61
- contents="es-icon-omit"
62
- ></es-icon>
63
- <div class="es-simplicity-side-app-text">更多</div>
64
- </div>
65
- <div
66
- class="es-simplicity-side-app"
67
- v-for="(item, index) in newApps"
68
- :class="{ 'is-active': active == item.id }"
69
- :key="item.id"
70
- :title="item.text || item.name"
71
- @click.stop="handlerClickApp(item)"
72
- >
73
- <i
74
- class="el-icon-circle-close"
75
- @click.stop="handleDelete(index)"
76
- ></i>
77
- <el-badge v-bind="getBadge(item)">
78
- <es-icon
79
- class="es-simplicity-side-app-icon"
80
- :contents="item.icons || item.icon || menuIcon"
81
- ></es-icon>
82
- <div class="es-simplicity-side-app-text">
83
- {{ item.text || item.name }}
84
- </div>
85
- </el-badge>
86
- </div>
87
- </el-scrollbar>
88
- <!-- 常用应用 end -->
89
- </div>
90
- <div class="es-simplicity-side-app" v-if="_aiConfig && showAi">
91
- <img
92
- :src="_aiConfig.icon"
93
- class="es-simplicity-ai-icon"
94
- @click="handlerSetDrawer(_aiConfig, 'ai')"
95
- />
96
- </div>
97
- </div>
98
- <div class="es-simplicity-main">
99
- <!-- 应用 -->
100
- <apps
101
- :visible.sync="showApps"
102
- :menu-icon="menuIcon"
103
- :color="appColor"
104
- :backgroundColor="appBackgroundColor"
105
- :applications="applications"
106
- :business="business"
107
- :systems="systems"
108
- :user="user"
109
- @click="handlerClickApps"
110
- ></apps>
111
- <!-- 应用 end -->
112
-
113
- <!-- AI/IM -->
114
- <el-drawer
115
- class="es-simplicity-public-drawer"
116
- :direction="drawer.direction"
117
- modal-class="es-simplicity-apps-modal"
118
- size="100%"
119
- show-close
120
- :modal-append-to-body="false"
121
- :visible.sync="drawer.visible"
122
- >
123
- <div
124
- class="es-public-drawer-main"
125
- v-if="drawer.ai && drawer.ai.url"
126
- v-show="drawer.active == 'ai'"
127
- >
128
- <template v-if="isIE || drawer.ai.method !== 'wujie'">
129
- <iframe
130
- frameborder="0"
131
- width="100%"
132
- height="100%"
133
- :src="drawer.ai.url"
134
- ></iframe>
135
- </template>
136
- <template v-else>
137
- <es-wujie
138
- :host="host"
139
- :show="true"
140
- :props="wjProps"
141
- :attrs="wjAttrs"
142
- :name="drawer.ai.name"
143
- :url="drawer.ai.url"
144
- ></es-wujie>
145
- </template>
146
- </div>
147
- <div
148
- class="es-public-drawer-main"
149
- v-if="drawer.im && drawer.im.url"
150
- v-show="drawer.active == 'im'"
151
- >
152
- <template v-if="isIE || drawer.im.method !== 'wujie'">
153
- <iframe
154
- frameborder="0"
155
- width="100%"
156
- height="100%"
157
- :src="drawer.im.url"
158
- ></iframe>
159
- </template>
160
- <template v-else>
161
- <es-wujie
162
- :host="host"
163
- :show="true"
164
- :props="wjProps"
165
- :attrs="wjAttrs"
166
- :name="drawer.im.name"
167
- :url="drawer.im.url"
168
- ></es-wujie>
169
- </template>
170
- </div>
171
- </el-drawer>
172
- <!-- AI/IM end -->
173
-
174
- <!-- 路由、iframe -->
175
- <div class="es-simplicity-tabs-handler-mask" v-show="showTabsHandler">
176
- <el-card class="es-simplicity-tabs-handler" ref="tabsHandler">
177
- <div
178
- class="es-simplicity-tabs-handler-item"
179
- :class="{ 'is-disabled': isDisabled.refresh }"
180
- @click="isDisabled.refresh ? '' : handleTabsEvents(0)"
181
- >
182
- 刷新
183
- </div>
184
- <div
185
- class="es-simplicity-tabs-handler-item"
186
- @click="handleTabsEvents(1)"
187
- >
188
- 关闭标签
189
- </div>
190
- <div
191
- class="es-simplicity-tabs-handler-item"
192
- :class="{ 'is-disabled': isDisabled.other }"
193
- @click="isDisabled.other ? '' : handleTabsEvents(2)"
194
- >
195
- 关闭其他
196
- </div>
197
- <div
198
- class="es-simplicity-tabs-handler-item"
199
- :class="{ 'is-disabled': isDisabled.left }"
200
- @click="isDisabled.left ? '' : handleTabsEvents(3)"
201
- >
202
- 关闭左侧
203
- </div>
204
- <div
205
- class="es-simplicity-tabs-handler-item"
206
- :class="{ 'is-disabled': isDisabled.right }"
207
- @click="isDisabled.right ? '' : handleTabsEvents(4)"
208
- >
209
- 关闭右侧
210
- </div>
211
- </el-card>
212
- </div>
213
- <el-tabs
214
- class="es-simplicity-iframe"
215
- :class="{ 'is-open': showMenu, 'is-fold': fold }"
216
- v-model="activeName"
217
- closable
218
- hide-bar
219
- opacity
220
- @tab-remove="handleRemove"
221
- @tab-contextmenu="handleContextmenu"
222
- >
223
- <!-- 操作栏 -->
224
- <handler
225
- slot="append"
226
- v-bind="handleConfig"
227
- :data="handleData"
228
- :hide="hide"
229
- :contact="contact"
230
- :online="userNums"
231
- :notice-num="notice"
232
- @click="handleClick"
233
- ></handler>
234
- <!-- 操作栏 end-->
235
-
236
- <!-- 菜单 -->
237
- <sub-menu
238
- :mode="mode"
239
- :visible.sync="showMenu"
240
- :closed.sync="fold"
241
- :size="menuWidth"
242
- :title="title"
243
- :color="menuColor"
244
- :backgroundColor="menuBackgroundColor"
245
- :menu-icon="menuIcon"
246
- :active="subActive"
247
- v-bind="subMenus"
248
- @command="handlerClickMenu"
249
- ></sub-menu>
250
- <!-- 菜单 end -->
251
- <el-tab-pane
252
- v-for="item in tabs"
253
- :key="item.id"
254
- :label="item.text || item.name"
255
- :name="item.id"
256
- >
257
- <router-page
258
- v-if="item.method === 'router'"
259
- v-bind="item"
260
- :query="$parent.params"
261
- ></router-page>
262
- <iframe
263
- v-else-if="isIE || item.method == 'iframe'"
264
- :id="activeName == item.id ? iframeId : ''"
265
- :name="activeName == item.id ? iframeId : ''"
266
- frameborder="0"
267
- width="100%"
268
- height="100%"
269
- :src="item.url"
270
- ></iframe>
271
- <es-wujie
272
- v-else-if="item.method === 'wujie' && item.url"
273
- :host="host"
274
- :show="true"
275
- :props="wjProps"
276
- :attrs="wjAttrs"
277
- :name="item.appCode"
278
- :url="item.url"
279
- ></es-wujie>
280
- </el-tab-pane>
281
- </el-tabs>
282
- <!-- 路由、iframe end -->
283
-
284
- <!-- 消息列表 -->
285
- <message
286
- v-if="showMsg"
287
- ref="message"
288
- :total.sync="notice"
289
- :visible.sync="showMsg"
290
- :winopen="winopen"
291
- @ignore="handleChange"
292
- @handle="handleMenuTips"
293
- ></message>
294
- <!-- 消息列表 end-->
295
-
296
- <!-- 设置 -->
297
- <settings
298
- v-bind="$attrs"
299
- layout-type="simplicity"
300
- active="simplicity"
301
- :theme="themeColor"
302
- :predefine="themes"
303
- :visible.sync="showSet"
304
- @change="handleChange"
305
- @layout="handleLayout"
306
- ></settings>
307
- <!-- 设置 end-->
308
-
309
- <!-- 消息提醒 -->
310
- <notice :data="sysMsg" :winopen="winopen" @opened="handleOpened"></notice>
311
- <!-- 消息提醒 end -->
312
-
313
- <es-dialog
314
- class="es-public-search-dialog"
315
- :visible.sync="showSearch"
316
- size="lg"
317
- >
318
- <search
319
- :apps="applications"
320
- :menus="menus"
321
- :menuIcon="menuIcon"
322
- @select="handleSelect"
323
- ></search>
324
- </es-dialog>
325
- <!-- 公用弹窗 -->
326
- <es-dialog :title="dialog.title" :visible.sync="dialog.show" size="md">
327
- <template v-if="dialog.title == '查看在线人员' && !dialog.src">
328
- <online></online>
329
- </template>
330
- <iframe
331
- v-else-if="dialog.show"
332
- width="100%"
333
- height="100%"
334
- frameborder="0"
335
- :src="dialog.src"
336
- ></iframe>
337
- </es-dialog>
338
- <!-- 公用弹窗 end -->
339
- </div>
340
- </div>
341
- </template>
342
-
343
- <script>
344
- import avatar from './avatar.vue';
345
- import handler from './handler.vue';
346
- import subMenu from './sub-menu.vue';
347
- import apps from './apps.vue';
348
- import user from './user.vue';
349
- import message from './message.vue';
350
- import notice from './notice.vue';
351
- import settings from '../public/settings.vue';
352
- import routerPage from './router-page.vue';
353
- import online from '../public/online.vue';
354
- import search from '../public/search.vue';
355
- import {
356
- wss,
357
- logout,
358
- topic,
359
- getUserAppWithTag,
360
- recordUserApp,
361
- getComplexApplications,
362
- getComplexApplicationsNew
363
- } from 'eoss-ui/src/config/api.js';
364
- import store from 'eoss-ui/src/utils/store';
365
- import util from 'eoss-ui/src/utils/util';
366
- const isIE = navigator.userAgent.indexOf('MSIE') != -1;
367
- const systemMode = util.win.systemMode || 'default';
368
- let events = [
369
- (tabs, index, that) => {
370
- let tab = tabs[index];
371
- if (tab.method == 'iframe') {
372
- tabs[index].url = util.handlerUrl(tab.url);
373
- }
374
- if (tab.method === 'wujie' && tab.appCode) {
375
- const url = tab.url;
376
- tab.url = '';
377
- that.$nextTick(() => {
378
- tab.url = url;
379
- });
380
- }
381
- if (tab.method === 'router') {
382
- that.$set(tabs[index], 'keys', util.uuid());
383
- }
384
- return tabs;
385
- },
386
- (tabs, index, that) => {
387
- let i = util.indexOfObj(tabs, that.activeName, 'id');
388
- if (tabs.length == 1) {
389
- that.activeName = '';
390
- } else if (i == index) {
391
- if (index < tabs.length - 1) {
392
- that.activeName = tabs[index + 1].id;
393
- } else {
394
- that.activeName = tabs[index - 1].id;
395
- }
396
- }
397
- tabs.splice(index, 1);
398
- return tabs;
399
- },
400
- (tabs, index, that) => {
401
- let tab = tabs.slice(index, index + 1);
402
- that.activeName = tab[0].id;
403
- return tab;
404
- },
405
- (tabs, index, that) => {
406
- let i = util.indexOfObj(tabs, that.activeName, 'id');
407
- if (i < index) {
408
- that.activeName = tabs[index].id;
409
- }
410
- tabs.splice(0, index);
411
- return tabs;
412
- },
413
- (tabs, index, that) => {
414
- let i = util.indexOfObj(tabs, that.activeName, 'id');
415
- if (i > index) {
416
- that.activeName = tabs[index].id;
417
- }
418
- tabs.splice(index + 1, tabs.length - index);
419
- return tabs;
420
- }
421
- ];
422
- export default {
423
- name: 'Simplicity',
424
- provide() {
425
- return {
426
- esMain: this,
427
- refresh: this.handleRefresh,
428
- jumpMenu: this.jumpMenu
429
- };
430
- },
431
- components: {
432
- avatar,
433
- handler,
434
- subMenu,
435
- apps,
436
- user,
437
- message,
438
- notice,
439
- settings,
440
- routerPage,
441
- online,
442
- search
443
- },
444
- props: {
445
- //im用例编码
446
- imUseCaseCode: String,
447
- //ai用例编码
448
- aiUseCaseCode: String,
449
- //模式
450
- mode: {
451
- type: String,
452
- default: systemMode
453
- },
454
- sysCode: String,
455
- appCode: String,
456
- //logo
457
- logo: String,
458
- //菜单、应用默认图标
459
- menuIcon: {
460
- type: String,
461
- default: 'es-icon-application'
462
- },
463
- //默认主题颜色
464
- theme: {
465
- type: String,
466
- default: '#409eff'
467
- },
468
- //主题颜色选择颜色集合
469
- themes: Array,
470
- //操作栏配置
471
- handleData: Array,
472
- //操作栏单项配置
473
- handleConfig: Object,
474
- //需要隐藏的头部功能
475
- hides: Object,
476
- //菜单颜色
477
- menuColor: [String, Array],
478
- //菜单背景颜色
479
- menuBackgroundColor: [String, Array],
480
- //应用颜色
481
- appColor: [String, Array],
482
- //应用背景颜色
483
- appBackgroundColor: [String, Array],
484
- //默认头像
485
- userHead: String,
486
- //应用列表接口
487
- appsUrl: {
488
- type: String,
489
- default: getUserAppWithTag
490
- },
491
- //是否启用子应用菜单接口
492
- application: {
493
- type: Boolean,
494
- default: false
495
- },
496
- //菜单接口
497
- menuUrl: String,
498
- //远程请求菜单
499
- remote: {
500
- type: Boolean,
501
- default: true
502
- },
503
- //websocket
504
- socket: {
505
- type: Boolean,
506
- default: true
507
- },
508
- //iframeId
509
- iframeId: {
510
- type: String,
511
- default: 'stage'
512
- },
513
- //查看在线人数
514
- onlineView: {
515
- type: [String, Boolean],
516
- default: true
517
- },
518
- //消息办理是否采用window.open的方式打开
519
- winopen: {
520
- type: Boolean,
521
- default: true
522
- },
523
- //是否采用wujie微前端加载页面
524
- loadWujie: {
525
- type: Boolean,
526
- default: true
527
- },
528
- //无界微前端Props属性
529
- wjProps: Object,
530
- //无界微前端Attrs属性
531
- wjAttrs: Object,
532
- //菜单宽度
533
- menuWidth: {
534
- type: Number,
535
- default: 220
536
- },
537
- //路由方式
538
- routeType: String,
539
- host: {
540
- type: String,
541
- default() {
542
- return sessionStorage.getItem('host') || '';
543
- }
544
- },
545
- //切换旧版样式
546
- oldVersion: Boolean,
547
- //运维联系人
548
- contacts: Object
549
- },
550
- data() {
551
- return {
552
- //用例权限编码
553
- useCaseCodes: util.getStorage('useCaseCodes'),
554
- //显示用户信息
555
- showUser: false,
556
- //主题色
557
- themeColor: this.theme,
558
- //是否ie浏览器
559
- isIE: isIE,
560
- //logo
561
- mainLogo: this.logo,
562
- //侧边用户应用
563
- userApps: [],
564
- //点击应用存侧边
565
- newApps: [],
566
- //所有菜单
567
- menus: [],
568
- //菜单名称
569
- title: '',
570
- //子菜单
571
- subMenus: null,
572
- //展示菜单导航
573
- showMenu: false,
574
- //子菜单选中
575
- subActive: '',
576
- //折叠菜单
577
- fold: false,
578
- //人工智能配置
579
- aiConfig: null,
580
- //im配置
581
- imConfig: null,
582
- //公用窗口面板配置
583
- drawer: {
584
- visible: false,
585
- direction: 'ltr',
586
- ai: {},
587
- im: {},
588
- active: ''
589
- },
590
- //所有应用
591
- applications: [],
592
- //业务系统
593
- business: [],
594
- //系统管理
595
- systems: [],
596
- //气泡数
597
- menuTips: {},
598
- //展示所有应用
599
- showApps: false,
600
- //用户信息
601
- userModel: {},
602
- //通知类型列表
603
- notifyList: [],
604
- //用户样式
605
- userStyle: {},
606
- //通知类型
607
- notify: '',
608
- //用户信息表单结构
609
- userInfoContents: undefined,
610
- //窗口页签
611
- tabs: [],
612
- //页签选中name
613
- activeName: '',
614
- //初始应用菜单页
615
- initApps: null,
616
- //首页地址
617
- indexUrl: '',
618
- //首页配置
619
- homePage: {},
620
- //门户跳转页地址
621
- doorIndex: '',
622
- //弹窗
623
- dialog: {},
624
- //在线人数
625
- userNums: 1,
626
- //消息列表展示状态
627
- showMsg: false,
628
- //搜索
629
- showSearch: false,
630
- //消息数
631
- notice: 0,
632
- //即时消息
633
- sysMsg: [],
634
- //定时关闭及时消息对象
635
- sysMsgOut: null,
636
- //额外信息数据
637
- extraData: '',
638
- //显示设置面板
639
- showSet: false,
640
- //窗口是否可选
641
- isDisabled: {},
642
- //显示页签操作
643
- showTabsHandler: false,
644
- //页签对象
645
- pane: null,
646
- //选中菜单
647
- active: '',
648
- //单位名称
649
- simpleUserInfo: {},
650
- topRightToolHide: '',
651
- showOld: this.oldVersion,
652
- //运维联系人
653
- contact: this.contacts,
654
- //单点退出地址
655
- singleLogout: null
656
- };
657
- },
658
- computed: {
659
- //菜单接口
660
- _menuUrl() {
661
- if (this.menuUrl) {
662
- return this.menuUrl;
663
- }
664
- if (this.application) {
665
- return getComplexApplicationsNew;
666
- }
667
- return getComplexApplications;
668
- },
669
- //人工智能配置
670
- _aiConfig() {
671
- return this.aiConfig
672
- ? {
673
- ...this.aiConfig,
674
- icon: ''
675
- }
676
- : false;
677
- },
678
- showAi() {
679
- return this.aiUseCaseCode
680
- ? this.useCaseCodes.indexOf(this.aiUseCaseCode) > -1
681
- : true;
682
- },
683
- //用户信息
684
- user() {
685
- return this.userModel ? this.userModel : store.get('userModel');
686
- },
687
- //在线人数列表地址
688
- onlineUrl() {
689
- if (this.onlineView) {
690
- return typeof this.onlineView == 'string' ? this.onlineView : '';
691
- }
692
- return false;
693
- },
694
- //隐藏操作按键
695
- hide() {
696
- let topRightToolHide = {};
697
- if (this.topRightToolHide) {
698
- topRightToolHide = JSON.parse(
699
- this.topRightToolHide.replace(
700
- /(['"])?([a-zA-Z0-9_]+)(['"])?:/g,
701
- '"$2":'
702
- )
703
- );
704
- }
705
- let hides = {
706
- im: this.imConfig
707
- ? this.imUseCaseCode
708
- ? this.useCaseCodes.indexOf(this.imUseCaseCode) == -1
709
- : false
710
- : true,
711
- home: this.indexUrl ? false : true,
712
- index: this.doorIndex ? false : true,
713
- old: this.showOld ? false : true
714
- };
715
-
716
- if (this.layout === 'subsystem' || this.application) {
717
- hides.system = false;
718
- }
719
- if (this.layout === 'topside' || this.layout === 'side') {
720
- hides.user = true;
721
- }
722
- return { ...hides, ...this.hides, ...topRightToolHide };
723
- }
724
- },
725
- watch: {
726
- menuTips: {
727
- deep: true,
728
- handler() {
729
- this.setTips(this.userApps);
730
- this.setTips(this.applications);
731
- this.setTips(this.business);
732
- this.setTips(this.systems);
733
- this.setTips(this.menus);
734
- }
735
- }
736
- },
737
- created() {
738
- this.doorIndex = sessionStorage.getItem('doorIndex');
739
- },
740
- mounted() {
741
- this.handleListener();
742
- },
743
- methods: {
744
- /**
745
- * @desc:匹配路由
746
- * @author huangbo
747
- * @date 2024年9月7日
748
- **/
749
- hasRouter(res, url, code) {
750
- if (!url) {
751
- return false;
752
- }
753
- if (Array.isArray(res)) {
754
- for (let i in res) {
755
- let path = this.hasRouter(res[i], url, code);
756
- if (path) {
757
- return path;
758
- }
759
- }
760
- } else {
761
- let path = res.path;
762
- if (path !== '/' && path !== '/404') {
763
- path = path.replace(path[1], path[1].toLowerCase());
764
- }
765
- let pathname = url.substring(url.indexOf('#/') + 1);
766
- pathname = pathname.split('?')[0];
767
- let appCode;
768
- if (res.path !== '/' && pathname == path) {
769
- if (res.components) {
770
- if (!res.components[code]) {
771
- console.error(
772
- '路由“命名视图”规范属性名称与菜单appCode不一致',
773
- res,
774
- code
775
- );
776
- appCode = Object.keys(res.components).filter((item) => {
777
- return item !== 'default';
778
- })[0];
779
- }
780
- } else {
781
- console.error(
782
- '请根据路由“命名视图”规范,正确添加components属性名称',
783
- res
784
- );
785
- }
786
- return appCode ? { path: pathname, appCode } : pathname;
787
- }
788
- if (res && Object.prototype.hasOwnProperty.call(res, 'children')) {
789
- let path = this.hasRouter(res.children, url, code);
790
- if (path) {
791
- return path;
792
- }
793
- }
794
- }
795
- return false;
796
- },
797
- /**
798
- * @desc:获取初始数据
799
- * @author huangbo
800
- * @date 2024年9月7日
801
- **/
802
- init(results, first) {
803
- this.setConfig(results);
804
- if (this.remote && first) {
805
- this.getApplications();
806
- }
807
- },
808
- /**
809
- * @desc:设置用户配置及信息
810
- * @author huangbo
811
- * @date 2024年9月7日
812
- **/
813
- setConfig(results) {
814
- localStorage.setItem('mainConfig', JSON.stringify(results));
815
- util.setStorage({
816
- type: this.storage,
817
- key: {
818
- depId: results.userModel.depId,
819
- orgId: results.userModel.orgId,
820
- userId: results.userModel.userId,
821
- userName: results.userModel.username || results.userModel.userName,
822
- useCaseCodes: results.resourceCodes || results.userModel.resourceCodes
823
- }
824
- });
825
- for (let i in results) {
826
- if (i === 'mainLogoUrl' && results[i]) {
827
- this.mainLogo = results[i];
828
- }
829
- if (
830
- i === 'mainBannerUrl' &&
831
- results[i] &&
832
- this.headerImage === undefined
833
- ) {
834
- this.headerImg = results[i];
835
- }
836
- if (i === 'initApplication' && results[i]) {
837
- this.initApps = results[i].split(',');
838
- }
839
- if (i === 'indexUrl' && results[i]) {
840
- this.indexUrl = results[i];
841
- }
842
- if (i === 'doorIndex' && results[i]) {
843
- util.win.open(results[i]);
844
- this.doorIndex = results[i];
845
- }
846
- if (i === 'subsystemName' && results[i]) {
847
- document.title = results[i];
848
- }
849
- if (i === 'loginPage' && results[i]) {
850
- util.setStorage('loginPage', results[i]);
851
- }
852
- if (i === 'sysLogoIco' && results[i]) {
853
- localStorage.setItem('sysLogoIco', results[i]);
854
- util.setFavicon(results[i]);
855
- }
856
- if (i === 'userStyle' && results[i]) {
857
- if (results[i].color) {
858
- let color = unescape(results[i].color).toLowerCase();
859
- if (util.startWith(color, '#')) {
860
- this.themeColor = color;
861
- }
862
- }
863
- this.userStyle = results[i];
864
- this.notify = results[i].notify || '';
865
- }
866
- if (i === 'subsystemExtend' && results[i]) {
867
- if (results[i].themeColor) {
868
- let color = unescape(results[i].themeColor).toLowerCase();
869
- if (util.startWith(color, '#')) {
870
- this.themeColor = color;
871
- }
872
- }
873
- if (results[i].singleLogout) {
874
- this.singleLogout = results[i].singleLogout.split(',');
875
- }
876
- if (results[i].userInfoContents) {
877
- this.userInfoContents = results[i].userInfoContents;
878
- }
879
- if (results[i].webPageWatermark) {
880
- try {
881
- util.win.webPageWatermark = results[i].webPageWatermark;
882
- util.watermark(results[i].webPageWatermark);
883
- } catch (error) {}
884
- }
885
- if (results[i].loginPage) {
886
- util.setStorage('loginPage', results[i].loginPage);
887
- }
888
- if (results[i].aiConfig) {
889
- if (typeof results[i].aiConfig == 'string') {
890
- try {
891
- this.aiConfig = JSON.parse(results[i].aiConfig);
892
- } catch (error) {
893
- this.aiConfig = { url: results[i].aiConfig };
894
- }
895
- } else {
896
- this.aiConfig = results[i].aiConfig;
897
- }
898
- }
899
- if (results[i].imConfig) {
900
- if (typeof results[i].imConfig == 'string') {
901
- try {
902
- this.imConfig = JSON.parse(results[i].imConfig);
903
- } catch (error) {
904
- this.imConfig = { url: results[i].imConfig };
905
- }
906
- } else {
907
- this.imConfig = results[i].imConfig;
908
- }
909
- }
910
- if (results[i].portalPage || results[i].portalpage) {
911
- this.doorIndex = results[i].portalPage || results[i].portalpage;
912
- }
913
- if (results[i].multipleVersion || results[i].oldVersion) {
914
- this.showOld = results[i].oldVersion ? results[i].oldVersion : true;
915
- }
916
- if (results[i].topRightToolHide) {
917
- this.topRightToolHide = results[i].topRightToolHide;
918
- }
919
- if (results[i].contact) {
920
- let contact = JSON.parse(results[i].contact);
921
- let content = contact.content.split(',');
922
- this.contact = {
923
- ...contact,
924
- content
925
- };
926
- }
927
- }
928
- if (i === 'userModel' && results[i]) {
929
- if (results[i].userHeadUrl) {
930
- results[i].userHeadUrl = util.jointUrl({
931
- url: results[i].userHeadUrl,
932
- reg: '/main2'
933
- });
934
- } else {
935
- results[i].userHeadUrl = this.userHead;
936
- }
937
- this.userModel = results[i];
938
- }
939
- if (i === 'notifyList' && results[i]) {
940
- this.notifyList = results[i];
941
- }
942
- store.set(i, results[i]);
943
- }
944
- },
945
- /**
946
- * @desc:获取所有应用
947
- * @author huangbo
948
- * @date 2024年9月7日
949
- **/
950
- getApplications() {
951
- let loading = util.loading('', '加载中...');
952
- util
953
- .ajax({
954
- url: this.appsUrl,
955
- defaults: true
956
- })
957
- .then((res) => {
958
- if (this.socket) {
959
- this.initWebSocket();
960
- }
961
- if (res.rCode === 0) {
962
- if (res.results && Object.keys(res.results).length) {
963
- let { all, app_special_business_system, app_system, app_user } =
964
- res.results;
965
- this.userApps = app_user.filter((item) => {
966
- return item.permission !== false;
967
- });
968
- this.applications = all;
969
- this.business = app_special_business_system;
970
- this.systems = app_system;
971
- this.setTips(this.userApps);
972
- this.setTips(this.applications);
973
- this.setTips(this.business);
974
- this.setTips(this.systems);
975
- } else {
976
- this.$message.error('未分配应用菜单权限,请联系管理员!');
977
- }
978
- this.getMenus(loading);
979
- } else {
980
- loading.close();
981
- let msg = res.msg || '系统错误,请联系管理员!';
982
- this.$message.error(msg);
983
- }
984
- })
985
- .catch((err) => {
986
- loading.close();
987
- if (err.message && err.message !== 'canceled') {
988
- this.$message.error(err.message);
989
- }
990
- });
991
- },
992
- /**
993
- * @desc:获取菜单列表
994
- * @author huangbo
995
- * @date 2024年9月7日
996
- **/
997
- getMenus(loading) {
998
- const menuData = store.get('nav');
999
- if (menuData && menuData.length) {
1000
- loading.close();
1001
- this.renderMenus(menuData);
1002
- return;
1003
- }
1004
- util
1005
- .ajax({ url: this._menuUrl })
1006
- .then((res) => {
1007
- loading.close();
1008
- if (res.rCode === 0) {
1009
- if (res.results && res.results.length) {
1010
- //this.$emit('update:menuData', res.results);
1011
- store.set('nav', JSON.parse(JSON.stringify(res.results)));
1012
- this.renderMenus(JSON.parse(JSON.stringify(res.results)));
1013
- } else {
1014
- this.$message.error('未分配菜单权限,请联系管理员!');
1015
- }
1016
- } else {
1017
- let msg = res.msg || '系统错误,请联系管理员!';
1018
- this.$message.error(msg);
1019
- }
1020
- })
1021
- .catch((err) => {
1022
- loading.close();
1023
- if (err.message && err.message !== 'canceled') {
1024
- this.$message.error(err.message);
1025
- }
1026
- });
1027
- },
1028
- /**
1029
- * @desc:处理菜单列表
1030
- * @author huangbo
1031
- * @date 2024年9月7日
1032
- **/
1033
- renderMenus(res) {
1034
- this.menus = res;
1035
- this.setTips(this.menus);
1036
- store.set('nav', this.menus);
1037
- if (this.indexUrl) {
1038
- let obj = this.getMenu(this.menus, this.indexUrl);
1039
- obj = obj
1040
- ? obj
1041
- : {
1042
- url: this.indexUrl,
1043
- text: '工作台',
1044
- id: '0',
1045
- appCode: 'indexUrl'
1046
- };
1047
- this.homePage = this.setIframeType(obj);
1048
- if (!this.appCode) {
1049
- this.tabs = [this.homePage];
1050
- this.activeName = this.homePage.id;
1051
- }
1052
- }
1053
- if (this.appCode) {
1054
- let code = this.sysCode || this.appCode;
1055
- let app = this.userApps.filter((item) => {
1056
- return item.code === code;
1057
- })[0];
1058
- if (app) {
1059
- this.active = app.id;
1060
- if (app.url) {
1061
- let obj = this.getMenu(this.menus, app.url);
1062
- if (obj) {
1063
- let tab = this.setIframeType(obj);
1064
- this.tabs = [tab];
1065
- this.activeName = tab.id;
1066
- } else {
1067
- this.tabs = [app];
1068
- }
1069
- }
1070
- }
1071
- if (this.sysCode) {
1072
- let subMenus = this.getMenu(this.menus, this.sysCode, 'appCode');
1073
- if (subMenus) {
1074
- let obj = this.getMenu(this.menus, this.appCode, 'appCode');
1075
- if (obj) {
1076
- if (!obj.url) {
1077
- obj = this.getFirst(obj);
1078
- }
1079
- this.subActive = obj.id;
1080
- let tab = this.setIframeType(obj);
1081
- this.tabs = [tab];
1082
- this.activeName = tab.id;
1083
- } else {
1084
- this.subActive = '';
1085
- }
1086
- this.subMenus = subMenus;
1087
- this.showMenu = true;
1088
- } else {
1089
- this.subMenus = null;
1090
- this.showMenu = false;
1091
- }
1092
- } else {
1093
- let subMenus = this.getMenu(this.menus, this.appCode, 'appCode');
1094
- if (subMenus) {
1095
- if (this.tabs.length == 0) {
1096
- let obj = this.getFirst(subMenus);
1097
- if (obj) {
1098
- this.subActive = obj.id;
1099
- let tab = this.setIframeType(obj);
1100
- this.tabs = [tab];
1101
- this.activeName = tab.id;
1102
- } else {
1103
- this.subActive = '';
1104
- }
1105
- }
1106
- this.subMenus = subMenus;
1107
- this.showMenu = true;
1108
- } else {
1109
- this.subMenus = null;
1110
- this.showMenu = false;
1111
- }
1112
- }
1113
- } else if (this.initApps && this.initApps.length && !this.indexUrl) {
1114
- let obj = this.getMenu(
1115
- this.menus,
1116
- this.initApps[this.initApps.length - 1]
1117
- );
1118
- if (obj) {
1119
- let tab = this.setIframeType(obj);
1120
- this.tabs.push(tab);
1121
- this.activeName = tab.id;
1122
- }
1123
- }
1124
- },
1125
- /**
1126
- * @desc:设置页面加载类型
1127
- * @author huangbo
1128
- * @date 2024年9月7日
1129
- **/
1130
- setIframeType(res) {
1131
- let { url } = res;
1132
- let urls = url.split('?');
1133
- if (urls[0].indexOf('.js') > 1 && !isIE) {
1134
- res.method = 'wujie';
1135
- if (!res.appCode) {
1136
- res.appCode = 'application_' + Date.now();
1137
- }
1138
- } else if (
1139
- urls[0].indexOf('.dhtml') > 0 ||
1140
- (urls[0].indexOf('.html') > 0 && urls[0].indexOf('.html#') === -1)
1141
- ) {
1142
- res.method = 'iframe';
1143
- } else {
1144
- if (urls[0].indexOf('.html') === -1 && urls[0].indexOf('#/') === -1) {
1145
- res.method = 'iframe';
1146
- } else {
1147
- const routes = this.$router.options.routes;
1148
- if (routes) {
1149
- let path = this.hasRouter(routes, urls[0], res.appCode);
1150
- if (path && this.routeType !== 'wujie') {
1151
- res.method = 'router';
1152
- if (typeof path === 'string') {
1153
- res.path = path;
1154
- } else {
1155
- res.path = path.path;
1156
- res.appCode = path.appCode;
1157
- }
1158
- res.keys = util.uuid();
1159
- } else {
1160
- let urlopenmode = util.getParams({
1161
- url: url,
1162
- name: 'urlopenmode'
1163
- });
1164
- if (
1165
- this.loadWujie === false ||
1166
- isIE ||
1167
- res.urlopenmode == 3 ||
1168
- urlopenmode == 3
1169
- ) {
1170
- res.method = 'iframe';
1171
- } else {
1172
- res.method = 'wujie';
1173
- if (!res.appCode) {
1174
- res.appCode = 'application_' + Date.now();
1175
- }
1176
- }
1177
- }
1178
- } else if (
1179
- (urls[0].indexOf('.html') > -1 && urls[0].indexOf('#/') > -1) ||
1180
- urls[0].indexOf('/#/') > -1
1181
- ) {
1182
- res.method = 'wujie';
1183
- if (!res.appCode) {
1184
- res.appCode = 'application_' + Date.now();
1185
- }
1186
- } else {
1187
- res.method = 'iframe';
1188
- }
1189
- }
1190
- }
1191
- return res;
1192
- },
1193
- /**
1194
- * @desc:获取菜单
1195
- * @author huangbo
1196
- * @date 2024年9月7日
1197
- **/
1198
- getMenu(menus, res, key) {
1199
- if (Array.isArray(menus)) {
1200
- for (let i = 0; i < menus.length; i++) {
1201
- let item = menus[i];
1202
- if (key) {
1203
- if (item[key] === res) {
1204
- return item;
1205
- }
1206
- } else if (
1207
- item.url === res ||
1208
- item.id === res ||
1209
- (item.appCode && item.appCode === res)
1210
- ) {
1211
- return item;
1212
- }
1213
- if (
1214
- Object.prototype.hasOwnProperty.call(item, 'children') &&
1215
- item.children.length
1216
- ) {
1217
- let obj = this.getMenu(item.children, res, key);
1218
- if (obj) {
1219
- return obj;
1220
- }
1221
- } else if (
1222
- Object.prototype.hasOwnProperty.call(item, 'fourthTabs') &&
1223
- item.fourthTabs.length
1224
- ) {
1225
- let obj = this.getMenu(item.fourthTabs, res, key);
1226
- if (obj) {
1227
- return obj;
1228
- }
1229
- }
1230
- }
1231
- }
1232
- return false;
1233
- },
1234
- /**
1235
- * @desc:获取菜单第一条数据
1236
- * @author huangbo
1237
- * @date 2024年9月7日
1238
- **/
1239
- getFirst(obj) {
1240
- if (!obj) {
1241
- return '';
1242
- }
1243
- let openIdex = 0;
1244
- if (
1245
- obj.extendData &&
1246
- (obj.extendData.subDefOpenIndex || obj.extendData.subDefOpen)
1247
- ) {
1248
- openIdex = parseInt(
1249
- obj.extendData.subDefOpenIndex || obj.extendData.subDefOpen,
1250
- 10
1251
- );
1252
- }
1253
- if (obj.children && obj.children.length && obj.children[openIdex]) {
1254
- return this.getFirst(obj.children[openIdex]);
1255
- } else if (
1256
- obj.fourthTabs &&
1257
- obj.fourthTabs.length &&
1258
- obj.fourthTabs[openIdex]
1259
- ) {
1260
- return this.getFirst(obj.fourthTabs[openIdex]);
1261
- } else if (obj.url && obj.urlopenmode !== 1 && obj.urlopenmode !== 2) {
1262
- return obj;
1263
- }
1264
- },
1265
- /**
1266
- * @desc:遍历设置菜单气泡提醒
1267
- * @author huangbo
1268
- * @date 2024年9月7日
1269
- **/
1270
- setTips(obj) {
1271
- if (Array.isArray(obj)) {
1272
- obj.forEach((item) => {
1273
- this.setTips(item);
1274
- });
1275
- } else {
1276
- if (
1277
- obj &&
1278
- Object.prototype.hasOwnProperty.call(obj, 'tips') &&
1279
- obj.tips
1280
- ) {
1281
- this.$set(obj, 'tips', false);
1282
- delete obj.tips;
1283
- }
1284
- let flag = 0;
1285
- if (obj.children && obj.children.length) {
1286
- obj.children.forEach((item) => {
1287
- let n = this.setTips(item);
1288
- flag += n ? parseInt(n) : 0;
1289
- });
1290
- if (flag) {
1291
- this.$set(obj, 'tips', flag);
1292
- this.setDot(this.userApps, obj.appCode);
1293
- this.setDot(this.applications, obj.appCode);
1294
- this.setDot(this.business, obj.appCode);
1295
- this.setDot(this.systems, obj.appCode);
1296
- return flag;
1297
- }
1298
- } else if (obj.fourthTabs && obj.fourthTabs.length) {
1299
- obj.fourthTabs.forEach((item) => {
1300
- let n = this.setTips(item);
1301
- flag += n ? parseInt(n) : 0;
1302
- });
1303
- if (flag) {
1304
- this.$set(obj, 'tips', flag);
1305
- this.setDot(this.userApps, obj.appCode);
1306
- this.setDot(this.applications, obj.appCode);
1307
- this.setDot(this.business, obj.appCode);
1308
- this.setDot(this.systems, obj.appCode);
1309
- return flag;
1310
- }
1311
- } else {
1312
- let num =
1313
- this.menuTips[obj.id] ||
1314
- this.menuTips[obj.code] ||
1315
- this.menuTips[obj.appCode];
1316
- if (num && Number(num)) {
1317
- this.$set(obj, 'tips', Number(num));
1318
- return num;
1319
- }
1320
- }
1321
- }
1322
- return false;
1323
- },
1324
- setDot(obj, code) {
1325
- if (Array.isArray(obj)) {
1326
- obj.forEach((item) => {
1327
- this.setDot(item, code);
1328
- });
1329
- } else if (obj.code === code) {
1330
- this.$set(obj, 'tips', true);
1331
- }
1332
- },
1333
- /**
1334
- * @desc:获取气泡提醒
1335
- * @author huangbo
1336
- * @date 2024年9月7日
1337
- **/
1338
- getBadge(res) {
1339
- let num = res.tips || 0;
1340
- return num === true
1341
- ? {
1342
- isDot: true
1343
- //hidden: item.tips
1344
- }
1345
- : {
1346
- value: num,
1347
- max: 99,
1348
- hidden: !num
1349
- };
1350
- },
1351
- /**
1352
- * @desc:开启weosocket
1353
- * @author huangbo
1354
- * @date 2024年9月7日
1355
- **/
1356
- initWebSocket() {
1357
- this.webSocket = util.socket({
1358
- url: wss,
1359
- take: topic,
1360
- success: (res) => {
1361
- let data = res.data || {};
1362
- for (let i in data) {
1363
- if (data[i] !== null && data[i] !== undefined) {
1364
- if (i === 'onlineUserNums' && data[i] > 0) {
1365
- this.userNums = data[i];
1366
- }
1367
- if (i === 'sysMsgNums' && data[i] !== null) {
1368
- this.notice = data[i];
1369
- if (this.showMsg) {
1370
- this.$refs.message.getMsg(true);
1371
- }
1372
- }
1373
- if (i === 'menuTipsMap' && data[i] !== null) {
1374
- this.menuTips = data[i];
1375
- }
1376
- if (i === 'sysMsgList' && data[i] !== null) {
1377
- this.sysMsg = data[i];
1378
- data[i] && data[i].length && this.$emit('bus-emit', 'waitdone');
1379
- }
1380
- if (i === 'extraData' && data[i] !== null) {
1381
- this.extraData = data[i];
1382
- }
1383
- }
1384
- }
1385
- if (this.$store) {
1386
- try {
1387
- this.$store.commit('websocket', data);
1388
- } catch (error) {}
1389
- }
1390
- if (this.$eventBus) {
1391
- this.$eventBus.$emit('websocket', data);
1392
- }
1393
- if (util.win.eventBus) {
1394
- util.win.eventBus.$emit('websocket', data);
1395
- }
1396
- }
1397
- });
1398
- },
1399
- /**
1400
- * @desc:显示用户信息
1401
- * @author huangbo
1402
- * @date 2024年9月7日
1403
- **/
1404
- showUserInfo() {
1405
- if (this.showUser === false) {
1406
- this.showUser = true;
1407
- }
1408
- },
1409
- /**
1410
- * @desc:删除更多应用菜单点击
1411
- * @author huangbo
1412
- * @date 2024年9月7日
1413
- **/
1414
- handleDelete(index) {
1415
- this.newApps.splice(index, 1);
1416
- },
1417
- /**
1418
- * @desc:储存更多应用菜单点击
1419
- * @author huangbo
1420
- * @date 2024年9月7日
1421
- **/
1422
- handlerClickApps(res) {
1423
- if (res.permission === false) {
1424
- return false;
1425
- }
1426
- let i = util.indexOfObj(this.newApps, res, 'id');
1427
- if (i == -1) {
1428
- this.newApps.push(res);
1429
- }
1430
- this.handlerClickApp(res);
1431
- },
1432
- /**
1433
- * @desc:侧边应用菜单点击
1434
- * @author huangbo
1435
- * @date 2024年9月7日
1436
- **/
1437
- handlerClickApp(res) {
1438
- this.showMsg = false;
1439
- this.showSet = false;
1440
- this.fold = false;
1441
- this.showApps = false;
1442
- this.drawer.visible = false;
1443
- if (res) {
1444
- if (res.permission === false) {
1445
- return false;
1446
- }
1447
- if (
1448
- (res.children && res.children.length) ||
1449
- (res.fourthTabs && res.fourthTabs.length)
1450
- ) {
1451
- this.subMenus = res;
1452
- this.showMenu = true;
1453
- } else {
1454
- this.subMenus = null;
1455
- this.showMenu = false;
1456
- }
1457
- let set = true;
1458
- if (res.url) {
1459
- if (res.urlopenmode == 1 || res.openModel == 1) {
1460
- set = false;
1461
- util.win.open(res.url);
1462
- } else if (res.urlopenmode == 2 || res.openModel == 2) {
1463
- set = false;
1464
- util.win.open(res.url, '_self');
1465
- } else {
1466
- let i = util.indexOfObj(this.tabs, res, 'id');
1467
- this.activeName = res.id;
1468
- if (i == -1) {
1469
- let obj = res.code
1470
- ? this.getMenu(this.menus, res.code, 'appCode')
1471
- : null;
1472
- if (obj) {
1473
- let n = util.indexOfObj(this.tabs, obj, 'id');
1474
- if (n == -1) {
1475
- let tab = this.setIframeType(obj);
1476
- this.tabs.push(tab);
1477
- this.activeName = tab.id;
1478
- } else {
1479
- if (obj.method == 'iframe') {
1480
- obj.url = util.handlerUrl(obj.url);
1481
- }
1482
- }
1483
- } else {
1484
- let tab = this.setIframeType(res);
1485
- this.tabs.push(tab);
1486
- this.activeName = tab.id;
1487
- }
1488
- } else {
1489
- if (res.method == 'iframe') {
1490
- res.url = util.handlerUrl(res.url);
1491
- }
1492
- }
1493
- }
1494
- }
1495
- if (set && res.code) {
1496
- let subMenus = this.getMenu(this.menus, res.code, 'appCode');
1497
- if (!subMenus && !res.url) {
1498
- this.$alert('没有关联菜单,请联系管理员!', '提示', {
1499
- confirmButtonText: '确定',
1500
- type: 'warning'
1501
- }).catch(() => {});
1502
- } else {
1503
- this.title = res.text || res.name;
1504
- this.subMenus = subMenus ? subMenus : null;
1505
- this.showMenu = subMenus !== false;
1506
- this.showApps = false;
1507
- if (subMenus && subMenus.url) {
1508
- let i = util.indexOfObj(this.tabs, subMenus, 'id');
1509
- this.activeName = subMenus.id;
1510
- if (i == -1) {
1511
- let tab = this.setIframeType(subMenus);
1512
- this.tabs.push(tab);
1513
- } else {
1514
- if (subMenus.method == 'iframe') {
1515
- subMenus.url = util.handlerUrl(subMenus.url);
1516
- }
1517
- }
1518
- }
1519
- }
1520
- }
1521
- this.active = res.id;
1522
- } else {
1523
- this.showApps = !this.showApps;
1524
- }
1525
- },
1526
- /**
1527
- * @desc:显示Drawer界面
1528
- * @author huangbo
1529
- * @date 2024年9月7日
1530
- **/
1531
- handlerSetDrawer(res, type, direction = 'ltr') {
1532
- this.drawer.visible = true;
1533
- this.drawer.active = type;
1534
- this.drawer.direction = direction;
1535
- if (res) {
1536
- let { mounted, url } = res;
1537
- this.drawer[type] = {
1538
- mounted,
1539
- url,
1540
- name: res.name || util.uuid()
1541
- };
1542
- }
1543
- },
1544
- /**
1545
- * @desc:关闭Drawer界面
1546
- * @author huangbo
1547
- * @date 2024年9月7日
1548
- **/
1549
- handleCloseDrawer() {
1550
- this.drawer = { visible: false };
1551
- },
1552
- /**
1553
- * @desc:菜单点击
1554
- * @author huangbo
1555
- * @date 2024年9月7日
1556
- **/
1557
- handlerClickMenu(res) {
1558
- util
1559
- .ajax({
1560
- url: recordUserApp,
1561
- params: {
1562
- userId: this.user.userId,
1563
- appId: res.id
1564
- }
1565
- })
1566
- .then(() => {})
1567
- .catch(() => {});
1568
- this.showMsg = false;
1569
- this.showSet = false;
1570
- let i = util.indexOfObj(this.tabs, res, 'id');
1571
- if (i == -1) {
1572
- let tab = this.setIframeType(res);
1573
- this.tabs.push(tab);
1574
- this.activeName = res.id;
1575
- } else {
1576
- this.tabs = events[0](this.tabs, i, this);
1577
- // let tab = this.tabs[i];
1578
- // if (tab.method === 'iframe') {
1579
- // this.activeName = res.id;
1580
- // this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1581
- // } else {
1582
- // if (tab.method === 'wujie' && tab.appCode) {
1583
- // window.document
1584
- // .querySelector(`iframe[name=${tab.appCode}]`)
1585
- // .contentWindow.location.reload(true);
1586
- // }
1587
- // if (tab.method === 'router') {
1588
- // this.$set(this.tabs[i], 'keys', util.uuid());
1589
- // }
1590
- // this.activeName = res.id;
1591
- // }
1592
- this.activeName = res.id;
1593
- }
1594
- },
1595
-
1596
- /**
1597
- * @desc:用户详情请求成功
1598
- * @author huangbo
1599
- * @date 2024年9月7日
1600
- **/
1601
- handleSuccess(res) {
1602
- this.simpleUserInfo = res.simpleUserInfo;
1603
- },
1604
- /**
1605
- * @desc:修改用户配置
1606
- * @author huangbo
1607
- * @date 2024年9月7日
1608
- **/
1609
- handleChangeConfig(name, res) {
1610
- if (name == 'userHeadUrl') {
1611
- this.$set(this.userModel, 'userHeadUrl', res);
1612
- store.set('userModel', this.userModel);
1613
- let mainConfig = JSON.parse(localStorage.getItem('mainConfig'));
1614
- sessionStorage.setItem(
1615
- 'mainConfig',
1616
- JSON.stringify({ ...mainConfig, userModel: this.userModel })
1617
- );
1618
- } else {
1619
- this.$set(this.userStyle, 'notify', res);
1620
- store.set('userStyle', this.userStyle);
1621
- let mainConfig = JSON.parse(localStorage.getItem('mainConfig'));
1622
- localStorage.setItem(
1623
- 'mainConfig',
1624
- JSON.stringify({ ...mainConfig, userStyle: this.userStyle })
1625
- );
1626
- }
1627
- },
1628
- /**
1629
- * @desc:关闭webSocket
1630
- * @author huangbo
1631
- * @date 2024年9月7日
1632
- **/
1633
- handlerClose() {
1634
- if (this.webSocket) {
1635
- this.webSocket.destroy();
1636
- }
1637
- },
1638
- /**
1639
- * @desc:刷新选中iframe页签
1640
- * @author huangbo
1641
- * @date 2024年9月7日
1642
- **/
1643
- handleRefresh() {
1644
- let i = util.indexOfObj(this.tabs, this.activeName, 'id');
1645
- let tab = this.tabs[i];
1646
- if (tab.method === 'iframe') {
1647
- tab.url = util.handlerUrl(tab.url);
1648
- } else {
1649
- let tab = this.tabs[i];
1650
- if (tab.method === 'iframe') {
1651
- this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1652
- }
1653
- if (tab.method === 'wujie' && tab.appCode) {
1654
- window.document
1655
- .querySelector(`iframe[name=${tab.appCode}]`)
1656
- .contentWindow.location.reload(true);
1657
- }
1658
- if (tab.method === 'router') {
1659
- this.$set(this.tabs[i], 'keys', util.uuid());
1660
- }
1661
- }
1662
- },
1663
- /**
1664
- * @desc:删除iframe
1665
- * @author huangbo
1666
- * @date 2024年9月7日
1667
- **/
1668
- handleRemove(name) {
1669
- let len = this.tabs.length - 1;
1670
- let i = util.indexOfObj(this.tabs, name, 'id,code,appCode');
1671
- if (i > -1) {
1672
- this.tabs.splice(i, 1);
1673
- if (this.tabs.length == 0) {
1674
- this.activeName = '';
1675
- } else if (i == len) {
1676
- this.activeName = this.tabs[len - 1].id;
1677
- } else {
1678
- this.activeName = this.tabs[i].id;
1679
- }
1680
- }
1681
- },
1682
- /**
1683
- * @desc:tabs鼠标右键事件
1684
- * @author huangbo
1685
- * @date 2024年9月7日
1686
- **/
1687
- handleContextmenu(tabs, e) {
1688
- let disabled = {};
1689
- let index = parseInt(tabs.index, 10);
1690
- if (index == 0) {
1691
- disabled.left = true;
1692
- }
1693
- if (index == this.tabs.length - 1) {
1694
- disabled.right = true;
1695
- }
1696
- if (this.tabs.length == 1) {
1697
- disabled.other = true;
1698
- }
1699
- if (this.tabs[index].id != this.activeName) {
1700
- disabled.refresh = true;
1701
- }
1702
- this.isDisabled = disabled;
1703
- this.$refs.tabsHandler.$el.style.setProperty('left', `${e.x}px`);
1704
- this.$refs.tabsHandler.$el.style.setProperty('top', `${e.y}px`);
1705
- this.showTabsHandler = true;
1706
- this.pane = index;
1707
- window.addEventListener('click', this.closeTabsEvents);
1708
- },
1709
- /**
1710
- * @desc:tabs页签事件
1711
- * @author huangbo
1712
- * @date 2024年9月7日
1713
- **/
1714
- handleTabsEvents(num) {
1715
- if (this.pane !== null) {
1716
- this.tabs = events[num](this.tabs, this.pane, this);
1717
- }
1718
- this.showTabsHandler = false;
1719
- window.removeEventListener('click', this.closeTabsEvents);
1720
- },
1721
- //关闭页签事件面板
1722
- closeTabsEvents(e) {
1723
- if (
1724
- e.target.parentNode != this.$refs.tabsHandler.$el &&
1725
- e.target.parentNode.parentNode != this.$refs.tabsHandler.$el
1726
- ) {
1727
- this.showTabsHandler = false;
1728
- }
1729
- window.removeEventListener('click', this.closeTabsEvents);
1730
- },
1731
- /**
1732
- * @desc:handler工具栏点击事件
1733
- * @author huangbo
1734
- * @date 2024年9月7日
1735
- **/
1736
- handleClick(res) {
1737
- const { type, event, open, link } = res;
1738
- if (event) {
1739
- event();
1740
- } else if (open) {
1741
- util.win.open(open);
1742
- } else if (link) {
1743
- util.win.open(link, '_self');
1744
- } else {
1745
- switch (type) {
1746
- case 'quit':
1747
- this.handleQuit();
1748
- break;
1749
- case 'online':
1750
- this.showMsg = false;
1751
- this.showSet = false;
1752
- this.dialog = {
1753
- title: '查看在线人员',
1754
- show: true,
1755
- src: this.onlineUrl
1756
- };
1757
- break;
1758
- case 'notice':
1759
- this.showMsg = !this.showMsg;
1760
- this.showSet = false;
1761
- break;
1762
- case 'index':
1763
- util.win.open(this.doorIndex, '_self');
1764
- break;
1765
- case 'set':
1766
- this.showSet = !this.showSet;
1767
- this.showMsg = false;
1768
- break;
1769
- case 'home':
1770
- let i = util.indexOfObj(this.tabs, this.homePage.id, 'id');
1771
- if (i == -1) {
1772
- this.tabs.unshift(this.homePage);
1773
- } else {
1774
- let tab = this.tabs[i];
1775
- if (tab.method === 'iframe') {
1776
- this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1777
- }
1778
- if (tab.method === 'wujie' && tab.appCode) {
1779
- window.document
1780
- .querySelector(`iframe[name=${tab.appCode}]`)
1781
- .contentWindow.location.reload(true);
1782
- }
1783
- if (tab.method === 'router') {
1784
- this.$set(this.tabs[i], 'keys', util.uuid());
1785
- }
1786
- }
1787
- this.activeName = this.homePage.id;
1788
- this.showMsg = false;
1789
- this.showSet = false;
1790
- break;
1791
- case 'search':
1792
- this.showSearch = true;
1793
- this.showMsg = false;
1794
- this.showSet = false;
1795
- break;
1796
- case 'ai':
1797
- this.handlerSetDrawer(this._aiConfig, 'ai', 'rtl');
1798
- break;
1799
- case 'im':
1800
- this.handlerSetDrawer(this.imConfig, 'im', 'rtl');
1801
- break;
1802
- case 'goView':
1803
- util.win.open(res.path, '_blank');
1804
- break;
1805
- }
1806
- }
1807
- this.$emit('handler-click', res);
1808
- },
1809
- /**
1810
- * @desc:退出登录
1811
- * @author huangbo
1812
- * @date 2024年9月7日
1813
- **/
1814
- handleQuit() {
1815
- this.$confirm('确定退出吗?', '退出系统', {
1816
- confirmButtonText: '确定',
1817
- cancelButtonText: '取消',
1818
- type: 'warning'
1819
- })
1820
- .then(() => {
1821
- let iframes = document.getElementsByTagName('iframe');
1822
- for (let i = 0; i < iframes.length; i++) {
1823
- let src = iframes[i] ? iframes[i].src : null;
1824
- let origin = util.win.location.origin;
1825
- if (
1826
- src &&
1827
- util.startWith(src, 'http') &&
1828
- src.indexOf(origin) === -1
1829
- ) {
1830
- iframes[i] && iframes[i].contentWindow.postMessage('logout', '*');
1831
- }
1832
- break;
1833
- }
1834
- if (this.singleLogout) {
1835
- for (let i = 0; i < this.singleLogout.length; i++) {
1836
- let iframe = document.createElement('iframe');
1837
- iframe.style.display = 'none';
1838
- iframe.src = this.singleLogout[i];
1839
- document.body.appendChild(iframe);
1840
- }
1841
- }
1842
- util
1843
- .ajax({ method: 'post', url: logout })
1844
- .then((res) => {
1845
- if (res.rCode == 0) {
1846
- util.removeStorage([
1847
- 'Authorization',
1848
- 'token',
1849
- 'ssId',
1850
- 'userId',
1851
- 'userName',
1852
- 'auth',
1853
- 'deviceUnique',
1854
- 'menus',
1855
- 'useCaseCodes',
1856
- 'mainConfig',
1857
- 'jump'
1858
- ]);
1859
- if (this.onQuit && typeof this.onQuit === 'function') {
1860
- this.onQuit();
1861
- } else {
1862
- try {
1863
- const loginPage =
1864
- util.getStorage('login') || util.getStorage('loginPage');
1865
- if (loginPage) {
1866
- let src;
1867
- if (!util.startWith(loginPage, ['http', '/'], true)) {
1868
- let pathname = util.win.top.location.pathname;
1869
- if (pathname !== '/') {
1870
- pathname = pathname.split('/');
1871
- pathname.splice(pathname.length - 1);
1872
- pathname = pathname.join('/');
1873
- src = pathname + '/' + loginPage.replace('./', '');
1874
- } else {
1875
- src = pathname + loginPage.replace('./', '');
1876
- }
1877
- } else {
1878
- src = loginPage;
1879
- }
1880
- util.win.top.location.href = src;
1881
- } else if (
1882
- util.win.top.location.href.indexOf('main.html') > -1
1883
- ) {
1884
- util.win.top.location.href = './login.html';
1885
- } else {
1886
- const hash = util.win.top.location.hash;
1887
- if (hash) {
1888
- const len = util.win.top.location.href.indexOf(hash);
1889
- util.win.top.location.href =
1890
- util.win.location.href.slice(0, len) + '#/login';
1891
- } else {
1892
- util.win.top.location.href = '/login.html';
1893
- }
1894
- }
1895
- } catch (error) {
1896
- util.win.top.postMessage({ type: 1 }, '*');
1897
- }
1898
- }
1899
- }
1900
- })
1901
- .catch((err) => {
1902
- if (err.message && err.message !== 'canceled') {
1903
- this.$message.error(err.message);
1904
- }
1905
- });
1906
- })
1907
- .catch((e) => {});
1908
- },
1909
- /**
1910
- * @desc:主题、消息回调
1911
- * @author huangbo
1912
- * @date 2024年9月7日
1913
- **/
1914
- handleChange(res) {
1915
- const { type, value } = res;
1916
- switch (type) {
1917
- case 'theme':
1918
- this.setTheme(value);
1919
- break;
1920
- case 'ignore':
1921
- this.notice = 0;
1922
- break;
1923
- }
1924
- },
1925
- /**
1926
- * @desc:菜单布局样式切换
1927
- * @author huangbo
1928
- * @date 2024年9月7日
1929
- **/
1930
- handleLayout(res, active) {
1931
- if (active) {
1932
- localStorage.setItem('layout', active);
1933
- }
1934
- this.$emit('chang-layout', res, active);
1935
- },
1936
- /**
1937
- * @desc:消息修改总数
1938
- * @author huangbo
1939
- * @date 2024年9月7日
1940
- **/
1941
- handleMenuTips(id, num) {
1942
- if (num) {
1943
- this.$set(this.menuTips, id, num);
1944
- } else {
1945
- let n = parseInt(this.menuTips[id], 10) - 1;
1946
- this.$set(this.menuTips, id, n);
1947
- }
1948
- },
1949
- /**
1950
- * @desc:处理即时消息
1951
- * @author huangbo
1952
- * @date 2024年9月7日
1953
- **/
1954
- handleOpened(res) {
1955
- if (res === undefined) {
1956
- this.sysMsg = [];
1957
- } else if (res == false && this.sysMsg.length) {
1958
- this.sysMsgOut = setTimeout(() => {
1959
- this.sysMsg = [];
1960
- }, 3000);
1961
- } else if (this.sysMsgOut) {
1962
- clearTimeout(this.sysMsgOut);
1963
- }
1964
- },
1965
- jumpMenu(res, close, params = {}) {
1966
- let apps = res;
1967
- let param = params;
1968
- let reload = true;
1969
- if (typeof res === 'string') {
1970
- apps = res.split(',');
1971
- } else if (typeof res === 'object') {
1972
- apps = res.appCode.split(',');
1973
- res.param && (param = { ...res.param, ...params });
1974
- reload = Object.prototype.hasOwnProperty.call(res, 'reload')
1975
- ? res.reload
1976
- : true;
1977
- }
1978
- let obj = this.getMenu(this.menus, apps[apps.length - 1]);
1979
- if (obj) {
1980
- let i = util.indexOfObj(this.tabs, obj, 'id,code,appCode');
1981
- let n = util.indexOfObj(this.tabs, this.activeName, 'id');
1982
- let old = this.activeName;
1983
- this.activeName = obj.id;
1984
- if (i == -1) {
1985
- let tab = this.setIframeType(obj);
1986
- this.$set(tab, 'url', util.handlerUrl(tab.url, param));
1987
- this.tabs.splice(n + 1, 0, tab);
1988
- } else {
1989
- let tab = this.tabs[i];
1990
- if (tab.method === 'iframe') {
1991
- this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url, param));
1992
- }
1993
- if (tab.method === 'wujie' && tab.appCode) {
1994
- const url = param ? util.handlerUrl(tab.url, param) : tab.url;
1995
- if (reload || param) {
1996
- tab.url = '';
1997
- this.$nextTick(() => {
1998
- tab.url = url;
1999
- });
2000
- }
2001
- // if (param) {
2002
- // window.document.querySelector(
2003
- // `iframe[name=${tab.appCode}]`
2004
- // ).contentWindow.location.href = util.handlerUrl(tab.url, param);
2005
- // } else {
2006
- // window.document
2007
- // .querySelector(`iframe[name=${tab.appCode}]`)
2008
- // .contentWindow.location.reload(true);
2009
- // }
2010
- }
2011
- if (tab.method === 'router') {
2012
- this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url, param));
2013
- this.$set(this.tabs[i], 'keys', util.uuid());
2014
- }
2015
- }
2016
- if (close) {
2017
- if (close === old) {
2018
- this.tabs.splice(n, 0);
2019
- } else {
2020
- let d = util.indexOfObj(this.tabs, close, 'id,code,appCode');
2021
- if (d > -1) {
2022
- this.tabs.splice(d, 0);
2023
- }
2024
- }
2025
- }
2026
- } else {
2027
- this.$message.error('没有此菜单!');
2028
- }
2029
- },
2030
- //监听改变菜单
2031
- handleListener() {
2032
- util.win.addEventListener(
2033
- 'message',
2034
- (e) => {
2035
- var msg = e.data;
2036
- if (msg.key == 'jump_Menu') {
2037
- let res = msg.data1;
2038
- this.jumpMenu(res);
2039
- }
2040
- },
2041
- false
2042
- );
2043
- },
2044
- handleSelect(res, parent) {
2045
- this.showSearch = false;
2046
- if (parent.name === '应用') {
2047
- this.handlerClickApps(res);
2048
- }
2049
- if (parent.name === '菜单') {
2050
- this.handlerClickApp(res);
2051
- }
2052
- }
2053
- },
2054
- beforeDestroy() {
2055
- clearTimeout(this.timer);
2056
- this.timer = null;
2057
- if (this.webSocket) {
2058
- this.webSocket.destroy();
2059
- }
2060
- }
2061
- };
2062
- </script>
2063
-
2064
- <style lang="scss" scoped></style>
1
+ <template>
2
+ <div class="es-main">
3
+ <div class="es-simplicity-side">
4
+ <img class="es-simplicity-logo" v-if="mainLogo" :src="mainLogo" />
5
+ <div
6
+ class="es-simplicity-org-name es-text-ellipsis-row2"
7
+ :title="simpleUserInfo.orgShortName || simpleUserInfo.orgName"
8
+ >
9
+ {{ simpleUserInfo.orgShortName || simpleUserInfo.orgName }}
10
+ </div>
11
+ <el-popover
12
+ class="es-simplicity-user-popover"
13
+ placement="right-start"
14
+ width="360"
15
+ trigger="click"
16
+ >
17
+ <!-- 用户信息 -->
18
+ <user
19
+ :user="user"
20
+ :notifyList="notifyList"
21
+ :notify="notify"
22
+ :contents="userInfoContents"
23
+ @success="handleSuccess"
24
+ @change="handleChangeConfig"
25
+ @close="handlerClose"
26
+ ></user>
27
+ <avatar slot="reference" :user="user" :size="56"> </avatar>
28
+ <!-- 用户信息 end -->
29
+ </el-popover>
30
+ <div class="es-simplicity-side-Application">
31
+ <!-- 常用应用 -->
32
+ <el-scrollbar>
33
+ <div
34
+ class="es-simplicity-side-app"
35
+ v-for="item in userApps"
36
+ :class="{ 'is-active': active == item.id }"
37
+ :key="item.id"
38
+ :title="item.text || item.name"
39
+ @click="handlerClickApp(item)"
40
+ >
41
+ <el-badge
42
+ class="es-simplicity-side-app-badge"
43
+ v-bind="getBadge(item)"
44
+ >
45
+ <es-icon
46
+ class="es-simplicity-side-app-icon"
47
+ :contents="item.icons || item.icon || menuIcon"
48
+ ></es-icon>
49
+ <div class="es-simplicity-side-app-text">
50
+ {{ item.text || item.name }}
51
+ </div>
52
+ </el-badge>
53
+ </div>
54
+ <div
55
+ class="es-simplicity-side-app"
56
+ @click="handlerClickApp()"
57
+ v-show="menus.length"
58
+ >
59
+ <es-icon
60
+ class="es-simplicity-side-app-icon"
61
+ contents="es-icon-omit"
62
+ ></es-icon>
63
+ <div class="es-simplicity-side-app-text">更多</div>
64
+ </div>
65
+ <div
66
+ class="es-simplicity-side-app"
67
+ v-for="(item, index) in newApps"
68
+ :class="{ 'is-active': active == item.id }"
69
+ :key="item.id"
70
+ :title="item.text || item.name"
71
+ @click.stop="handlerClickApp(item)"
72
+ >
73
+ <i
74
+ class="el-icon-circle-close"
75
+ @click.stop="handleDelete(index)"
76
+ ></i>
77
+ <el-badge v-bind="getBadge(item)">
78
+ <es-icon
79
+ class="es-simplicity-side-app-icon"
80
+ :contents="item.icons || item.icon || menuIcon"
81
+ ></es-icon>
82
+ <div class="es-simplicity-side-app-text">
83
+ {{ item.text || item.name }}
84
+ </div>
85
+ </el-badge>
86
+ </div>
87
+ </el-scrollbar>
88
+ <!-- 常用应用 end -->
89
+ </div>
90
+ <div class="es-simplicity-side-app" v-if="_aiConfig && showAi">
91
+ <img
92
+ :src="_aiConfig.icon"
93
+ class="es-simplicity-ai-icon"
94
+ @click="handlerSetDrawer(_aiConfig, 'ai')"
95
+ />
96
+ </div>
97
+ </div>
98
+ <div class="es-simplicity-main">
99
+ <!-- 应用 -->
100
+ <apps
101
+ :visible.sync="showApps"
102
+ :menu-icon="menuIcon"
103
+ :color="appColor"
104
+ :backgroundColor="appBackgroundColor"
105
+ :applications="applications"
106
+ :business="business"
107
+ :systems="systems"
108
+ :user="user"
109
+ @click="handlerClickApps"
110
+ ></apps>
111
+ <!-- 应用 end -->
112
+
113
+ <!-- AI/IM -->
114
+ <el-drawer
115
+ class="es-simplicity-public-drawer"
116
+ :direction="drawer.direction"
117
+ modal-class="es-simplicity-apps-modal"
118
+ size="100%"
119
+ show-close
120
+ :modal-append-to-body="false"
121
+ :visible.sync="drawer.visible"
122
+ >
123
+ <div
124
+ class="es-public-drawer-main"
125
+ v-if="drawer.ai && drawer.ai.url"
126
+ v-show="drawer.active == 'ai'"
127
+ >
128
+ <template v-if="isIE || drawer.ai.method !== 'wujie'">
129
+ <iframe
130
+ frameborder="0"
131
+ width="100%"
132
+ height="100%"
133
+ :src="drawer.ai.url"
134
+ ></iframe>
135
+ </template>
136
+ <template v-else>
137
+ <es-wujie
138
+ :host="host"
139
+ :show="true"
140
+ :props="wjProps"
141
+ :attrs="wjAttrs"
142
+ :name="drawer.ai.name"
143
+ :url="drawer.ai.url"
144
+ ></es-wujie>
145
+ </template>
146
+ </div>
147
+ <div
148
+ class="es-public-drawer-main"
149
+ v-if="drawer.im && drawer.im.url"
150
+ v-show="drawer.active == 'im'"
151
+ >
152
+ <template v-if="isIE || drawer.im.method !== 'wujie'">
153
+ <iframe
154
+ frameborder="0"
155
+ width="100%"
156
+ height="100%"
157
+ :src="drawer.im.url"
158
+ ></iframe>
159
+ </template>
160
+ <template v-else>
161
+ <es-wujie
162
+ :host="host"
163
+ :show="true"
164
+ :props="wjProps"
165
+ :attrs="wjAttrs"
166
+ :name="drawer.im.name"
167
+ :url="drawer.im.url"
168
+ ></es-wujie>
169
+ </template>
170
+ </div>
171
+ </el-drawer>
172
+ <!-- AI/IM end -->
173
+
174
+ <!-- 路由、iframe -->
175
+ <div class="es-simplicity-tabs-handler-mask" v-show="showTabsHandler">
176
+ <el-card class="es-simplicity-tabs-handler" ref="tabsHandler">
177
+ <div
178
+ class="es-simplicity-tabs-handler-item"
179
+ :class="{ 'is-disabled': isDisabled.refresh }"
180
+ @click="isDisabled.refresh ? '' : handleTabsEvents(0)"
181
+ >
182
+ 刷新
183
+ </div>
184
+ <div
185
+ class="es-simplicity-tabs-handler-item"
186
+ @click="handleTabsEvents(1)"
187
+ >
188
+ 关闭标签
189
+ </div>
190
+ <div
191
+ class="es-simplicity-tabs-handler-item"
192
+ :class="{ 'is-disabled': isDisabled.other }"
193
+ @click="isDisabled.other ? '' : handleTabsEvents(2)"
194
+ >
195
+ 关闭其他
196
+ </div>
197
+ <div
198
+ class="es-simplicity-tabs-handler-item"
199
+ :class="{ 'is-disabled': isDisabled.left }"
200
+ @click="isDisabled.left ? '' : handleTabsEvents(3)"
201
+ >
202
+ 关闭左侧
203
+ </div>
204
+ <div
205
+ class="es-simplicity-tabs-handler-item"
206
+ :class="{ 'is-disabled': isDisabled.right }"
207
+ @click="isDisabled.right ? '' : handleTabsEvents(4)"
208
+ >
209
+ 关闭右侧
210
+ </div>
211
+ </el-card>
212
+ </div>
213
+ <el-tabs
214
+ class="es-simplicity-iframe"
215
+ :class="{ 'is-open': showMenu, 'is-fold': fold }"
216
+ v-model="activeName"
217
+ closable
218
+ hide-bar
219
+ opacity
220
+ @tab-remove="handleRemove"
221
+ @tab-contextmenu="handleContextmenu"
222
+ >
223
+ <!-- 操作栏 -->
224
+ <handler
225
+ slot="append"
226
+ v-bind="handleConfig"
227
+ :data="handleData"
228
+ :hide="hide"
229
+ :contact="contact"
230
+ :online="userNums"
231
+ :notice-num="notice"
232
+ @click="handleClick"
233
+ ></handler>
234
+ <!-- 操作栏 end-->
235
+
236
+ <!-- 菜单 -->
237
+ <sub-menu
238
+ :collapse="collapse"
239
+ :mode="mode"
240
+ :visible.sync="showMenu"
241
+ :closed.sync="fold"
242
+ :size="menuWidth"
243
+ :title="title"
244
+ :color="menuColor"
245
+ :backgroundColor="menuBackgroundColor"
246
+ :menu-icon="menuIcon"
247
+ :active="subActive"
248
+ v-bind="subMenus"
249
+ @command="handlerClickMenu"
250
+ ></sub-menu>
251
+ <!-- 菜单 end -->
252
+ <el-tab-pane
253
+ v-for="item in tabs"
254
+ :key="item.id"
255
+ :label="item.text || item.name"
256
+ :name="item.id"
257
+ >
258
+ <router-page
259
+ v-if="item.method === 'router'"
260
+ v-bind="item"
261
+ :query="$parent.params"
262
+ ></router-page>
263
+ <iframe
264
+ v-else-if="isIE || item.method == 'iframe'"
265
+ :id="activeName == item.id ? iframeId : ''"
266
+ :name="activeName == item.id ? iframeId : ''"
267
+ frameborder="0"
268
+ width="100%"
269
+ height="100%"
270
+ :src="item.url"
271
+ ></iframe>
272
+ <es-wujie
273
+ v-else-if="item.method === 'wujie' && item.url"
274
+ :host="host"
275
+ :show="true"
276
+ :props="wjProps"
277
+ :attrs="wjAttrs"
278
+ :name="item.appCode"
279
+ :url="item.url"
280
+ ></es-wujie>
281
+ </el-tab-pane>
282
+ </el-tabs>
283
+ <!-- 路由、iframe end -->
284
+
285
+ <!-- 消息列表 -->
286
+ <message
287
+ v-if="showMsg"
288
+ ref="message"
289
+ :total.sync="notice"
290
+ :visible.sync="showMsg"
291
+ :winopen="winopen"
292
+ @ignore="handleChange"
293
+ @handle="handleMenuTips"
294
+ ></message>
295
+ <!-- 消息列表 end-->
296
+
297
+ <!-- 设置 -->
298
+ <settings
299
+ v-bind="$attrs"
300
+ layout-type="simplicity"
301
+ active="simplicity"
302
+ :theme="themeColor"
303
+ :predefine="themes"
304
+ :visible.sync="showSet"
305
+ @change="handleChange"
306
+ @layout="handleLayout"
307
+ ></settings>
308
+ <!-- 设置 end-->
309
+
310
+ <!-- 消息提醒 -->
311
+ <notice :data="sysMsg" :winopen="winopen" @opened="handleOpened"></notice>
312
+ <!-- 消息提醒 end -->
313
+
314
+ <es-dialog
315
+ class="es-public-search-dialog"
316
+ :visible.sync="showSearch"
317
+ size="lg"
318
+ >
319
+ <search
320
+ :apps="applications"
321
+ :menus="menus"
322
+ :menuIcon="menuIcon"
323
+ @select="handleSelect"
324
+ ></search>
325
+ </es-dialog>
326
+ <!-- 公用弹窗 -->
327
+ <es-dialog :title="dialog.title" :visible.sync="dialog.show" size="md">
328
+ <template v-if="dialog.title == '查看在线人员' && !dialog.src">
329
+ <online></online>
330
+ </template>
331
+ <iframe
332
+ v-else-if="dialog.show"
333
+ width="100%"
334
+ height="100%"
335
+ frameborder="0"
336
+ :src="dialog.src"
337
+ ></iframe>
338
+ </es-dialog>
339
+ <!-- 公用弹窗 end -->
340
+ </div>
341
+ </div>
342
+ </template>
343
+
344
+ <script>
345
+ import avatar from './avatar.vue';
346
+ import handler from './handler.vue';
347
+ import subMenu from './sub-menu.vue';
348
+ import apps from './apps.vue';
349
+ import user from './user.vue';
350
+ import message from './message.vue';
351
+ import notice from './notice.vue';
352
+ import settings from '../public/settings.vue';
353
+ import routerPage from './router-page.vue';
354
+ import online from '../public/online.vue';
355
+ import search from '../public/search.vue';
356
+ import {
357
+ wss,
358
+ logout,
359
+ topic,
360
+ getUserAppWithTag,
361
+ recordUserApp,
362
+ getComplexApplications,
363
+ getComplexApplicationsNew
364
+ } from 'eoss-ui/src/config/api.js';
365
+ import store from 'eoss-ui/src/utils/store';
366
+ import util from 'eoss-ui/src/utils/util';
367
+ const isIE = navigator.userAgent.indexOf('MSIE') != -1;
368
+ const systemMode = util.win.systemMode || 'default';
369
+ let events = [
370
+ (tabs, index, that) => {
371
+ let tab = tabs[index];
372
+ if (tab.method == 'iframe') {
373
+ tabs[index].url = util.handlerUrl(tab.url);
374
+ }
375
+ if (tab.method === 'wujie' && tab.appCode) {
376
+ const url = tab.url;
377
+ tab.url = '';
378
+ that.$nextTick(() => {
379
+ tab.url = url;
380
+ });
381
+ }
382
+ if (tab.method === 'router') {
383
+ that.$set(tabs[index], 'keys', util.uuid());
384
+ }
385
+ return tabs;
386
+ },
387
+ (tabs, index, that) => {
388
+ let i = util.indexOfObj(tabs, that.activeName, 'id');
389
+ if (tabs.length == 1) {
390
+ that.activeName = '';
391
+ } else if (i == index) {
392
+ if (index < tabs.length - 1) {
393
+ that.activeName = tabs[index + 1].id;
394
+ } else {
395
+ that.activeName = tabs[index - 1].id;
396
+ }
397
+ }
398
+ tabs.splice(index, 1);
399
+ return tabs;
400
+ },
401
+ (tabs, index, that) => {
402
+ let tab = tabs.slice(index, index + 1);
403
+ that.activeName = tab[0].id;
404
+ return tab;
405
+ },
406
+ (tabs, index, that) => {
407
+ let i = util.indexOfObj(tabs, that.activeName, 'id');
408
+ if (i < index) {
409
+ that.activeName = tabs[index].id;
410
+ }
411
+ tabs.splice(0, index);
412
+ return tabs;
413
+ },
414
+ (tabs, index, that) => {
415
+ let i = util.indexOfObj(tabs, that.activeName, 'id');
416
+ if (i > index) {
417
+ that.activeName = tabs[index].id;
418
+ }
419
+ tabs.splice(index + 1, tabs.length - index);
420
+ return tabs;
421
+ }
422
+ ];
423
+ export default {
424
+ name: 'Simplicity',
425
+ provide() {
426
+ return {
427
+ esMain: this,
428
+ refresh: this.handleRefresh,
429
+ jumpMenu: this.jumpMenu
430
+ };
431
+ },
432
+ components: {
433
+ avatar,
434
+ handler,
435
+ subMenu,
436
+ apps,
437
+ user,
438
+ message,
439
+ notice,
440
+ settings,
441
+ routerPage,
442
+ online,
443
+ search
444
+ },
445
+ props: {
446
+ //im用例编码
447
+ imUseCaseCode: String,
448
+ //ai用例编码
449
+ aiUseCaseCode: String,
450
+ //模式
451
+ mode: {
452
+ type: String,
453
+ default: systemMode
454
+ },
455
+ sysCode: String,
456
+ appCode: String,
457
+ //logo
458
+ logo: String,
459
+ //菜单、应用默认图标
460
+ menuIcon: {
461
+ type: String,
462
+ default: 'es-icon-application'
463
+ },
464
+ //默认主题颜色
465
+ theme: {
466
+ type: String,
467
+ default: '#409eff'
468
+ },
469
+ //主题颜色选择颜色集合
470
+ themes: Array,
471
+ //操作栏配置
472
+ handleData: Array,
473
+ //操作栏单项配置
474
+ handleConfig: Object,
475
+ //需要隐藏的头部功能
476
+ hides: Object,
477
+ //菜单颜色
478
+ menuColor: [String, Array],
479
+ //菜单背景颜色
480
+ menuBackgroundColor: [String, Array],
481
+ //菜单是否折叠形式
482
+ collapse: Boolean,
483
+ //应用颜色
484
+ appColor: [String, Array],
485
+ //应用背景颜色
486
+ appBackgroundColor: [String, Array],
487
+ //默认头像
488
+ userHead: String,
489
+ //应用列表接口
490
+ appsUrl: {
491
+ type: String,
492
+ default: getUserAppWithTag
493
+ },
494
+ //是否启用子应用菜单接口
495
+ application: {
496
+ type: Boolean,
497
+ default: false
498
+ },
499
+ //菜单接口
500
+ menuUrl: String,
501
+ //远程请求菜单
502
+ remote: {
503
+ type: Boolean,
504
+ default: true
505
+ },
506
+ //websocket
507
+ socket: {
508
+ type: Boolean,
509
+ default: true
510
+ },
511
+ //iframeId
512
+ iframeId: {
513
+ type: String,
514
+ default: 'stage'
515
+ },
516
+ //查看在线人数
517
+ onlineView: {
518
+ type: [String, Boolean],
519
+ default: true
520
+ },
521
+ //消息办理是否采用window.open的方式打开
522
+ winopen: {
523
+ type: Boolean,
524
+ default: true
525
+ },
526
+ //是否采用wujie微前端加载页面
527
+ loadWujie: {
528
+ type: Boolean,
529
+ default: true
530
+ },
531
+ //无界微前端Props属性
532
+ wjProps: Object,
533
+ //无界微前端Attrs属性
534
+ wjAttrs: Object,
535
+ //菜单宽度
536
+ menuWidth: {
537
+ type: Number,
538
+ default: 220
539
+ },
540
+ //路由方式
541
+ routeType: String,
542
+ host: {
543
+ type: String,
544
+ default() {
545
+ return sessionStorage.getItem('host') || '';
546
+ }
547
+ },
548
+ //切换旧版样式
549
+ oldVersion: Boolean,
550
+ //运维联系人
551
+ contacts: Object
552
+ },
553
+ data() {
554
+ return {
555
+ //用例权限编码
556
+ useCaseCodes: util.getStorage('useCaseCodes'),
557
+ //显示用户信息
558
+ showUser: false,
559
+ //主题色
560
+ themeColor: this.theme,
561
+ //是否ie浏览器
562
+ isIE: isIE,
563
+ //logo
564
+ mainLogo: this.logo,
565
+ //侧边用户应用
566
+ userApps: [],
567
+ //点击应用存侧边
568
+ newApps: [],
569
+ //所有菜单
570
+ menus: [],
571
+ //菜单名称
572
+ title: '',
573
+ //子菜单
574
+ subMenus: null,
575
+ //展示菜单导航
576
+ showMenu: false,
577
+ //子菜单选中
578
+ subActive: '',
579
+ //折叠菜单
580
+ fold: false,
581
+ //人工智能配置
582
+ aiConfig: null,
583
+ //im配置
584
+ imConfig: null,
585
+ //公用窗口面板配置
586
+ drawer: {
587
+ visible: false,
588
+ direction: 'ltr',
589
+ ai: {},
590
+ im: {},
591
+ active: ''
592
+ },
593
+ //所有应用
594
+ applications: [],
595
+ //业务系统
596
+ business: [],
597
+ //系统管理
598
+ systems: [],
599
+ //气泡数
600
+ menuTips: {},
601
+ //展示所有应用
602
+ showApps: false,
603
+ //用户信息
604
+ userModel: {},
605
+ //通知类型列表
606
+ notifyList: [],
607
+ //用户样式
608
+ userStyle: {},
609
+ //通知类型
610
+ notify: '',
611
+ //用户信息表单结构
612
+ userInfoContents: undefined,
613
+ //窗口页签
614
+ tabs: [],
615
+ //页签选中name
616
+ activeName: '',
617
+ //初始应用菜单页
618
+ initApps: null,
619
+ //首页地址
620
+ indexUrl: '',
621
+ //首页配置
622
+ homePage: {},
623
+ //门户跳转页地址
624
+ doorIndex: '',
625
+ //弹窗
626
+ dialog: {},
627
+ //在线人数
628
+ userNums: 1,
629
+ //消息列表展示状态
630
+ showMsg: false,
631
+ //搜索
632
+ showSearch: false,
633
+ //消息数
634
+ notice: 0,
635
+ //即时消息
636
+ sysMsg: [],
637
+ //定时关闭及时消息对象
638
+ sysMsgOut: null,
639
+ //额外信息数据
640
+ extraData: '',
641
+ //显示设置面板
642
+ showSet: false,
643
+ //窗口是否可选
644
+ isDisabled: {},
645
+ //显示页签操作
646
+ showTabsHandler: false,
647
+ //页签对象
648
+ pane: null,
649
+ //选中菜单
650
+ active: '',
651
+ //单位名称
652
+ simpleUserInfo: {},
653
+ topRightToolHide: '',
654
+ showOld: this.oldVersion,
655
+ //运维联系人
656
+ contact: this.contacts,
657
+ //单点退出地址
658
+ singleLogout: null
659
+ };
660
+ },
661
+ computed: {
662
+ //菜单接口
663
+ _menuUrl() {
664
+ if (this.menuUrl) {
665
+ return this.menuUrl;
666
+ }
667
+ if (this.application) {
668
+ return getComplexApplicationsNew;
669
+ }
670
+ return getComplexApplications;
671
+ },
672
+ //人工智能配置
673
+ _aiConfig() {
674
+ return this.aiConfig
675
+ ? {
676
+ ...this.aiConfig,
677
+ icon: ''
678
+ }
679
+ : false;
680
+ },
681
+ showAi() {
682
+ return this.aiUseCaseCode
683
+ ? this.useCaseCodes.indexOf(this.aiUseCaseCode) > -1
684
+ : true;
685
+ },
686
+ //用户信息
687
+ user() {
688
+ return this.userModel ? this.userModel : store.get('userModel');
689
+ },
690
+ //在线人数列表地址
691
+ onlineUrl() {
692
+ if (this.onlineView) {
693
+ return typeof this.onlineView == 'string' ? this.onlineView : '';
694
+ }
695
+ return false;
696
+ },
697
+ //隐藏操作按键
698
+ hide() {
699
+ let topRightToolHide = {};
700
+ if (this.topRightToolHide) {
701
+ topRightToolHide = JSON.parse(
702
+ this.topRightToolHide.replace(
703
+ /(['"])?([a-zA-Z0-9_]+)(['"])?:/g,
704
+ '"$2":'
705
+ )
706
+ );
707
+ }
708
+ let hides = {
709
+ im: this.imConfig
710
+ ? this.imUseCaseCode
711
+ ? this.useCaseCodes.indexOf(this.imUseCaseCode) == -1
712
+ : false
713
+ : true,
714
+ home: this.indexUrl ? false : true,
715
+ index: this.doorIndex ? false : true,
716
+ old: this.showOld ? false : true
717
+ };
718
+
719
+ if (this.layout === 'subsystem' || this.application) {
720
+ hides.system = false;
721
+ }
722
+ if (this.layout === 'topside' || this.layout === 'side') {
723
+ hides.user = true;
724
+ }
725
+ return { ...hides, ...this.hides, ...topRightToolHide };
726
+ }
727
+ },
728
+ watch: {
729
+ menuTips: {
730
+ deep: true,
731
+ handler() {
732
+ this.setTips(this.userApps);
733
+ this.setTips(this.applications);
734
+ this.setTips(this.business);
735
+ this.setTips(this.systems);
736
+ this.setTips(this.menus);
737
+ }
738
+ }
739
+ },
740
+ created() {
741
+ this.doorIndex = sessionStorage.getItem('doorIndex');
742
+ },
743
+ mounted() {
744
+ this.handleListener();
745
+ },
746
+ methods: {
747
+ /**
748
+ * @desc:匹配路由
749
+ * @author huangbo
750
+ * @date 2024年9月7日
751
+ **/
752
+ hasRouter(res, url, code) {
753
+ if (!url) {
754
+ return false;
755
+ }
756
+ if (Array.isArray(res)) {
757
+ for (let i in res) {
758
+ let path = this.hasRouter(res[i], url, code);
759
+ if (path) {
760
+ return path;
761
+ }
762
+ }
763
+ } else {
764
+ let path = res.path;
765
+ if (path !== '/' && path !== '/404') {
766
+ path = path.replace(path[1], path[1].toLowerCase());
767
+ }
768
+ let pathname = url.substring(url.indexOf('#/') + 1);
769
+ pathname = pathname.split('?')[0];
770
+ let appCode;
771
+ if (res.path !== '/' && pathname == path) {
772
+ if (res.components) {
773
+ if (!res.components[code]) {
774
+ console.error(
775
+ '路由“命名视图”规范属性名称与菜单appCode不一致',
776
+ res,
777
+ code
778
+ );
779
+ appCode = Object.keys(res.components).filter((item) => {
780
+ return item !== 'default';
781
+ })[0];
782
+ }
783
+ } else {
784
+ console.error(
785
+ '请根据路由“命名视图”规范,正确添加components属性名称',
786
+ res
787
+ );
788
+ }
789
+ return appCode ? { path: pathname, appCode } : pathname;
790
+ }
791
+ if (res && Object.prototype.hasOwnProperty.call(res, 'children')) {
792
+ let path = this.hasRouter(res.children, url, code);
793
+ if (path) {
794
+ return path;
795
+ }
796
+ }
797
+ }
798
+ return false;
799
+ },
800
+ /**
801
+ * @desc:获取初始数据
802
+ * @author huangbo
803
+ * @date 2024年9月7日
804
+ **/
805
+ init(results, first) {
806
+ this.setConfig(results);
807
+ if (this.remote && first) {
808
+ this.getApplications();
809
+ }
810
+ },
811
+ /**
812
+ * @desc:设置用户配置及信息
813
+ * @author huangbo
814
+ * @date 2024年9月7日
815
+ **/
816
+ setConfig(results) {
817
+ localStorage.setItem('mainConfig', JSON.stringify(results));
818
+ util.setStorage({
819
+ type: this.storage,
820
+ key: {
821
+ depId: results.userModel.depId,
822
+ orgId: results.userModel.orgId,
823
+ userId: results.userModel.userId,
824
+ userName: results.userModel.username || results.userModel.userName,
825
+ useCaseCodes: results.resourceCodes || results.userModel.resourceCodes
826
+ }
827
+ });
828
+ for (let i in results) {
829
+ if (i === 'mainLogoUrl' && results[i]) {
830
+ this.mainLogo = results[i];
831
+ }
832
+ if (
833
+ i === 'mainBannerUrl' &&
834
+ results[i] &&
835
+ this.headerImage === undefined
836
+ ) {
837
+ this.headerImg = results[i];
838
+ }
839
+ if (i === 'initApplication' && results[i]) {
840
+ this.initApps = results[i].split(',');
841
+ }
842
+ if (i === 'indexUrl' && results[i]) {
843
+ this.indexUrl = results[i];
844
+ }
845
+ if (i === 'doorIndex' && results[i]) {
846
+ util.win.open(results[i]);
847
+ this.doorIndex = results[i];
848
+ }
849
+ if (i === 'subsystemName' && results[i]) {
850
+ document.title = results[i];
851
+ }
852
+ if (i === 'loginPage' && results[i]) {
853
+ util.setStorage('loginPage', results[i]);
854
+ }
855
+ if (i === 'sysLogoIco' && results[i]) {
856
+ localStorage.setItem('sysLogoIco', results[i]);
857
+ util.setFavicon(results[i]);
858
+ }
859
+ if (i === 'userStyle' && results[i]) {
860
+ if (results[i].color) {
861
+ let color = unescape(results[i].color).toLowerCase();
862
+ if (util.startWith(color, '#')) {
863
+ this.themeColor = color;
864
+ }
865
+ }
866
+ this.userStyle = results[i];
867
+ this.notify = results[i].notify || '';
868
+ }
869
+ if (i === 'subsystemExtend' && results[i]) {
870
+ if (results[i].themeColor) {
871
+ let color = unescape(results[i].themeColor).toLowerCase();
872
+ if (util.startWith(color, '#')) {
873
+ this.themeColor = color;
874
+ }
875
+ }
876
+ if (results[i].singleLogout) {
877
+ this.singleLogout = results[i].singleLogout.split(',');
878
+ }
879
+ if (results[i].userInfoContents) {
880
+ this.userInfoContents = results[i].userInfoContents;
881
+ }
882
+ if (results[i].webPageWatermark) {
883
+ try {
884
+ util.win.webPageWatermark = results[i].webPageWatermark;
885
+ util.watermark(results[i].webPageWatermark);
886
+ } catch (error) {}
887
+ }
888
+ if (results[i].loginPage) {
889
+ util.setStorage('loginPage', results[i].loginPage);
890
+ }
891
+ if (results[i].aiConfig) {
892
+ if (typeof results[i].aiConfig == 'string') {
893
+ try {
894
+ this.aiConfig = JSON.parse(results[i].aiConfig);
895
+ } catch (error) {
896
+ this.aiConfig = { url: results[i].aiConfig };
897
+ }
898
+ } else {
899
+ this.aiConfig = results[i].aiConfig;
900
+ }
901
+ }
902
+ if (results[i].imConfig) {
903
+ if (typeof results[i].imConfig == 'string') {
904
+ try {
905
+ this.imConfig = JSON.parse(results[i].imConfig);
906
+ } catch (error) {
907
+ this.imConfig = { url: results[i].imConfig };
908
+ }
909
+ } else {
910
+ this.imConfig = results[i].imConfig;
911
+ }
912
+ }
913
+ if (results[i].portalPage || results[i].portalpage) {
914
+ this.doorIndex = results[i].portalPage || results[i].portalpage;
915
+ }
916
+ if (results[i].multipleVersion || results[i].oldVersion) {
917
+ this.showOld = results[i].oldVersion ? results[i].oldVersion : true;
918
+ }
919
+ if (results[i].topRightToolHide) {
920
+ this.topRightToolHide = results[i].topRightToolHide;
921
+ }
922
+ if (results[i].contact) {
923
+ let contact = JSON.parse(results[i].contact);
924
+ let content = contact.content.split(',');
925
+ this.contact = {
926
+ ...contact,
927
+ content
928
+ };
929
+ }
930
+ }
931
+ if (i === 'userModel' && results[i]) {
932
+ if (results[i].userHeadUrl) {
933
+ results[i].userHeadUrl = util.jointUrl({
934
+ url: results[i].userHeadUrl,
935
+ reg: '/main2'
936
+ });
937
+ } else {
938
+ results[i].userHeadUrl = this.userHead;
939
+ }
940
+ this.userModel = results[i];
941
+ }
942
+ if (i === 'notifyList' && results[i]) {
943
+ this.notifyList = results[i];
944
+ }
945
+ store.set(i, results[i]);
946
+ }
947
+ },
948
+ /**
949
+ * @desc:获取所有应用
950
+ * @author huangbo
951
+ * @date 2024年9月7日
952
+ **/
953
+ getApplications() {
954
+ let loading = util.loading('', '加载中...');
955
+ util
956
+ .ajax({
957
+ url: this.appsUrl,
958
+ defaults: true
959
+ })
960
+ .then((res) => {
961
+ if (this.socket) {
962
+ this.initWebSocket();
963
+ }
964
+ if (res.rCode === 0) {
965
+ if (res.results && Object.keys(res.results).length) {
966
+ let { all, app_special_business_system, app_system, app_user } =
967
+ res.results;
968
+ this.userApps = app_user.filter((item) => {
969
+ return item.permission !== false;
970
+ });
971
+ this.applications = all;
972
+ this.business = app_special_business_system;
973
+ this.systems = app_system;
974
+ this.setTips(this.userApps);
975
+ this.setTips(this.applications);
976
+ this.setTips(this.business);
977
+ this.setTips(this.systems);
978
+ } else {
979
+ this.$message.error('未分配应用菜单权限,请联系管理员!');
980
+ }
981
+ this.getMenus(loading);
982
+ } else {
983
+ loading.close();
984
+ let msg = res.msg || '系统错误,请联系管理员!';
985
+ this.$message.error(msg);
986
+ }
987
+ })
988
+ .catch((err) => {
989
+ loading.close();
990
+ if (err.message && err.message !== 'canceled') {
991
+ this.$message.error(err.message);
992
+ }
993
+ });
994
+ },
995
+ /**
996
+ * @desc:获取菜单列表
997
+ * @author huangbo
998
+ * @date 2024年9月7日
999
+ **/
1000
+ getMenus(loading) {
1001
+ const menuData = store.get('nav');
1002
+ if (menuData && menuData.length) {
1003
+ loading.close();
1004
+ this.renderMenus(menuData);
1005
+ return;
1006
+ }
1007
+ util
1008
+ .ajax({ url: this._menuUrl })
1009
+ .then((res) => {
1010
+ loading.close();
1011
+ if (res.rCode === 0) {
1012
+ if (res.results && res.results.length) {
1013
+ //this.$emit('update:menuData', res.results);
1014
+ store.set('nav', JSON.parse(JSON.stringify(res.results)));
1015
+ this.renderMenus(JSON.parse(JSON.stringify(res.results)));
1016
+ } else {
1017
+ this.$message.error('未分配菜单权限,请联系管理员!');
1018
+ }
1019
+ } else {
1020
+ let msg = res.msg || '系统错误,请联系管理员!';
1021
+ this.$message.error(msg);
1022
+ }
1023
+ })
1024
+ .catch((err) => {
1025
+ loading.close();
1026
+ if (err.message && err.message !== 'canceled') {
1027
+ this.$message.error(err.message);
1028
+ }
1029
+ });
1030
+ },
1031
+ /**
1032
+ * @desc:处理菜单列表
1033
+ * @author huangbo
1034
+ * @date 2024年9月7日
1035
+ **/
1036
+ renderMenus(res) {
1037
+ this.menus = res;
1038
+ this.setTips(this.menus);
1039
+ store.set('nav', this.menus);
1040
+ if (this.indexUrl) {
1041
+ let obj = this.getMenu(this.menus, this.indexUrl);
1042
+ obj = obj
1043
+ ? obj
1044
+ : {
1045
+ url: this.indexUrl,
1046
+ text: '工作台',
1047
+ id: '0',
1048
+ appCode: 'indexUrl'
1049
+ };
1050
+ this.homePage = this.setIframeType(obj);
1051
+ if (!this.appCode) {
1052
+ this.tabs = [this.homePage];
1053
+ this.activeName = this.homePage.id;
1054
+ }
1055
+ }
1056
+ if (this.appCode) {
1057
+ let code = this.sysCode || this.appCode;
1058
+ let app = this.userApps.filter((item) => {
1059
+ return item.code === code;
1060
+ })[0];
1061
+ if (app) {
1062
+ this.active = app.id;
1063
+ if (app.url) {
1064
+ let obj = this.getMenu(this.menus, app.url);
1065
+ if (obj) {
1066
+ let tab = this.setIframeType(obj);
1067
+ this.tabs = [tab];
1068
+ this.activeName = tab.id;
1069
+ } else {
1070
+ this.tabs = [app];
1071
+ }
1072
+ }
1073
+ }
1074
+ if (this.sysCode) {
1075
+ let subMenus = this.getMenu(this.menus, this.sysCode, 'appCode');
1076
+ if (subMenus) {
1077
+ let obj = this.getMenu(this.menus, this.appCode, 'appCode');
1078
+ if (obj) {
1079
+ if (!obj.url) {
1080
+ obj = this.getFirst(obj);
1081
+ }
1082
+ this.subActive = obj.id;
1083
+ let tab = this.setIframeType(obj);
1084
+ this.tabs = [tab];
1085
+ this.activeName = tab.id;
1086
+ } else {
1087
+ this.subActive = '';
1088
+ }
1089
+ this.subMenus = subMenus;
1090
+ this.showMenu =
1091
+ (subMenus.children && subMenus.children.length > 0) ||
1092
+ (subMenus.fourthTabs && subMenus.fourthTabs.length > 0);
1093
+ } else {
1094
+ this.subMenus = null;
1095
+ this.showMenu = false;
1096
+ }
1097
+ } else {
1098
+ let subMenus = this.getMenu(this.menus, this.appCode, 'appCode');
1099
+ if (subMenus) {
1100
+ if (this.tabs.length == 0) {
1101
+ let obj = this.getFirst(subMenus);
1102
+ if (obj) {
1103
+ this.subActive = obj.id;
1104
+ let tab = this.setIframeType(obj);
1105
+ this.tabs = [tab];
1106
+ this.activeName = tab.id;
1107
+ } else {
1108
+ this.subActive = '';
1109
+ }
1110
+ }
1111
+ this.subMenus = subMenus;
1112
+ this.showMenu =
1113
+ (subMenus.children && subMenus.children.length > 0) ||
1114
+ (subMenus.fourthTabs && subMenus.fourthTabs.length > 0);
1115
+ } else {
1116
+ this.subMenus = null;
1117
+ this.showMenu = false;
1118
+ }
1119
+ }
1120
+ } else if (this.initApps && this.initApps.length && !this.indexUrl) {
1121
+ let obj = this.getMenu(
1122
+ this.menus,
1123
+ this.initApps[this.initApps.length - 1]
1124
+ );
1125
+ if (obj) {
1126
+ let tab = this.setIframeType(obj);
1127
+ this.tabs.push(tab);
1128
+ this.activeName = tab.id;
1129
+ }
1130
+ }
1131
+ },
1132
+ /**
1133
+ * @desc:设置页面加载类型
1134
+ * @author huangbo
1135
+ * @date 2024年9月7日
1136
+ **/
1137
+ setIframeType(res) {
1138
+ let { url } = res;
1139
+ let urls = url.split('?');
1140
+ if (urls[0].indexOf('.js') > 1 && !isIE) {
1141
+ res.method = 'wujie';
1142
+ if (!res.appCode) {
1143
+ res.appCode = 'application_' + Date.now();
1144
+ }
1145
+ } else if (
1146
+ urls[0].indexOf('.dhtml') > 0 ||
1147
+ (urls[0].indexOf('.html') > 0 && urls[0].indexOf('.html#') === -1)
1148
+ ) {
1149
+ res.method = 'iframe';
1150
+ } else {
1151
+ if (urls[0].indexOf('.html') === -1 && urls[0].indexOf('#/') === -1) {
1152
+ res.method = 'iframe';
1153
+ } else {
1154
+ const routes = this.$router.options.routes;
1155
+ if (routes) {
1156
+ let path = this.hasRouter(routes, urls[0], res.appCode);
1157
+ if (path && this.routeType !== 'wujie') {
1158
+ res.method = 'router';
1159
+ if (typeof path === 'string') {
1160
+ res.path = path;
1161
+ } else {
1162
+ res.path = path.path;
1163
+ res.appCode = path.appCode;
1164
+ }
1165
+ res.keys = util.uuid();
1166
+ } else {
1167
+ let urlopenmode = util.getParams({
1168
+ url: url,
1169
+ name: 'urlopenmode'
1170
+ });
1171
+ if (
1172
+ this.loadWujie === false ||
1173
+ isIE ||
1174
+ res.urlopenmode == 3 ||
1175
+ urlopenmode == 3
1176
+ ) {
1177
+ res.method = 'iframe';
1178
+ } else {
1179
+ res.method = 'wujie';
1180
+ if (!res.appCode) {
1181
+ res.appCode = 'application_' + Date.now();
1182
+ }
1183
+ }
1184
+ }
1185
+ } else if (
1186
+ (urls[0].indexOf('.html') > -1 && urls[0].indexOf('#/') > -1) ||
1187
+ urls[0].indexOf('/#/') > -1
1188
+ ) {
1189
+ res.method = 'wujie';
1190
+ if (!res.appCode) {
1191
+ res.appCode = 'application_' + Date.now();
1192
+ }
1193
+ } else {
1194
+ res.method = 'iframe';
1195
+ }
1196
+ }
1197
+ }
1198
+ return res;
1199
+ },
1200
+ /**
1201
+ * @desc:获取菜单
1202
+ * @author huangbo
1203
+ * @date 2024年9月7日
1204
+ **/
1205
+ getMenu(menus, res, key) {
1206
+ if (Array.isArray(menus)) {
1207
+ for (let i = 0; i < menus.length; i++) {
1208
+ let item = menus[i];
1209
+ if (key) {
1210
+ if (item[key] === res) {
1211
+ return item;
1212
+ }
1213
+ } else if (
1214
+ item.url === res ||
1215
+ item.id === res ||
1216
+ (item.appCode && item.appCode === res)
1217
+ ) {
1218
+ return item;
1219
+ }
1220
+ if (
1221
+ Object.prototype.hasOwnProperty.call(item, 'children') &&
1222
+ item.children.length
1223
+ ) {
1224
+ let obj = this.getMenu(item.children, res, key);
1225
+ if (obj) {
1226
+ return obj;
1227
+ }
1228
+ } else if (
1229
+ Object.prototype.hasOwnProperty.call(item, 'fourthTabs') &&
1230
+ item.fourthTabs.length
1231
+ ) {
1232
+ let obj = this.getMenu(item.fourthTabs, res, key);
1233
+ if (obj) {
1234
+ return obj;
1235
+ }
1236
+ }
1237
+ }
1238
+ }
1239
+ return false;
1240
+ },
1241
+ /**
1242
+ * @desc:获取菜单第一条数据
1243
+ * @author huangbo
1244
+ * @date 2024年9月7日
1245
+ **/
1246
+ getFirst(obj) {
1247
+ if (!obj) {
1248
+ return '';
1249
+ }
1250
+ let openIdex = 0;
1251
+ if (
1252
+ obj.extendData &&
1253
+ (obj.extendData.subDefOpenIndex || obj.extendData.subDefOpen)
1254
+ ) {
1255
+ openIdex = parseInt(
1256
+ obj.extendData.subDefOpenIndex || obj.extendData.subDefOpen,
1257
+ 10
1258
+ );
1259
+ }
1260
+ if (obj.children && obj.children.length && obj.children[openIdex]) {
1261
+ return this.getFirst(obj.children[openIdex]);
1262
+ } else if (
1263
+ obj.fourthTabs &&
1264
+ obj.fourthTabs.length &&
1265
+ obj.fourthTabs[openIdex]
1266
+ ) {
1267
+ return this.getFirst(obj.fourthTabs[openIdex]);
1268
+ } else if (obj.url && obj.urlopenmode !== 1 && obj.urlopenmode !== 2) {
1269
+ return obj;
1270
+ }
1271
+ },
1272
+ /**
1273
+ * @desc:遍历设置菜单气泡提醒
1274
+ * @author huangbo
1275
+ * @date 2024年9月7日
1276
+ **/
1277
+ setTips(obj) {
1278
+ if (Array.isArray(obj)) {
1279
+ obj.forEach((item) => {
1280
+ this.setTips(item);
1281
+ });
1282
+ } else {
1283
+ if (
1284
+ obj &&
1285
+ Object.prototype.hasOwnProperty.call(obj, 'tips') &&
1286
+ obj.tips
1287
+ ) {
1288
+ this.$set(obj, 'tips', false);
1289
+ delete obj.tips;
1290
+ }
1291
+ let flag = 0;
1292
+ if (obj.children && obj.children.length) {
1293
+ obj.children.forEach((item) => {
1294
+ let n = this.setTips(item);
1295
+ flag += n ? parseInt(n) : 0;
1296
+ });
1297
+ if (flag) {
1298
+ this.$set(obj, 'tips', flag);
1299
+ this.setDot(this.userApps, obj.appCode);
1300
+ this.setDot(this.applications, obj.appCode);
1301
+ this.setDot(this.business, obj.appCode);
1302
+ this.setDot(this.systems, obj.appCode);
1303
+ return flag;
1304
+ }
1305
+ } else if (obj.fourthTabs && obj.fourthTabs.length) {
1306
+ obj.fourthTabs.forEach((item) => {
1307
+ let n = this.setTips(item);
1308
+ flag += n ? parseInt(n) : 0;
1309
+ });
1310
+ if (flag) {
1311
+ this.$set(obj, 'tips', flag);
1312
+ this.setDot(this.userApps, obj.appCode);
1313
+ this.setDot(this.applications, obj.appCode);
1314
+ this.setDot(this.business, obj.appCode);
1315
+ this.setDot(this.systems, obj.appCode);
1316
+ return flag;
1317
+ }
1318
+ } else {
1319
+ let num =
1320
+ this.menuTips[obj.id] ||
1321
+ this.menuTips[obj.code] ||
1322
+ this.menuTips[obj.appCode];
1323
+ if (num && Number(num)) {
1324
+ this.$set(obj, 'tips', Number(num));
1325
+ return num;
1326
+ }
1327
+ }
1328
+ }
1329
+ return false;
1330
+ },
1331
+ setDot(obj, code) {
1332
+ if (Array.isArray(obj)) {
1333
+ obj.forEach((item) => {
1334
+ this.setDot(item, code);
1335
+ });
1336
+ } else if (obj.code === code) {
1337
+ this.$set(obj, 'tips', true);
1338
+ }
1339
+ },
1340
+ /**
1341
+ * @desc:获取气泡提醒
1342
+ * @author huangbo
1343
+ * @date 2024年9月7日
1344
+ **/
1345
+ getBadge(res) {
1346
+ let num = res.tips || 0;
1347
+ return num === true
1348
+ ? {
1349
+ isDot: true
1350
+ //hidden: item.tips
1351
+ }
1352
+ : {
1353
+ value: num,
1354
+ max: 99,
1355
+ hidden: !num
1356
+ };
1357
+ },
1358
+ /**
1359
+ * @desc:开启weosocket
1360
+ * @author huangbo
1361
+ * @date 2024年9月7日
1362
+ **/
1363
+ initWebSocket() {
1364
+ this.webSocket = util.socket({
1365
+ url: wss,
1366
+ take: topic,
1367
+ success: (res) => {
1368
+ let data = res.data || {};
1369
+ for (let i in data) {
1370
+ if (data[i] !== null && data[i] !== undefined) {
1371
+ if (i === 'onlineUserNums' && data[i] > 0) {
1372
+ this.userNums = data[i];
1373
+ }
1374
+ if (i === 'sysMsgNums' && data[i] !== null) {
1375
+ this.notice = data[i];
1376
+ if (this.showMsg) {
1377
+ this.$refs.message.getMsg(true);
1378
+ }
1379
+ }
1380
+ if (i === 'menuTipsMap' && data[i] !== null) {
1381
+ this.menuTips = data[i];
1382
+ }
1383
+ if (i === 'sysMsgList' && data[i] !== null) {
1384
+ this.sysMsg = data[i];
1385
+ data[i] && data[i].length && this.$emit('bus-emit', 'waitdone');
1386
+ }
1387
+ if (i === 'extraData' && data[i] !== null) {
1388
+ this.extraData = data[i];
1389
+ }
1390
+ }
1391
+ }
1392
+ if (this.$store) {
1393
+ try {
1394
+ this.$store.commit('websocket', data);
1395
+ } catch (error) {}
1396
+ }
1397
+ if (this.$eventBus) {
1398
+ this.$eventBus.$emit('websocket', data);
1399
+ }
1400
+ if (util.win.eventBus) {
1401
+ util.win.eventBus.$emit('websocket', data);
1402
+ }
1403
+ }
1404
+ });
1405
+ },
1406
+ /**
1407
+ * @desc:显示用户信息
1408
+ * @author huangbo
1409
+ * @date 2024年9月7日
1410
+ **/
1411
+ showUserInfo() {
1412
+ if (this.showUser === false) {
1413
+ this.showUser = true;
1414
+ }
1415
+ },
1416
+ /**
1417
+ * @desc:删除更多应用菜单点击
1418
+ * @author huangbo
1419
+ * @date 2024年9月7日
1420
+ **/
1421
+ handleDelete(index) {
1422
+ this.newApps.splice(index, 1);
1423
+ },
1424
+ /**
1425
+ * @desc:储存更多应用菜单点击
1426
+ * @author huangbo
1427
+ * @date 2024年9月7日
1428
+ **/
1429
+ handlerClickApps(res) {
1430
+ if (res.permission === false) {
1431
+ return false;
1432
+ }
1433
+ let i = util.indexOfObj(this.newApps, res, 'id');
1434
+ if (i == -1) {
1435
+ this.newApps.push(res);
1436
+ }
1437
+ this.handlerClickApp(res);
1438
+ },
1439
+ /**
1440
+ * @desc:侧边应用菜单点击
1441
+ * @author huangbo
1442
+ * @date 2024年9月7日
1443
+ **/
1444
+ handlerClickApp(res) {
1445
+ this.showMsg = false;
1446
+ this.showSet = false;
1447
+ this.fold = false;
1448
+ this.showApps = false;
1449
+ this.drawer.visible = false;
1450
+ if (res) {
1451
+ if (res.permission === false) {
1452
+ return false;
1453
+ }
1454
+ if (
1455
+ (res.children && res.children.length) ||
1456
+ (res.fourthTabs && res.fourthTabs.length)
1457
+ ) {
1458
+ this.subMenus = res;
1459
+ this.showMenu = true;
1460
+ } else {
1461
+ this.subMenus = null;
1462
+ this.showMenu = false;
1463
+ }
1464
+ let set = true;
1465
+ if (res.url) {
1466
+ if (res.urlopenmode == 1 || res.openModel == 1) {
1467
+ set = false;
1468
+ util.win.open(res.url);
1469
+ } else if (res.urlopenmode == 2 || res.openModel == 2) {
1470
+ set = false;
1471
+ util.win.open(res.url, '_self');
1472
+ } else {
1473
+ let i = util.indexOfObj(this.tabs, res, 'id');
1474
+ this.activeName = res.id;
1475
+ if (i == -1) {
1476
+ let obj = res.code
1477
+ ? this.getMenu(this.menus, res.code, 'appCode')
1478
+ : null;
1479
+ if (obj) {
1480
+ let n = util.indexOfObj(this.tabs, obj, 'id');
1481
+ if (n == -1) {
1482
+ let tab = this.setIframeType(obj);
1483
+ this.tabs.push(tab);
1484
+ this.activeName = tab.id;
1485
+ } else {
1486
+ if (obj.method == 'iframe') {
1487
+ obj.url = util.handlerUrl(obj.url);
1488
+ }
1489
+ }
1490
+ } else {
1491
+ let tab = this.setIframeType(res);
1492
+ this.tabs.push(tab);
1493
+ this.activeName = tab.id;
1494
+ }
1495
+ } else {
1496
+ if (res.method == 'iframe') {
1497
+ res.url = util.handlerUrl(res.url);
1498
+ }
1499
+ }
1500
+ }
1501
+ }
1502
+ if (set && res.code) {
1503
+ let subMenus = this.getMenu(this.menus, res.code, 'appCode');
1504
+ if (!subMenus && !res.url) {
1505
+ this.$alert('没有关联菜单,请联系管理员!', '提示', {
1506
+ confirmButtonText: '确定',
1507
+ type: 'warning'
1508
+ }).catch(() => {});
1509
+ } else {
1510
+ this.title = res.text || res.name;
1511
+ this.subMenus = subMenus ? subMenus : null;
1512
+ this.showMenu = subMenus
1513
+ ? (subMenus.children && subMenus.children.length > 0) ||
1514
+ (subMenus.fourthTabs && subMenus.fourthTabs.length > 0)
1515
+ : false;
1516
+ this.showApps = false;
1517
+ if (subMenus && subMenus.url) {
1518
+ let i = util.indexOfObj(this.tabs, subMenus, 'id');
1519
+ this.activeName = subMenus.id;
1520
+ if (i == -1) {
1521
+ let tab = this.setIframeType(subMenus);
1522
+ this.tabs.push(tab);
1523
+ } else {
1524
+ if (subMenus.method == 'iframe') {
1525
+ subMenus.url = util.handlerUrl(subMenus.url);
1526
+ }
1527
+ }
1528
+ }
1529
+ }
1530
+ }
1531
+ this.active = res.id;
1532
+ } else {
1533
+ this.showApps = !this.showApps;
1534
+ }
1535
+ },
1536
+ /**
1537
+ * @desc:显示Drawer界面
1538
+ * @author huangbo
1539
+ * @date 2024年9月7日
1540
+ **/
1541
+ handlerSetDrawer(res, type, direction = 'ltr') {
1542
+ this.drawer.visible = true;
1543
+ this.drawer.active = type;
1544
+ this.drawer.direction = direction;
1545
+ if (res) {
1546
+ let { mounted, url } = res;
1547
+ this.drawer[type] = {
1548
+ mounted,
1549
+ url,
1550
+ name: res.name || util.uuid()
1551
+ };
1552
+ }
1553
+ },
1554
+ /**
1555
+ * @desc:关闭Drawer界面
1556
+ * @author huangbo
1557
+ * @date 2024年9月7日
1558
+ **/
1559
+ handleCloseDrawer() {
1560
+ this.drawer = { visible: false };
1561
+ },
1562
+ /**
1563
+ * @desc:菜单点击
1564
+ * @author huangbo
1565
+ * @date 2024年9月7日
1566
+ **/
1567
+ handlerClickMenu(res) {
1568
+ util
1569
+ .ajax({
1570
+ url: recordUserApp,
1571
+ params: {
1572
+ userId: this.user.userId,
1573
+ appId: res.id
1574
+ }
1575
+ })
1576
+ .then(() => {})
1577
+ .catch(() => {});
1578
+ this.showMsg = false;
1579
+ this.showSet = false;
1580
+ let i = util.indexOfObj(this.tabs, res, 'id');
1581
+ if (i == -1) {
1582
+ let tab = this.setIframeType(res);
1583
+ this.tabs.push(tab);
1584
+ this.activeName = res.id;
1585
+ } else {
1586
+ this.tabs = events[0](this.tabs, i, this);
1587
+ // let tab = this.tabs[i];
1588
+ // if (tab.method === 'iframe') {
1589
+ // this.activeName = res.id;
1590
+ // this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1591
+ // } else {
1592
+ // if (tab.method === 'wujie' && tab.appCode) {
1593
+ // window.document
1594
+ // .querySelector(`iframe[name=${tab.appCode}]`)
1595
+ // .contentWindow.location.reload(true);
1596
+ // }
1597
+ // if (tab.method === 'router') {
1598
+ // this.$set(this.tabs[i], 'keys', util.uuid());
1599
+ // }
1600
+ // this.activeName = res.id;
1601
+ // }
1602
+ this.activeName = res.id;
1603
+ }
1604
+ },
1605
+
1606
+ /**
1607
+ * @desc:用户详情请求成功
1608
+ * @author huangbo
1609
+ * @date 2024年9月7日
1610
+ **/
1611
+ handleSuccess(res) {
1612
+ this.simpleUserInfo = res.simpleUserInfo;
1613
+ },
1614
+ /**
1615
+ * @desc:修改用户配置
1616
+ * @author huangbo
1617
+ * @date 2024年9月7日
1618
+ **/
1619
+ handleChangeConfig(name, res) {
1620
+ if (name == 'userHeadUrl') {
1621
+ this.$set(this.userModel, 'userHeadUrl', res);
1622
+ store.set('userModel', this.userModel);
1623
+ let mainConfig = JSON.parse(localStorage.getItem('mainConfig'));
1624
+ sessionStorage.setItem(
1625
+ 'mainConfig',
1626
+ JSON.stringify({ ...mainConfig, userModel: this.userModel })
1627
+ );
1628
+ } else {
1629
+ this.$set(this.userStyle, 'notify', res);
1630
+ store.set('userStyle', this.userStyle);
1631
+ let mainConfig = JSON.parse(localStorage.getItem('mainConfig'));
1632
+ localStorage.setItem(
1633
+ 'mainConfig',
1634
+ JSON.stringify({ ...mainConfig, userStyle: this.userStyle })
1635
+ );
1636
+ }
1637
+ },
1638
+ /**
1639
+ * @desc:关闭webSocket
1640
+ * @author huangbo
1641
+ * @date 2024年9月7日
1642
+ **/
1643
+ handlerClose() {
1644
+ if (this.webSocket) {
1645
+ this.webSocket.destroy();
1646
+ }
1647
+ },
1648
+ /**
1649
+ * @desc:刷新选中iframe页签
1650
+ * @author huangbo
1651
+ * @date 2024年9月7日
1652
+ **/
1653
+ handleRefresh() {
1654
+ let i = util.indexOfObj(this.tabs, this.activeName, 'id');
1655
+ let tab = this.tabs[i];
1656
+ if (tab.method === 'iframe') {
1657
+ tab.url = util.handlerUrl(tab.url);
1658
+ } else {
1659
+ let tab = this.tabs[i];
1660
+ if (tab.method === 'iframe') {
1661
+ this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1662
+ }
1663
+ if (tab.method === 'wujie' && tab.appCode) {
1664
+ window.document
1665
+ .querySelector(`iframe[name=${tab.appCode}]`)
1666
+ .contentWindow.location.reload(true);
1667
+ }
1668
+ if (tab.method === 'router') {
1669
+ this.$set(this.tabs[i], 'keys', util.uuid());
1670
+ }
1671
+ }
1672
+ },
1673
+ /**
1674
+ * @desc:删除iframe
1675
+ * @author huangbo
1676
+ * @date 2024年9月7日
1677
+ **/
1678
+ handleRemove(name) {
1679
+ let len = this.tabs.length - 1;
1680
+ let i = util.indexOfObj(this.tabs, name, 'id,code,appCode');
1681
+ if (i > -1) {
1682
+ this.tabs.splice(i, 1);
1683
+ if (this.tabs.length == 0) {
1684
+ this.activeName = '';
1685
+ } else if (i == len) {
1686
+ this.activeName = this.tabs[len - 1].id;
1687
+ } else {
1688
+ this.activeName = this.tabs[i].id;
1689
+ }
1690
+ }
1691
+ },
1692
+ /**
1693
+ * @desc:tabs鼠标右键事件
1694
+ * @author huangbo
1695
+ * @date 2024年9月7日
1696
+ **/
1697
+ handleContextmenu(tabs, e) {
1698
+ let disabled = {};
1699
+ let index = parseInt(tabs.index, 10);
1700
+ if (index == 0) {
1701
+ disabled.left = true;
1702
+ }
1703
+ if (index == this.tabs.length - 1) {
1704
+ disabled.right = true;
1705
+ }
1706
+ if (this.tabs.length == 1) {
1707
+ disabled.other = true;
1708
+ }
1709
+ if (this.tabs[index].id != this.activeName) {
1710
+ disabled.refresh = true;
1711
+ }
1712
+ this.isDisabled = disabled;
1713
+ this.$refs.tabsHandler.$el.style.setProperty('left', `${e.x}px`);
1714
+ this.$refs.tabsHandler.$el.style.setProperty('top', `${e.y}px`);
1715
+ this.showTabsHandler = true;
1716
+ this.pane = index;
1717
+ window.addEventListener('click', this.closeTabsEvents);
1718
+ },
1719
+ /**
1720
+ * @desc:tabs页签事件
1721
+ * @author huangbo
1722
+ * @date 2024年9月7日
1723
+ **/
1724
+ handleTabsEvents(num) {
1725
+ if (this.pane !== null) {
1726
+ this.tabs = events[num](this.tabs, this.pane, this);
1727
+ }
1728
+ this.showTabsHandler = false;
1729
+ window.removeEventListener('click', this.closeTabsEvents);
1730
+ },
1731
+ //关闭页签事件面板
1732
+ closeTabsEvents(e) {
1733
+ if (
1734
+ e.target.parentNode != this.$refs.tabsHandler.$el &&
1735
+ e.target.parentNode.parentNode != this.$refs.tabsHandler.$el
1736
+ ) {
1737
+ this.showTabsHandler = false;
1738
+ }
1739
+ window.removeEventListener('click', this.closeTabsEvents);
1740
+ },
1741
+ /**
1742
+ * @desc:handler工具栏点击事件
1743
+ * @author huangbo
1744
+ * @date 2024年9月7日
1745
+ **/
1746
+ handleClick(res) {
1747
+ const { type, event, open, link } = res;
1748
+ if (event) {
1749
+ event();
1750
+ } else if (open) {
1751
+ util.win.open(open);
1752
+ } else if (link) {
1753
+ util.win.open(link, '_self');
1754
+ } else {
1755
+ switch (type) {
1756
+ case 'quit':
1757
+ this.handleQuit();
1758
+ break;
1759
+ case 'online':
1760
+ this.showMsg = false;
1761
+ this.showSet = false;
1762
+ this.dialog = {
1763
+ title: '查看在线人员',
1764
+ show: true,
1765
+ src: this.onlineUrl
1766
+ };
1767
+ break;
1768
+ case 'notice':
1769
+ this.showMsg = !this.showMsg;
1770
+ this.showSet = false;
1771
+ break;
1772
+ case 'index':
1773
+ util.win.open(this.doorIndex, '_self');
1774
+ break;
1775
+ case 'set':
1776
+ this.showSet = !this.showSet;
1777
+ this.showMsg = false;
1778
+ break;
1779
+ case 'home':
1780
+ let i = util.indexOfObj(this.tabs, this.homePage.id, 'id');
1781
+ if (i == -1) {
1782
+ this.tabs.unshift(this.homePage);
1783
+ } else {
1784
+ let tab = this.tabs[i];
1785
+ if (tab.method === 'iframe') {
1786
+ this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url));
1787
+ }
1788
+ if (tab.method === 'wujie' && tab.appCode) {
1789
+ window.document
1790
+ .querySelector(`iframe[name=${tab.appCode}]`)
1791
+ .contentWindow.location.reload(true);
1792
+ }
1793
+ if (tab.method === 'router') {
1794
+ this.$set(this.tabs[i], 'keys', util.uuid());
1795
+ }
1796
+ }
1797
+ this.activeName = this.homePage.id;
1798
+ this.showMsg = false;
1799
+ this.showSet = false;
1800
+ break;
1801
+ case 'search':
1802
+ this.showSearch = true;
1803
+ this.showMsg = false;
1804
+ this.showSet = false;
1805
+ break;
1806
+ case 'ai':
1807
+ this.handlerSetDrawer(this._aiConfig, 'ai', 'rtl');
1808
+ break;
1809
+ case 'im':
1810
+ this.handlerSetDrawer(this.imConfig, 'im', 'rtl');
1811
+ break;
1812
+ case 'goView':
1813
+ util.win.open(res.path, '_blank');
1814
+ break;
1815
+ }
1816
+ }
1817
+ this.$emit('handler-click', res);
1818
+ },
1819
+ /**
1820
+ * @desc:退出登录
1821
+ * @author huangbo
1822
+ * @date 2024年9月7日
1823
+ **/
1824
+ handleQuit() {
1825
+ this.$confirm('确定退出吗?', '退出系统', {
1826
+ confirmButtonText: '确定',
1827
+ cancelButtonText: '取消',
1828
+ type: 'warning'
1829
+ })
1830
+ .then(() => {
1831
+ let iframes = document.getElementsByTagName('iframe');
1832
+ for (let i = 0; i < iframes.length; i++) {
1833
+ let src = iframes[i] ? iframes[i].src : null;
1834
+ let origin = util.win.location.origin;
1835
+ if (
1836
+ src &&
1837
+ util.startWith(src, 'http') &&
1838
+ src.indexOf(origin) === -1
1839
+ ) {
1840
+ iframes[i] && iframes[i].contentWindow.postMessage('logout', '*');
1841
+ }
1842
+ break;
1843
+ }
1844
+ if (this.singleLogout) {
1845
+ for (let i = 0; i < this.singleLogout.length; i++) {
1846
+ let iframe = document.createElement('iframe');
1847
+ iframe.style.display = 'none';
1848
+ iframe.src = this.singleLogout[i];
1849
+ document.body.appendChild(iframe);
1850
+ }
1851
+ }
1852
+ util
1853
+ .ajax({ method: 'post', url: logout })
1854
+ .then((res) => {
1855
+ if (res.rCode == 0) {
1856
+ util.removeStorage([
1857
+ 'Authorization',
1858
+ 'token',
1859
+ 'ssId',
1860
+ 'userId',
1861
+ 'userName',
1862
+ 'auth',
1863
+ 'deviceUnique',
1864
+ 'menus',
1865
+ 'useCaseCodes',
1866
+ 'mainConfig',
1867
+ 'jump'
1868
+ ]);
1869
+ if (this.onQuit && typeof this.onQuit === 'function') {
1870
+ this.onQuit();
1871
+ } else {
1872
+ try {
1873
+ const loginPage =
1874
+ util.getStorage('login') || util.getStorage('loginPage');
1875
+ if (loginPage) {
1876
+ let src;
1877
+ if (!util.startWith(loginPage, ['http', '/'], true)) {
1878
+ let pathname = util.win.top.location.pathname;
1879
+ if (pathname !== '/') {
1880
+ pathname = pathname.split('/');
1881
+ pathname.splice(pathname.length - 1);
1882
+ pathname = pathname.join('/');
1883
+ src = pathname + '/' + loginPage.replace('./', '');
1884
+ } else {
1885
+ src = pathname + loginPage.replace('./', '');
1886
+ }
1887
+ } else {
1888
+ src = loginPage;
1889
+ }
1890
+ util.win.top.location.href = src;
1891
+ } else if (
1892
+ util.win.top.location.href.indexOf('main.html') > -1
1893
+ ) {
1894
+ util.win.top.location.href = './login.html';
1895
+ } else {
1896
+ const hash = util.win.top.location.hash;
1897
+ if (hash) {
1898
+ const len = util.win.top.location.href.indexOf(hash);
1899
+ util.win.top.location.href =
1900
+ util.win.location.href.slice(0, len) + '#/login';
1901
+ } else {
1902
+ util.win.top.location.href = '/login.html';
1903
+ }
1904
+ }
1905
+ } catch (error) {
1906
+ util.win.top.postMessage({ type: 1 }, '*');
1907
+ }
1908
+ }
1909
+ }
1910
+ })
1911
+ .catch((err) => {
1912
+ if (err.message && err.message !== 'canceled') {
1913
+ this.$message.error(err.message);
1914
+ }
1915
+ });
1916
+ })
1917
+ .catch((e) => {});
1918
+ },
1919
+ /**
1920
+ * @desc:主题、消息回调
1921
+ * @author huangbo
1922
+ * @date 2024年9月7日
1923
+ **/
1924
+ handleChange(res) {
1925
+ const { type, value } = res;
1926
+ switch (type) {
1927
+ case 'theme':
1928
+ this.setTheme(value);
1929
+ break;
1930
+ case 'ignore':
1931
+ this.notice = 0;
1932
+ break;
1933
+ }
1934
+ },
1935
+ /**
1936
+ * @desc:菜单布局样式切换
1937
+ * @author huangbo
1938
+ * @date 2024年9月7日
1939
+ **/
1940
+ handleLayout(res, active) {
1941
+ if (active) {
1942
+ localStorage.setItem('layout', active);
1943
+ }
1944
+ this.$emit('chang-layout', res, active);
1945
+ },
1946
+ /**
1947
+ * @desc:消息修改总数
1948
+ * @author huangbo
1949
+ * @date 2024年9月7日
1950
+ **/
1951
+ handleMenuTips(id, num) {
1952
+ if (num) {
1953
+ this.$set(this.menuTips, id, num);
1954
+ } else {
1955
+ let n = parseInt(this.menuTips[id], 10) - 1;
1956
+ this.$set(this.menuTips, id, n);
1957
+ }
1958
+ },
1959
+ /**
1960
+ * @desc:处理即时消息
1961
+ * @author huangbo
1962
+ * @date 2024年9月7日
1963
+ **/
1964
+ handleOpened(res) {
1965
+ if (res === undefined) {
1966
+ this.sysMsg = [];
1967
+ } else if (res == false && this.sysMsg.length) {
1968
+ this.sysMsgOut = setTimeout(() => {
1969
+ this.sysMsg = [];
1970
+ }, 3000);
1971
+ } else if (this.sysMsgOut) {
1972
+ clearTimeout(this.sysMsgOut);
1973
+ }
1974
+ },
1975
+ jumpMenu(res, close, params = {}) {
1976
+ let apps = res;
1977
+ let param = params;
1978
+ let reload = true;
1979
+ if (typeof res === 'string') {
1980
+ apps = res.split(',');
1981
+ } else if (util.isObject(res)) {
1982
+ apps = Array.isArray(res.appCode)
1983
+ ? res.appCode
1984
+ : res.appCode.split(',');
1985
+ res.param && (param = { ...res.param, ...params });
1986
+ reload = Object.prototype.hasOwnProperty.call(res, 'reload')
1987
+ ? res.reload
1988
+ : true;
1989
+ }
1990
+ let obj = this.getMenu(this.menus, apps[apps.length - 1]);
1991
+ if (obj) {
1992
+ let i = util.indexOfObj(this.tabs, obj, 'id,code,appCode');
1993
+ let n = util.indexOfObj(this.tabs, this.activeName, 'id');
1994
+ let old = this.activeName;
1995
+ this.activeName = obj.id;
1996
+ if (i == -1) {
1997
+ let tab = this.setIframeType(obj);
1998
+ this.$set(tab, 'url', util.handlerUrl(tab.url, param));
1999
+ this.tabs.splice(n + 1, 0, tab);
2000
+ } else {
2001
+ let tab = this.tabs[i];
2002
+ if (tab.method === 'iframe') {
2003
+ this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url, param));
2004
+ }
2005
+ if (tab.method === 'wujie' && tab.appCode) {
2006
+ const url = param ? util.handlerUrl(tab.url, param) : tab.url;
2007
+ if (reload || param) {
2008
+ tab.url = '';
2009
+ this.$nextTick(() => {
2010
+ tab.url = url;
2011
+ });
2012
+ }
2013
+ // if (param) {
2014
+ // window.document.querySelector(
2015
+ // `iframe[name=${tab.appCode}]`
2016
+ // ).contentWindow.location.href = util.handlerUrl(tab.url, param);
2017
+ // } else {
2018
+ // window.document
2019
+ // .querySelector(`iframe[name=${tab.appCode}]`)
2020
+ // .contentWindow.location.reload(true);
2021
+ // }
2022
+ }
2023
+ if (tab.method === 'router') {
2024
+ this.$set(this.tabs[i], 'url', util.handlerUrl(tab.url, param));
2025
+ this.$set(this.tabs[i], 'keys', util.uuid());
2026
+ }
2027
+ }
2028
+ if (close) {
2029
+ if (close === old) {
2030
+ this.tabs.splice(n, 0);
2031
+ } else {
2032
+ let d = util.indexOfObj(this.tabs, close, 'id,code,appCode');
2033
+ if (d > -1) {
2034
+ this.tabs.splice(d, 0);
2035
+ }
2036
+ }
2037
+ }
2038
+ } else {
2039
+ this.$message.error('没有此菜单!');
2040
+ }
2041
+ },
2042
+ //监听改变菜单
2043
+ handleListener() {
2044
+ util.win.addEventListener(
2045
+ 'message',
2046
+ (e) => {
2047
+ var msg = e.data;
2048
+ if (msg.key == 'jump_Menu') {
2049
+ let res = msg.data1;
2050
+ this.jumpMenu(res);
2051
+ }
2052
+ },
2053
+ false
2054
+ );
2055
+ },
2056
+ handleSelect(res, parent) {
2057
+ this.showSearch = false;
2058
+ if (parent.name === '应用') {
2059
+ this.handlerClickApps(res);
2060
+ }
2061
+ if (parent.name === '菜单') {
2062
+ this.handlerClickApp(res);
2063
+ }
2064
+ }
2065
+ },
2066
+ beforeDestroy() {
2067
+ clearTimeout(this.timer);
2068
+ this.timer = null;
2069
+ if (this.webSocket) {
2070
+ this.webSocket.destroy();
2071
+ }
2072
+ }
2073
+ };
2074
+ </script>
2075
+
2076
+ <style lang="scss" scoped></style>