eoss-ui 0.7.64 → 0.7.66

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