eoss-ui 0.7.25 → 0.7.26

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