eoss-ui 0.7.56 → 0.7.57

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