eoss-ui 0.6.39 → 0.6.41

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