eoss-ui 0.6.99 → 0.7.11

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