eoss-ui 0.7.94 → 0.7.96

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