eoss-ui 0.7.27 → 0.7.28

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