eoss-ui 0.6.43 → 0.6.45

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