eoss-ui 0.7.52 → 0.7.53

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