eoss-ui 0.7.27 → 0.7.29

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