eoss-ui 0.5.79 → 0.5.81-beta

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 (131) hide show
  1. package/lib/button-group.js +279 -265
  2. package/lib/button.js +71 -69
  3. package/lib/calendar.js +2 -2
  4. package/lib/card.js +2 -2
  5. package/lib/cascader.js +2 -2
  6. package/lib/checkbox-group.js +71 -70
  7. package/lib/clients.js +11 -11
  8. package/lib/config/api.js +1 -0
  9. package/lib/data-table-form.js +69 -67
  10. package/lib/data-table.js +87 -80
  11. package/lib/date-picker.js +71 -69
  12. package/lib/dialog.js +71 -70
  13. package/lib/enterprise.js +2 -2
  14. package/lib/eoss-ui.common.js +5966 -986
  15. package/lib/error-page.js +2 -2
  16. package/lib/flow-group.js +71 -69
  17. package/lib/flow-list.js +74 -72
  18. package/lib/flow.js +95 -93
  19. package/lib/form.js +179 -98
  20. package/lib/handle-user.js +72 -70
  21. package/lib/handler.js +75 -73
  22. package/lib/icon.js +3731 -12
  23. package/lib/icons.js +3 -3
  24. package/lib/index.js +1 -1
  25. package/lib/input-number.js +71 -69
  26. package/lib/input.js +71 -73
  27. package/lib/label.js +2 -2
  28. package/lib/layout.js +2 -2
  29. package/lib/login.js +146 -106
  30. package/lib/main.js +5663 -844
  31. package/lib/menu.js +2 -2
  32. package/lib/nav.js +71 -69
  33. package/lib/notify.js +72 -70
  34. package/lib/page.js +71 -69
  35. package/lib/pagination.js +2 -2
  36. package/lib/player.js +75 -73
  37. package/lib/qr-code.js +73 -71
  38. package/lib/radio-group.js +71 -69
  39. package/lib/retrial-auth.js +73 -71
  40. package/lib/select-ganged.js +71 -69
  41. package/lib/select.js +71 -69
  42. package/lib/selector-panel.js +74 -73
  43. package/lib/selector.js +80 -78
  44. package/lib/sizer.js +71 -69
  45. package/lib/steps.js +71 -69
  46. package/lib/switch.js +78 -76
  47. package/lib/table-form.js +71 -69
  48. package/lib/tabs-panel.js +2 -2
  49. package/lib/tabs.js +71 -69
  50. package/lib/theme-chalk/base.css +1 -1
  51. package/lib/theme-chalk/clients.css +1 -1
  52. package/lib/theme-chalk/data-table.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/form.css +1 -1
  56. package/lib/theme-chalk/icon.css +1 -1
  57. package/lib/theme-chalk/index.css +1 -1
  58. package/lib/theme-chalk/login.css +1 -1
  59. package/lib/theme-chalk/main.css +1 -1
  60. package/lib/theme-chalk/menu.css +1 -1
  61. package/lib/theme-chalk/simplicity.css +1 -0
  62. package/lib/theme-chalk/sizer.css +1 -1
  63. package/lib/theme-chalk/upload.css +1 -1
  64. package/lib/tips.js +72 -70
  65. package/lib/toolbar.js +2 -2
  66. package/lib/tree-group.js +71 -69
  67. package/lib/tree.js +71 -69
  68. package/lib/upload.js +146 -118
  69. package/lib/utils/util.js +2 -2
  70. package/lib/wujie.js +71 -69
  71. package/lib/wxlogin.js +214 -212
  72. package/package.json +3 -3
  73. package/packages/clients/src/main.vue +7 -7
  74. package/packages/data-table/src/main.vue +17 -5
  75. package/packages/form/src/main.vue +27 -13
  76. package/packages/handler/src/main.vue +3 -1
  77. package/packages/icon/src/main.vue +31 -10
  78. package/packages/icons/src/icon.json +1 -1
  79. package/packages/input/src/main.vue +0 -4
  80. package/packages/login/src/main.vue +13 -7
  81. package/packages/main/src/default/index.vue +2199 -0
  82. package/packages/main/src/main.vue +30 -2209
  83. package/packages/main/src/simplicity/apps.vue +301 -0
  84. package/packages/main/src/simplicity/avatar.vue +68 -0
  85. package/packages/main/src/simplicity/handler.vue +148 -0
  86. package/packages/main/src/simplicity/index.vue +1515 -0
  87. package/packages/main/src/simplicity/lists.vue +84 -0
  88. package/packages/main/src/simplicity/menu-list.vue +74 -0
  89. package/packages/main/src/simplicity/message.vue +237 -0
  90. package/packages/main/src/simplicity/notice.vue +145 -0
  91. package/packages/main/src/simplicity/settings.vue +119 -0
  92. package/packages/main/src/simplicity/sub-menu.vue +120 -0
  93. package/packages/main/src/simplicity/user.vue +243 -0
  94. package/packages/main/src/simplicity/userinfo.vue +302 -0
  95. package/packages/theme-chalk/lib/base.css +1 -1
  96. package/packages/theme-chalk/lib/clients.css +1 -1
  97. package/packages/theme-chalk/lib/data-table.css +1 -1
  98. package/packages/theme-chalk/lib/fonts/iconfont.ttf +0 -0
  99. package/packages/theme-chalk/lib/fonts/iconfont.woff +0 -0
  100. package/packages/theme-chalk/lib/form.css +1 -1
  101. package/packages/theme-chalk/lib/icon.css +1 -1
  102. package/packages/theme-chalk/lib/index.css +1 -1
  103. package/packages/theme-chalk/lib/login.css +1 -1
  104. package/packages/theme-chalk/lib/main.css +1 -1
  105. package/packages/theme-chalk/lib/menu.css +1 -1
  106. package/packages/theme-chalk/lib/simplicity.css +1 -0
  107. package/packages/theme-chalk/lib/sizer.css +1 -1
  108. package/packages/theme-chalk/lib/upload.css +1 -1
  109. package/packages/theme-chalk/src/base.scss +1 -0
  110. package/packages/theme-chalk/src/clients.scss +1 -1
  111. package/packages/theme-chalk/src/common/var.scss +4 -0
  112. package/packages/theme-chalk/src/data-table.scss +3 -0
  113. package/packages/theme-chalk/src/fonts/iconfont.ttf +0 -0
  114. package/packages/theme-chalk/src/fonts/iconfont.woff +0 -0
  115. package/packages/theme-chalk/src/form.scss +2 -2
  116. package/packages/theme-chalk/src/icon.scss +4 -4
  117. package/packages/theme-chalk/src/login.scss +644 -632
  118. package/packages/theme-chalk/src/main.scss +6 -2
  119. package/packages/theme-chalk/src/simplicity.scss +545 -0
  120. package/packages/upload/src/main.vue +132 -80
  121. package/src/config/api.js +1 -0
  122. package/src/index.js +1 -1
  123. package/src/utils/util.js +2 -2
  124. package/lib/theme-chalk/mainComp.css +0 -0
  125. package/packages/main/src/async-component/index.vue +0 -87
  126. package/packages/theme-chalk/lib/mainComp.css +0 -0
  127. package/packages/theme-chalk/src/mainComp.scss +0 -0
  128. /package/packages/main/src/{message.vue → default/message.vue} +0 -0
  129. /package/packages/main/src/{notice.vue → default/notice.vue} +0 -0
  130. /package/packages/main/src/{settings.vue → default/settings.vue} +0 -0
  131. /package/packages/main/src/{userinfo.vue → default/userinfo.vue} +0 -0
@@ -0,0 +1,1515 @@
1
+ <template>
2
+ <div class="es-main">
3
+ <div class="es-simplicity-side">
4
+ <img
5
+ class="es-simplicity-side-item es-simplicity-logo"
6
+ v-if="mainLogo"
7
+ :src="mainLogo"
8
+ />
9
+ <el-popover placement="right-start" width="360" trigger="click">
10
+ <!-- 用户信息 -->
11
+ <user
12
+ :user="user"
13
+ :notifyList="notifyList"
14
+ :notify="notify"
15
+ :contents="userInfoContents"
16
+ @change="handleChangeConfig"
17
+ @close="handlerClose"
18
+ ></user>
19
+ <avatar slot="reference" :user="user"> </avatar>
20
+ <!-- 用户信息 end -->
21
+ </el-popover>
22
+ <div class="es-simplicity-side-item es-simplicity-side-Application">
23
+ <!-- 常用应用 -->
24
+ <el-scrollbar>
25
+ <div
26
+ class="es-simplicity-side-app"
27
+ v-for="item in userApps"
28
+ :key="item.id"
29
+ :title="item.text || item.name"
30
+ @click="handlerClickApp(item)"
31
+ >
32
+ <el-badge v-bind="getBadge(item)">
33
+ <es-icon
34
+ class="es-simplicity-side-app-icon"
35
+ :contents="item.icons || item.icon || menuIcon"
36
+ ></es-icon>
37
+ <div class="es-simplicity-side-app-text">
38
+ {{ item.text || item.name }}
39
+ </div>
40
+ </el-badge>
41
+ </div>
42
+ <div
43
+ class="es-simplicity-side-app"
44
+ @click="handlerClickApp()"
45
+ v-show="menus.length"
46
+ >
47
+ <es-icon
48
+ class="es-simplicity-side-app-icon"
49
+ contents="es-icon-omit"
50
+ ></es-icon>
51
+ <div class="es-simplicity-side-app-text">更多</div>
52
+ </div>
53
+ </el-scrollbar>
54
+ <!-- 常用应用 end -->
55
+ </div>
56
+ <div
57
+ class="es-simplicity-side-app"
58
+ v-if="_aiConfig"
59
+ :style="_aibackground"
60
+ @click="handlerClickAi"
61
+ >
62
+ <es-icon
63
+ v-show="_aiConfig.icon"
64
+ class="es-simplicity-side-app-icon"
65
+ :contents="_aiConfig.icon"
66
+ ></es-icon>
67
+ <div class="es-simplicity-side-app-text" v-show="_aiConfig.text">
68
+ {{ _aiConfig.text }}
69
+ </div>
70
+ </div>
71
+ </div>
72
+ <div class="es-simplicity-main">
73
+ <!-- 菜单 -->
74
+ <el-drawer
75
+ class="es-simplicity-subMenus"
76
+ direction="ltr"
77
+ modal-class="es-simplicity-apps-modal"
78
+ :size="width"
79
+ :modal-append-to-body="false"
80
+ :with-header="false"
81
+ :visible.sync="showMenu"
82
+ >
83
+ <sub-menu
84
+ :color="menuColor"
85
+ :backgroundColor="menuBackgroundColor"
86
+ :menu-icon="menuIcon"
87
+ v-bind="subMenus"
88
+ @command="handlerClickMenu"
89
+ ></sub-menu>
90
+ </el-drawer>
91
+ <!-- 菜单 end -->
92
+
93
+ <!-- 应用 -->
94
+ <el-drawer
95
+ class="es-simplicity-apps"
96
+ direction="ltr"
97
+ modal-class="es-simplicity-apps-modal"
98
+ size="90%"
99
+ :modal-append-to-body="false"
100
+ :with-header="false"
101
+ :visible.sync="showApps"
102
+ >
103
+ <apps
104
+ :menu-icon="menuIcon"
105
+ :color="appColor"
106
+ :backgroundColor="appBackgroundColor"
107
+ :applications="applications"
108
+ :business="business"
109
+ :systems="systems"
110
+ @click="handlerClickApp"
111
+ ></apps>
112
+ </el-drawer>
113
+ <!-- 应用 end -->
114
+
115
+ <!-- AI -->
116
+ <el-drawer
117
+ class="es-simplicity-subMenus"
118
+ direction="ltr"
119
+ modal-class="es-simplicity-apps-modal"
120
+ size="100%"
121
+ :modal-append-to-body="false"
122
+ :with-header="false"
123
+ :visible.sync="showAi"
124
+ >
125
+ <iframe
126
+ frameborder="0"
127
+ width="100%"
128
+ height="100%"
129
+ :src="_aiConfig.url"
130
+ ></iframe>
131
+ </el-drawer>
132
+ <!-- AI end -->
133
+
134
+ <!-- 路由、iframe -->
135
+ <div class="es-simplicity-tabs-handler-mask" v-show="showTabsHandler">
136
+ <el-card class="es-simplicity-tabs-handler" ref="tabsHandler">
137
+ <div
138
+ class="es-simplicity-tabs-handler-item"
139
+ @click="handleTabsEvents(0)"
140
+ >
141
+ 刷新
142
+ </div>
143
+ <div
144
+ class="es-simplicity-tabs-handler-item"
145
+ @click="handleTabsEvents(1)"
146
+ >
147
+ 关闭标签
148
+ </div>
149
+ <div
150
+ class="es-simplicity-tabs-handler-item"
151
+ :class="{ 'is-disabled': isDisabled.other }"
152
+ @click="isDisabled.left ? '' : handleTabsEvents(2)"
153
+ >
154
+ 关闭其他
155
+ </div>
156
+ <div
157
+ class="es-simplicity-tabs-handler-item"
158
+ :class="{ 'is-disabled': isDisabled.left }"
159
+ @click="isDisabled.left ? '' : handleTabsEvents(3)"
160
+ >
161
+ 关闭左侧
162
+ </div>
163
+ <div
164
+ class="es-simplicity-tabs-handler-item"
165
+ :class="{ 'is-disabled': isDisabled.right }"
166
+ @click="isDisabled.right ? '' : handleTabsEvents(4)"
167
+ >
168
+ 关闭右侧
169
+ </div>
170
+ </el-card>
171
+ </div>
172
+ <el-tabs
173
+ class="es-simplicity-iframe"
174
+ v-model="activeName"
175
+ closable
176
+ hide-bar
177
+ @tab-click="handleTab"
178
+ @tab-remove="handleRemove"
179
+ @tab-contextmenu="handleContextmenu"
180
+ >
181
+ <handler
182
+ slot="append"
183
+ :hide="hides"
184
+ :notice="notice"
185
+ @click="handleClick"
186
+ ></handler>
187
+ <el-tab-pane
188
+ v-for="item in tabs"
189
+ :key="item.id"
190
+ :label="item.text || item.name"
191
+ :name="item.id"
192
+ >
193
+ <template
194
+ v-if="(isIE && item.method !== 'router') || item.method == 'iframe'"
195
+ >
196
+ <iframe
197
+ :id="iframeId"
198
+ :name="iframeId"
199
+ frameborder="0"
200
+ width="100%"
201
+ height="100%"
202
+ :src="item.url"
203
+ ></iframe>
204
+ </template>
205
+ <template v-else-if="item.method === 'wujie' && item.refresh">
206
+ <es-wujie
207
+ :show="true"
208
+ :props="wjProps"
209
+ :attrs="wjAttrs"
210
+ :name="item.appCode"
211
+ :url="item.url"
212
+ ></es-wujie>
213
+ </template>
214
+ <template v-else-if="item.method === 'router' && item.refresh">
215
+ <router-view v-if="!isKeepAlive" :name="item.appCode" />
216
+ <keep-alive>
217
+ <router-view v-if="isKeepAlive" :name="item.appCode" />
218
+ </keep-alive>
219
+ </template>
220
+ </el-tab-pane>
221
+ </el-tabs>
222
+ <!-- 路由、iframe end -->
223
+
224
+ <!-- 消息列表 -->
225
+ <message
226
+ v-if="showMsg"
227
+ ref="message"
228
+ :total.sync="notice"
229
+ :visible.sync="showMsg"
230
+ :winopen="winopen"
231
+ @ignore="handleChange"
232
+ @handle="handleMenuTips"
233
+ ></message>
234
+ <!-- 消息列表 end-->
235
+
236
+ <!-- 设置 -->
237
+ <settings
238
+ v-bind="$attrs"
239
+ :theme="themeColor"
240
+ :predefine="themes"
241
+ :visible.sync="showSet"
242
+ @change="handleChange"
243
+ ></settings>
244
+ <!-- 设置 end-->
245
+
246
+ <!-- 消息提醒 -->
247
+ <notice :data="sysMsg" :winopen="winopen" @opened="handleOpened"></notice>
248
+ <!-- 消息提醒 end -->
249
+
250
+ <!-- 公用弹窗 -->
251
+ <es-dialog :title="dialog.title" :visible.sync="dialog.show" size="md">
252
+ <iframe
253
+ v-if="dialog.show"
254
+ width="100%"
255
+ height="100%"
256
+ frameborder="0"
257
+ :src="dialog.src"
258
+ ></iframe>
259
+ </es-dialog>
260
+ <!-- 公用弹窗 end -->
261
+ </div>
262
+ </div>
263
+ </template>
264
+
265
+ <script>
266
+ import avatar from './avatar.vue';
267
+ import handler from './handler.vue';
268
+ import subMenu from './sub-menu.vue';
269
+ import apps from './apps.vue';
270
+ import user from './user.vue';
271
+ import message from './message.vue';
272
+ import notice from './notice.vue';
273
+ import settings from './settings.vue';
274
+ import {
275
+ wss,
276
+ topic,
277
+ getUserAppWithTag,
278
+ getComplexApplications,
279
+ getComplexApplicationsNew
280
+ } from 'eoss-ui/src/config/api.js';
281
+ import store from 'eoss-ui/src/utils/store';
282
+ import util from 'eoss-ui/src/utils/util';
283
+ const isIE = navigator.userAgent.indexOf('MSIE') != -1;
284
+ let events = [
285
+ (tabs, index) => {
286
+ let tab = tabs[index];
287
+
288
+ if (tab.method == 'iframe') {
289
+ tabs[index].url = util.handlerUrl(tab.url);
290
+ } else {
291
+ tabs[index].refresh = false;
292
+ this.$nextTick(() => {
293
+ tabs[index].refresh = true;
294
+ });
295
+ }
296
+ return tabs;
297
+ },
298
+ (tabs, index) => {
299
+ tabs.splice(index, 1);
300
+ return tabs;
301
+ },
302
+ (tabs, index) => {
303
+ return tabs.slice(index, index + 1);
304
+ },
305
+ (tabs, index) => {
306
+ tabs.splice(0, index);
307
+ return tabs;
308
+ },
309
+ (tabs, index) => {
310
+ tabs.slice(index + 1, tabs.length - index);
311
+ return tabs;
312
+ }
313
+ ];
314
+ export default {
315
+ name: 'EsMainSimplicity',
316
+ components: {
317
+ avatar,
318
+ handler,
319
+ subMenu,
320
+ apps,
321
+ user,
322
+ message,
323
+ notice,
324
+ settings
325
+ },
326
+ props: {
327
+ //logo
328
+ logo: String,
329
+ //菜单、应用默认图标
330
+ menuIcon: {
331
+ type: String,
332
+ default: 'es-icon-application'
333
+ },
334
+ //默认主题颜色
335
+ theme: {
336
+ type: String,
337
+ default: '#409eff'
338
+ },
339
+ //主题颜色选择颜色集合
340
+ themes: Array,
341
+ //需要隐藏的头部功能
342
+ hides: [Object, Array],
343
+ //菜单颜色
344
+ menuColor: [String, Array],
345
+ //菜单背景颜色
346
+ menuBackgroundColor: [String, Array],
347
+ //应用颜色
348
+ appColor: [String, Array],
349
+ //应用背景颜色
350
+ appBackgroundColor: [String, Array],
351
+ //默认头像
352
+ userHead: String,
353
+ //应用列表接口
354
+ appsUrl: {
355
+ type: String,
356
+ default: getUserAppWithTag
357
+ },
358
+ //是否启用子应用菜单接口
359
+ application: {
360
+ type: Boolean,
361
+ default: false
362
+ },
363
+ //菜单接口
364
+ menuUrl: String,
365
+ //远程请求菜单
366
+ remote: {
367
+ type: Boolean,
368
+ default: true
369
+ },
370
+ //websocket
371
+ socket: {
372
+ type: Boolean,
373
+ default: true
374
+ },
375
+ //人工智能配置
376
+ ai: Object,
377
+ //iframeId
378
+ iframeId: {
379
+ type: String,
380
+ default: 'stage'
381
+ },
382
+ //查看在线人数
383
+ onlineView: {
384
+ type: [String, Boolean],
385
+ default: true
386
+ },
387
+ //消息办理是否采用window.open的方式打开
388
+ winopen: {
389
+ type: Boolean,
390
+ default: true
391
+ },
392
+ //是否采用wujie微前端加载页面
393
+ loadWujie: {
394
+ type: Boolean,
395
+ default: true
396
+ },
397
+ //无界微前端Props属性
398
+ wjProps: Object,
399
+ //无界微前端Attrs属性
400
+ wjAttrs: Object
401
+ },
402
+ data() {
403
+ return {
404
+ //主题色
405
+ themeColor: this.theme,
406
+ //是否ie浏览器
407
+ isIE: isIE,
408
+ //logo
409
+ mainLogo: this.logo,
410
+ //侧边用户应用
411
+ userApps: [],
412
+ //所有菜单
413
+ menus: [],
414
+ //子菜单
415
+ subMenus: [],
416
+ //展示菜单导航
417
+ showMenu: false,
418
+ //展示菜单导航宽度
419
+ width: '296px',
420
+ //人工智能配置
421
+ aiConfig: null,
422
+ //展示人工智能界面
423
+ showAi: false,
424
+ //所有应用
425
+ applications: [],
426
+ //业务系统
427
+ business: [],
428
+ //系统管理
429
+ systems: [],
430
+ //气泡数
431
+ menuTips: {},
432
+ //展示所有应用
433
+ showApps: false,
434
+ //用户信息
435
+ userModel: {},
436
+ //通知类型列表
437
+ notifyList: [],
438
+ //用户样式
439
+ userStyle: {},
440
+ //通知类型
441
+ notify: '',
442
+ //用户信息表单结构
443
+ userInfoContents: undefined,
444
+ //窗口页签
445
+ tabs: [],
446
+ //页签选中name
447
+ activeName: '',
448
+ //初始应用菜单页
449
+ initApps: null,
450
+ //首页地址
451
+ indexUrl: '',
452
+ //弹窗
453
+ dialog: {},
454
+ //消息列表展示状态
455
+ showMsg: false,
456
+ notice: 0,
457
+ //即时消息
458
+ sysMsg: [],
459
+ //定时关闭及时消息对象
460
+ sysMsgOut: null,
461
+ //额外信息数据
462
+ extraData: '',
463
+ //显示设置面板
464
+ showSet: false,
465
+ //窗口是否可选
466
+ isDisabled: {},
467
+ //显示页签操作
468
+ showTabsHandler: false,
469
+ //页签对象
470
+ pane: null
471
+ };
472
+ },
473
+ computed: {
474
+ //菜单接口
475
+ _menuUrl() {
476
+ if (this.menuUrl) {
477
+ return this.menuUrl;
478
+ }
479
+ if (this.application) {
480
+ return getComplexApplicationsNew;
481
+ }
482
+ return getComplexApplications;
483
+ },
484
+ //人工智能配置
485
+ _aiConfig() {
486
+ return this.aiConfig || this.ai
487
+ ? {
488
+ icon: '',
489
+ ...(this.aiConfig || this.ai)
490
+ }
491
+ : false;
492
+ },
493
+ //人工智能图片背景
494
+ _aibackground() {
495
+ return this._aiConfig && (this._aiConfig.image || this._aiConfig.icon)
496
+ ? {
497
+ 'background-image': `url(${
498
+ this._aiConfig.image || this._aiConfig.icon
499
+ })`
500
+ }
501
+ : {};
502
+ },
503
+ //用户信息
504
+ user() {
505
+ return this.userModel ? this.userModel : store.get('userModel');
506
+ },
507
+ //在线人数列表地址
508
+ onlineUrl() {
509
+ if (this.onlineView) {
510
+ return typeof this.onlineView == 'string'
511
+ ? this.onlineView
512
+ : '/main/sysuseronline/list.dhtml';
513
+ }
514
+ return false;
515
+ }
516
+ },
517
+ watch: {
518
+ menuTips: {
519
+ deep: true,
520
+ handler() {
521
+ this.setTips(this.userApps);
522
+ this.setTips(this.applications);
523
+ this.setTips(this.business);
524
+ this.setTips(this.systems);
525
+ this.setTips(this.menus);
526
+ }
527
+ }
528
+ },
529
+ created() {
530
+ let mainConfig = util.getStorage('mainConfig');
531
+ if (mainConfig) {
532
+ const results = JSON.parse(mainConfig);
533
+ this.init(results);
534
+ }
535
+ },
536
+ mounted() {
537
+ util.win.reLogin = this.handleReLogin;
538
+ util.win.refresh = this.handleRefresh;
539
+ util.win.jumpMenu = this.jumpMenu;
540
+ util.win.windowOpen = this.openPage;
541
+ },
542
+ methods: {
543
+ /**
544
+ * @desc:匹配路由
545
+ * @author huangbo
546
+ * @date 2024年9月7日
547
+ **/
548
+ hasRouter(res, url, code, parentName) {
549
+ if (!url) {
550
+ return false;
551
+ }
552
+ if (Array.isArray(res)) {
553
+ for (let i in res) {
554
+ let path = this.hasRouter(res[i], url, code, parentName);
555
+ if (path) {
556
+ return path;
557
+ }
558
+ }
559
+ } else {
560
+ let path = res.path;
561
+ if (path !== '/' && path !== '/404') {
562
+ path = path.replace(path[1], path[1].toLowerCase());
563
+ }
564
+ let pathname = url.substring(url.indexOf('#/') + 1);
565
+ pathname = pathname
566
+ .replace(pathname[1], pathname[1].toLowerCase())
567
+ .split('?')[0];
568
+ if (res.path !== '/' && pathname == path) {
569
+ if (typeof res.component === 'function') {
570
+ let component = {};
571
+ component[code] = res.component;
572
+ res.component = component;
573
+ if (parentName) {
574
+ this.$router.addRoute({ parentName, route: res });
575
+ } else {
576
+ this.$router.addRoute(res);
577
+ }
578
+ }
579
+ return pathname;
580
+ }
581
+ if (res && Object.prototype.hasOwnProperty.call(res, 'children')) {
582
+ let path = this.hasRouter(res.children, url, code, parentName);
583
+ if (path) {
584
+ return path;
585
+ }
586
+ }
587
+ }
588
+ return false;
589
+ },
590
+ /**
591
+ * @desc:获取初始数据
592
+ * @author huangbo
593
+ * @date 2024年9月7日
594
+ **/
595
+ init(results) {
596
+ this.setConfig(results);
597
+ if (this.remote) {
598
+ this.getApplications();
599
+ this.getMenus();
600
+ }
601
+ },
602
+ /**
603
+ * @desc:设置用户配置及信息
604
+ * @author huangbo
605
+ * @date 2024年9月7日
606
+ **/
607
+ setConfig(results) {
608
+ if (this.socket) {
609
+ this.initWebSocket();
610
+ }
611
+ sessionStorage.setItem('mainConfig', JSON.stringify(results));
612
+ util.setStorage({
613
+ type: this.storage,
614
+ key: {
615
+ userId: results.userModel.userId,
616
+ userName: results.userModel.username,
617
+ useCaseCodes: results.resourceCodes || results.userModel.resourceCodes
618
+ }
619
+ });
620
+ for (let i in results) {
621
+ if (i === 'mainLogoUrl' && results[i]) {
622
+ this.mainLogo = results[i];
623
+ }
624
+ if (
625
+ i === 'mainBannerUrl' &&
626
+ results[i] &&
627
+ this.headerImage === undefined
628
+ ) {
629
+ this.headerImg = results[i];
630
+ }
631
+ if (i === 'initApplication' && results[i]) {
632
+ this.initApps = results[i].split(',');
633
+ }
634
+ if (i === 'indexUrl' && results[i]) {
635
+ this.indexUrl = results[i];
636
+ }
637
+ if (i === 'doorIndex' && results[i]) {
638
+ util.win.open(results[i]);
639
+ }
640
+ if (i === 'subsystemName' && results[i]) {
641
+ document.title = results[i];
642
+ }
643
+ if (i === 'loginPage' && results[i]) {
644
+ util.setStorage('loginPage', results[i]);
645
+ }
646
+ if (i === 'sysLogoIco' && results[i]) {
647
+ sessionStorage.setItem('sysLogoIco', results[i]);
648
+ util.setFavicon(results[i]);
649
+ }
650
+ if (i === 'userStyle' && results[i]) {
651
+ if (results[i].color) {
652
+ let color = unescape(results[i].color).toLowerCase();
653
+ if (util.startWith(color, '#')) {
654
+ this.themeColor = color;
655
+ }
656
+ }
657
+ this.userStyle = results[i];
658
+ this.notify = results[i].notify || '';
659
+ }
660
+ if (i === 'subsystemExtend' && results[i]) {
661
+ if (results[i].themeColor) {
662
+ let color = unescape(results[i].themeColor).toLowerCase();
663
+ if (util.startWith(color, '#')) {
664
+ this.themeColor = color;
665
+ }
666
+ }
667
+ if (results[i].userInfoContents) {
668
+ this.userInfoContents = results[i].userInfoContents;
669
+ }
670
+ if (results[i].webPageWatermark) {
671
+ try {
672
+ util.win.top.webPageWatermark = results[i].webPageWatermark;
673
+ util.watermark(results[i].webPageWatermark);
674
+ } catch (error) {
675
+ util.win.postMessage(
676
+ { type: 2, content: results[i].webPageWatermark },
677
+ '*'
678
+ );
679
+ }
680
+ }
681
+ if (results[i].loginPage) {
682
+ util.setStorage('loginPage', results[i].loginPage);
683
+ }
684
+ if (results[i].aiConfig) {
685
+ if (typeof results[i].aiConfig == 'string') {
686
+ try {
687
+ this.aiConfig = JSON.parse(results[i].aiConfig);
688
+ } catch (error) {
689
+ this.aiConfig = { url: results[i].aiConfig };
690
+ }
691
+ } else {
692
+ this.aiConfig = results[i].aiConfig;
693
+ }
694
+ }
695
+ }
696
+ if (i === 'userModel' && results[i]) {
697
+ if (results[i].userHeadUrl) {
698
+ results[i].userHeadUrl = util.jointUrl({
699
+ url: results[i].userHeadUrl,
700
+ reg: '/main2'
701
+ });
702
+ } else {
703
+ results[i].userHeadUrl = this.userHead;
704
+ }
705
+ this.userModel = results[i];
706
+ }
707
+ if (i === 'notifyList' && results[i]) {
708
+ this.notifyList = results[i];
709
+ }
710
+ store.set(i, results[i]);
711
+ }
712
+ },
713
+ /**
714
+ * @desc:获取所有应用
715
+ * @author huangbo
716
+ * @date 2024年9月7日
717
+ **/
718
+ getApplications() {
719
+ util
720
+ .ajax({
721
+ url: this.appsUrl,
722
+ defaults: true
723
+ })
724
+ .then((res) => {
725
+ if (res.rCode === 0) {
726
+ if (res.results && Object.keys(res.results).length) {
727
+ let { all, app_special_business_system, app_system, app_user } =
728
+ res.results;
729
+ this.userApps = app_user.filter((item) => {
730
+ return item.permission !== false;
731
+ });
732
+ this.applications = all;
733
+ this.business = app_special_business_system;
734
+ this.systems = app_system;
735
+ this.setTips(this.userApps);
736
+ this.setTips(this.applications);
737
+ this.setTips(this.business);
738
+ this.setTips(this.systems);
739
+ } else {
740
+ this.$message.error('未分配应用菜单权限,请联系管理员!');
741
+ }
742
+ } else {
743
+ let msg = res.msg || '系统错误,请联系管理员!';
744
+ this.$message.error(msg);
745
+ }
746
+ })
747
+ .catch((err) => {
748
+ if (err.message && err.message !== 'canceled') {
749
+ this.$message.error(err.message);
750
+ }
751
+ });
752
+ },
753
+ /**
754
+ * @desc:获取菜单列表
755
+ * @author huangbo
756
+ * @date 2024年9月7日
757
+ **/
758
+ getMenus(appCode, url) {
759
+ let params = appCode ? { menuCode: appCode } : {};
760
+ util
761
+ .ajax({ url: url || this._menuUrl, params: params })
762
+ .then((res) => {
763
+ if (res.rCode === 0) {
764
+ if (res.results && res.results.length) {
765
+ this.menus = res.results;
766
+ this.setTips(this.menus);
767
+ store.set('nav', this.menus);
768
+ if (this.indexUrl) {
769
+ let obj = this.getMenu(this.menus, this.indexUrl);
770
+ if (obj) {
771
+ this.tabs = [this.setIframeType(obj)];
772
+ this.activeName = obj.id;
773
+ } else {
774
+ this.tabs = [
775
+ this.setIframeType({
776
+ url: this.indexUrl,
777
+ text: '工作台',
778
+ id: '0',
779
+ appCode: 'indexUrl'
780
+ })
781
+ ];
782
+ this.activeName = '0';
783
+ }
784
+ }
785
+ if (this.initApps && this.initApps.length) {
786
+ let obj = this.getMenu(
787
+ this.menus,
788
+ this.initApps[this.initApps.length - 1]
789
+ );
790
+ if (obj) {
791
+ this.tabs.push(this.setIframeType(obj));
792
+ this.activeName = obj.id;
793
+ }
794
+ }
795
+ } else {
796
+ this.$message.error('未分配菜单权限,请联系管理员!');
797
+ }
798
+ } else {
799
+ let msg = res.msg || '系统错误,请联系管理员!';
800
+ this.$message.error(msg);
801
+ }
802
+ })
803
+ .catch((err) => {
804
+ if (err.message && err.message !== 'canceled') {
805
+ this.$message.error(err.message);
806
+ }
807
+ });
808
+ },
809
+ setIframeType(res) {
810
+ let { url } = res;
811
+ let urls = url.split('?');
812
+ if (urls[0].indexOf('.js') > 1 && !isIE) {
813
+ res.method = 'wujie';
814
+ this.$nextTick(() => {
815
+ res.refresh = true;
816
+ });
817
+ } else if (
818
+ urls[0].indexOf('.dhtml') > 0 ||
819
+ (urls[0].indexOf('.html') > 0 && urls[0].indexOf('.html#') === -1)
820
+ ) {
821
+ res.method = 'iframe';
822
+ } else {
823
+ if (urls[0].indexOf('.html') === -1 && urls[0].indexOf('#/') === -1) {
824
+ res.method = 'iframe';
825
+ } else {
826
+ const routes = this.$router.options.routes;
827
+ if (routes) {
828
+ let path = this.hasRouter(routes, urls[0], res.appCode);
829
+ if (path) {
830
+ let params = util.getParams({ url: url });
831
+ this.$router.push({
832
+ path: path,
833
+ query: params
834
+ });
835
+ this.$nextTick(() => {
836
+ res.refresh = true;
837
+ });
838
+ } else {
839
+ let urlopenmode = util.getParams({
840
+ url: url,
841
+ name: 'urlopenmode'
842
+ });
843
+ if (
844
+ this.loadWujie === false ||
845
+ isIE ||
846
+ res.urlopenmode == 3 ||
847
+ urlopenmode == 3
848
+ ) {
849
+ res.method = 'iframe';
850
+ } else {
851
+ res.method = 'wujie';
852
+ this.$nextTick(() => {
853
+ res.refresh = true;
854
+ });
855
+ }
856
+ }
857
+ } else if (
858
+ (urls[0].indexOf('.html') > -1 && urls[0].indexOf('#/') > -1) ||
859
+ urls[0].indexOf('/#/') > -1
860
+ ) {
861
+ res.method = 'wujie';
862
+ this.$nextTick(() => {
863
+ res.refresh = true;
864
+ });
865
+ } else {
866
+ res.method = 'iframe';
867
+ }
868
+ }
869
+ }
870
+ return res;
871
+ },
872
+ /**
873
+ * @desc:获取菜单
874
+ * @author huangbo
875
+ * @date 2024年9月7日
876
+ **/
877
+ getMenu(menus, res, key) {
878
+ if (Array.isArray(menus)) {
879
+ for (let i = 0; i < menus.length; i++) {
880
+ let item = menus[i];
881
+ if (key && item[key] === res) {
882
+ return item;
883
+ }
884
+ if (item.url === res || item.id === res) {
885
+ return item;
886
+ }
887
+ if (
888
+ Object.prototype.hasOwnProperty.call(item, 'children') &&
889
+ item.children.length
890
+ ) {
891
+ let obj = this.getMenu(item.children, res, key);
892
+ if (obj) {
893
+ return obj;
894
+ }
895
+ } else if (
896
+ Object.prototype.hasOwnProperty.call(item, 'fourthTabs') &&
897
+ item.fourthTabs.length
898
+ ) {
899
+ let obj = this.getMenu(item.fourthTabs, res, key);
900
+ if (obj) {
901
+ return obj;
902
+ }
903
+ }
904
+ }
905
+ }
906
+ return false;
907
+ },
908
+ /**
909
+ * @desc:遍历设置菜单气泡提醒
910
+ * @author huangbo
911
+ * @date 2024年9月7日
912
+ **/
913
+ setTips(obj) {
914
+ if (Array.isArray(obj)) {
915
+ obj.forEach((item) => {
916
+ this.setTips(item);
917
+ });
918
+ } else {
919
+ if (
920
+ obj &&
921
+ Object.prototype.hasOwnProperty.call(obj, 'tips') &&
922
+ obj.tips
923
+ ) {
924
+ this.$set(obj, 'tips', false);
925
+ delete obj.tips;
926
+ }
927
+ let flag = false;
928
+ if (obj.children && obj.children.length) {
929
+ obj.children.forEach((item) => {
930
+ if (this.setTips(item)) {
931
+ flag = true;
932
+ }
933
+ });
934
+ if (flag) {
935
+ this.$set(obj, 'tips', true);
936
+ return true;
937
+ }
938
+ } else if (obj.fourthTabs && obj.fourthTabs.length) {
939
+ obj.fourthTabs.forEach((item) => {
940
+ if (this.setTips(item)) {
941
+ flag = true;
942
+ }
943
+ });
944
+ if (flag) {
945
+ this.$set(obj, 'tips', true);
946
+ return true;
947
+ }
948
+ } else {
949
+ if (this.menuTips[obj.id] && Number(this.menuTips[obj.id])) {
950
+ this.$set(obj, 'tips', Number(this.menuTips[obj.id]));
951
+ return true;
952
+ }
953
+ }
954
+ }
955
+ return false;
956
+ },
957
+ /**
958
+ * @desc:获取气泡提醒
959
+ * @author huangbo
960
+ * @date 2024年9月7日
961
+ **/
962
+ getBadge(res) {
963
+ let num = res.tips || 0;
964
+ return num === true
965
+ ? {
966
+ isDot: true
967
+ //hidden: item.tips
968
+ }
969
+ : {
970
+ value: num,
971
+ max: 99,
972
+ hidden: !num
973
+ };
974
+ },
975
+ /**
976
+ * @desc:开启weosocket
977
+ * @author huangbo
978
+ * @date 2024年9月7日
979
+ **/
980
+ initWebSocket() {
981
+ this.webSocket = util.socket({
982
+ url: wss,
983
+ take: topic,
984
+ success: (res) => {
985
+ let data = res.data || {};
986
+ for (let i in data) {
987
+ if (data[i] !== null && data[i] !== undefined) {
988
+ if (i === 'onlineUserNums' && data[i] > 0) {
989
+ this.online = data[i];
990
+ }
991
+ if (i === 'sysMsgNums') {
992
+ this.notice = data[i];
993
+ if (this.showMsg) {
994
+ this.$refs.message.getMsg(true);
995
+ }
996
+ }
997
+ if (i === 'menuTipsMap') {
998
+ this.menuTips = data[i];
999
+ }
1000
+ if (i === 'sysMsgList') {
1001
+ this.sysMsg = data[i];
1002
+ }
1003
+ if (i === 'extraData') {
1004
+ this.extraData = data[i];
1005
+ }
1006
+ }
1007
+ }
1008
+ if (this.$store) {
1009
+ try {
1010
+ this.$store.commit('websocket', data);
1011
+ } catch (error) {}
1012
+ }
1013
+ if (this.$eventBus) {
1014
+ this.$eventBus.$emit('websocket', data);
1015
+ }
1016
+ if (util.win.eventBus) {
1017
+ util.win.eventBus.$emit('websocket', data);
1018
+ }
1019
+ }
1020
+ });
1021
+ },
1022
+ /**
1023
+ * @desc:侧边应用菜单点击
1024
+ * @author huangbo
1025
+ * @date 2024年9月7日
1026
+ **/
1027
+ handlerClickApp(res) {
1028
+ if (res) {
1029
+ if (res.permission === false) {
1030
+ return false;
1031
+ }
1032
+ if (
1033
+ (res.children && res.children.length) ||
1034
+ (res.fourthTabs && res.fourthTabs.length)
1035
+ ) {
1036
+ this.subMenus = res;
1037
+ this.showMenu = true;
1038
+ this.showApps = false;
1039
+ } else {
1040
+ if (res.code) {
1041
+ this.subMenus = this.getMenu(this.menus, res.code, 'appCode');
1042
+ this.showMenu = true;
1043
+ this.showApps = false;
1044
+ }
1045
+ }
1046
+ if (res.url) {
1047
+ if (res.urlopenmode == 1 || res.openModel == 1) {
1048
+ util.win.open(res.url);
1049
+ } else if (res.urlopenmode == 2 || res.openModel == 2) {
1050
+ util.win.location.href = res.url;
1051
+ } else {
1052
+ let i = util.indexOfObj(this.tabs, res, 'id');
1053
+ this.activeName = res.id;
1054
+ if (i == -1) {
1055
+ this.tabs.push(this.setIframeType(res));
1056
+ }
1057
+ }
1058
+ } else {
1059
+ }
1060
+ } else {
1061
+ this.showApps = !this.showApps;
1062
+ }
1063
+ },
1064
+ /**
1065
+ * @desc:显示人工智能界面
1066
+ * @author huangbo
1067
+ * @date 2024年9月7日
1068
+ **/
1069
+ handlerClickAi() {
1070
+ this.showAi = !this.showAi;
1071
+ },
1072
+ /**
1073
+ * @desc:菜单点击
1074
+ * @author huangbo
1075
+ * @date 2024年9月7日
1076
+ **/
1077
+ handlerClickMenu(res) {
1078
+ if (typeof res === 'number') {
1079
+ let num = 296;
1080
+ this.width = num * res + 'px';
1081
+ } else {
1082
+ let i = util.indexOfObj(this.tabs, res, 'id');
1083
+ this.activeName = res.id;
1084
+ if (i == -1) {
1085
+ this.tabs.push(this.setIframeType(res));
1086
+ }
1087
+ }
1088
+ },
1089
+ /**
1090
+ * @desc:修改用户配置
1091
+ * @author huangbo
1092
+ * @date 2024年9月7日
1093
+ **/
1094
+ handleChangeConfig(name, res) {
1095
+ if (name == 'userHeadUrl') {
1096
+ this.$set(this.userModel, 'userHeadUrl', res);
1097
+ store.set('userModel', this.userModel);
1098
+ let mainConfig = JSON.parse(sessionStorage.getItem('mainConfig'));
1099
+ sessionStorage.setItem(
1100
+ 'mainConfig',
1101
+ JSON.stringify({ ...mainConfig, userModel: this.userModel })
1102
+ );
1103
+ } else {
1104
+ this.$set(this.userStyle, 'notify', res);
1105
+ store.set('userStyle', this.userStyle);
1106
+ let mainConfig = JSON.parse(sessionStorage.getItem('mainConfig'));
1107
+ sessionStorage.setItem(
1108
+ 'mainConfig',
1109
+ JSON.stringify({ ...mainConfig, userStyle: this.userStyle })
1110
+ );
1111
+ }
1112
+ },
1113
+ /**
1114
+ * @desc:关闭webSocket
1115
+ * @author huangbo
1116
+ * @date 2024年9月7日
1117
+ **/
1118
+ handlerClose() {
1119
+ if (this.webSocket) {
1120
+ this.webSocket.destroy();
1121
+ }
1122
+ },
1123
+ /**
1124
+ * @desc:选中iframe页签刷新
1125
+ * @author huangbo
1126
+ * @date 2024年9月7日
1127
+ **/
1128
+ handleTab(res) {
1129
+ let index;
1130
+ if (res) {
1131
+ index = parseInt(res.index);
1132
+ } else {
1133
+ index = util.indexOfObj(this.tabs, this.activeName, 'id');
1134
+ }
1135
+ let item = this.tabs[index];
1136
+ if (item.method == 'iframe') {
1137
+ item.url = util.handlerUrl(item.url);
1138
+ } else {
1139
+ item.refresh = false;
1140
+ this.$nextTick(() => {
1141
+ item.refresh = true;
1142
+ });
1143
+ }
1144
+ },
1145
+ /**
1146
+ * @desc:刷新选中iframe页签
1147
+ * @author huangbo
1148
+ * @date 2024年9月7日
1149
+ **/
1150
+ handleRefresh() {
1151
+ this.handleTab();
1152
+ },
1153
+ /**
1154
+ * @desc:删除iframe
1155
+ * @author huangbo
1156
+ * @date 2024年9月7日
1157
+ **/
1158
+ handleRemove(name) {
1159
+ let i = util.indexOfObj(this.tabs, name, 'id');
1160
+ if (i > -1) {
1161
+ this.tabs.splice(i, 1);
1162
+ }
1163
+ },
1164
+ /**
1165
+ * @desc:tabs鼠标右键事件
1166
+ * @author huangbo
1167
+ * @date 2024年9月7日
1168
+ **/
1169
+ handleContextmenu(tabs, e) {
1170
+ let disabled = {};
1171
+ let index = parseInt(tabs.index, 10);
1172
+ if (index == 0) {
1173
+ disabled.left = true;
1174
+ }
1175
+ if (index == this.tabs.length - 1) {
1176
+ disabled.right = true;
1177
+ }
1178
+ if (this.tabs.length == 1) {
1179
+ disabled.other = true;
1180
+ }
1181
+ this.isDisabled = disabled;
1182
+ this.$refs.tabsHandler.$el.style.setProperty('left', `${e.x}px`);
1183
+ this.$refs.tabsHandler.$el.style.setProperty('top', `${e.y}px`);
1184
+ this.showTabsHandler = true;
1185
+ this.pane = index;
1186
+ window.addEventListener('click', this.closeTabsEvents);
1187
+ },
1188
+ /**
1189
+ * @desc:tabs页签事件
1190
+ * @author huangbo
1191
+ * @date 2024年9月7日
1192
+ **/
1193
+ handleTabsEvents(num) {
1194
+ if (this.pane !== null) {
1195
+ this.tabs = events[num](this.tabs, this.pane);
1196
+ }
1197
+ this.showTabsHandler = false;
1198
+ window.removeEventListener('click', this.closeTabsEvents);
1199
+ },
1200
+ //关闭页签事件面板
1201
+ closeTabsEvents(e) {
1202
+ if (
1203
+ e.target.parentNode != this.$refs.tabsHandler.$el &&
1204
+ e.target.parentNode.parentNode != this.$refs.tabsHandler.$el
1205
+ ) {
1206
+ this.showTabsHandler = false;
1207
+ }
1208
+ window.removeEventListener('click', this.closeTabsEvents);
1209
+ },
1210
+ /**
1211
+ * @desc:handler工具栏点击事件
1212
+ * @author huangbo
1213
+ * @date 2024年9月7日
1214
+ **/
1215
+ handleClick(res) {
1216
+ const { type, event, open, link } = res;
1217
+ if (event) {
1218
+ event();
1219
+ } else if (open) {
1220
+ util.win.open(open);
1221
+ } else if (link) {
1222
+ util.win.location.href = link;
1223
+ } else {
1224
+ switch (type) {
1225
+ case 'quit':
1226
+ this.handleQuit();
1227
+ break;
1228
+ case 'online':
1229
+ if (this.onlineUrl) {
1230
+ this.dialog = {
1231
+ title: '查看在线人员',
1232
+ show: true,
1233
+ src: this.onlineUrl
1234
+ };
1235
+ }
1236
+ break;
1237
+ case 'notice':
1238
+ this.showMsg = !this.showMsg;
1239
+ break;
1240
+ case 'set':
1241
+ this.showSet = !this.showSet;
1242
+ break;
1243
+ case 'goView':
1244
+ util.win.open(res.path, '_blank');
1245
+ break;
1246
+ }
1247
+ }
1248
+ this.$emit('handler-click', res);
1249
+ },
1250
+ /**
1251
+ * @desc:退出登录
1252
+ * @author huangbo
1253
+ * @date 2024年9月7日
1254
+ **/
1255
+ handleQuit() {
1256
+ this.$confirm('确定注销吗?', '退出系统', {
1257
+ confirmButtonText: '确定',
1258
+ cancelButtonText: '取消',
1259
+ type: 'warning'
1260
+ })
1261
+ .then(() => {
1262
+ util
1263
+ .ajax({ method: 'post', url: logout })
1264
+ .then((res) => {
1265
+ if (res.rCode == 0) {
1266
+ util.removeStorage([
1267
+ 'Authorization',
1268
+ 'token',
1269
+ 'ssId',
1270
+ 'userId',
1271
+ 'userName',
1272
+ 'auth',
1273
+ 'deviceUnique',
1274
+ 'menus',
1275
+ 'useCaseCodes',
1276
+ 'mainConfig',
1277
+ 'jump'
1278
+ ]);
1279
+ if (this.onQuit && typeof this.onQuit === 'function') {
1280
+ this.onQuit();
1281
+ } else {
1282
+ try {
1283
+ const loginPage =
1284
+ util.getStorage('login') || util.getStorage('loginPage');
1285
+ if (loginPage) {
1286
+ let src;
1287
+ if (!util.startWith(loginPage, ['http', '/'], true)) {
1288
+ let pathname = util.win.top.location.pathname;
1289
+ if (pathname !== '/') {
1290
+ pathname = pathname.split('/');
1291
+ pathname.splice(pathname.length - 1);
1292
+ pathname = pathname.join('/');
1293
+ src = pathname + '/' + loginPage.replace('./', '');
1294
+ } else {
1295
+ src = pathname + loginPage.replace('./', '');
1296
+ }
1297
+ } else {
1298
+ src = loginPage;
1299
+ }
1300
+ util.win.top.location.href = src;
1301
+ } else if (
1302
+ util.win.top.location.href.indexOf('main.html') > -1
1303
+ ) {
1304
+ util.win.top.location.href = './login.html';
1305
+ } else {
1306
+ const hash = util.win.top.location.hash;
1307
+ if (hash) {
1308
+ const len = util.win.top.location.href.indexOf(hash);
1309
+ util.win.top.location.href =
1310
+ util.win.location.href.slice(0, len) + '#/login';
1311
+ } else {
1312
+ util.win.top.location.href = '/login.html';
1313
+ }
1314
+ }
1315
+ } catch (error) {
1316
+ util.win.postMessage({ type: 1 }, '*');
1317
+ }
1318
+ }
1319
+ }
1320
+ })
1321
+ .catch((err) => {
1322
+ if (err.message && err.message !== 'canceled') {
1323
+ this.$message.error(err.message);
1324
+ }
1325
+ });
1326
+ })
1327
+ .catch((e) => {});
1328
+ },
1329
+ /**
1330
+ * @desc:主题、消息回调
1331
+ * @author huangbo
1332
+ * @date 2024年9月7日
1333
+ **/
1334
+ handleChange(res) {
1335
+ const { type, value } = res;
1336
+ switch (type) {
1337
+ case 'theme':
1338
+ this.setTheme(value);
1339
+ break;
1340
+ case 'ignore':
1341
+ this.notice = 0;
1342
+ break;
1343
+ }
1344
+ },
1345
+ /**
1346
+ * @desc:消息修改总数
1347
+ * @author huangbo
1348
+ * @date 2024年9月7日
1349
+ **/
1350
+ handleMenuTips(id, num) {
1351
+ if (num) {
1352
+ this.$set(this.menuTips, id, num);
1353
+ } else {
1354
+ let n = parseInt(this.menuTips[id], 10) - 1;
1355
+ this.$set(this.menuTips, id, n);
1356
+ }
1357
+ },
1358
+ /**
1359
+ * @desc:处理即时消息
1360
+ * @author huangbo
1361
+ * @date 2024年9月7日
1362
+ **/
1363
+ handleOpened(res) {
1364
+ if (res === undefined) {
1365
+ this.sysMsg = [];
1366
+ } else if (res == false && this.sysMsg.length) {
1367
+ this.sysMsgOut = setTimeout(() => {
1368
+ this.sysMsg = [];
1369
+ }, 3000);
1370
+ } else if (this.sysMsgOut) {
1371
+ clearTimeout(this.sysMsgOut);
1372
+ }
1373
+ },
1374
+ handleReLogin(res) {
1375
+ if (res && typeof res == 'string') {
1376
+ res = JSON.parse(res);
1377
+ }
1378
+ let msg = '提示';
1379
+ let btn = {
1380
+ confirmButtonText: '确定',
1381
+ cancelButtonText: '取消',
1382
+ closeOnClickModal: false,
1383
+ type: 'warning'
1384
+ };
1385
+ if (res) {
1386
+ if (res.rCode === 69) {
1387
+ msg = '该账号在其他地方已登陆!';
1388
+ btn = {
1389
+ confirmButtonText: '确定',
1390
+ closeOnClickModal: false,
1391
+ type: 'warning'
1392
+ };
1393
+ } else {
1394
+ msg = '登录已过期,请重新登录!';
1395
+ }
1396
+ }
1397
+ cl;
1398
+ let remind = sessionStorage.getItem('remind');
1399
+ if (!remind) {
1400
+ clearTimeout(this.timer);
1401
+ this.timer = setTimeout(() => {
1402
+ sessionStorage.setItem('remind', 1);
1403
+ this.$confirm(msg, btn)
1404
+ .then(() => {
1405
+ util.removeStorage([
1406
+ 'Authorization',
1407
+ 'token',
1408
+ 'ssId',
1409
+ 'userId',
1410
+ 'userName',
1411
+ 'auth',
1412
+ 'deviceUnique',
1413
+ 'menus',
1414
+ 'useCaseCodes',
1415
+ 'mainConfig',
1416
+ 'jump'
1417
+ ]);
1418
+ const loginPage =
1419
+ util.getStorage('login') || util.getStorage('loginPage');
1420
+ try {
1421
+ if (loginPage) {
1422
+ let src;
1423
+ if (!util.startWith(loginPage, ['http', '/'], true)) {
1424
+ let pathname = util.win.top.location.pathname;
1425
+ if (pathname !== '/') {
1426
+ pathname = pathname.split('/');
1427
+ pathname.splice(pathname.length - 1);
1428
+ pathname = pathname.join('/');
1429
+ src = pathname + '/' + loginPage.replace('./', '');
1430
+ } else {
1431
+ src = pathname + loginPage.replace('./', '');
1432
+ }
1433
+ } else {
1434
+ src = loginPage;
1435
+ }
1436
+ util.win.top.location.href = src;
1437
+ } else if (
1438
+ util.win.top.location.href.indexOf('main.html') > -1
1439
+ ) {
1440
+ util.win.top.location.href = './login.html';
1441
+ } else {
1442
+ const hash = util.win.top.location.hash;
1443
+ if (hash) {
1444
+ const len = util.win.top.location.href.indexOf(hash);
1445
+ util.win.top.location.href =
1446
+ util.win.location.href.slice(0, len) + '#/login';
1447
+ } else {
1448
+ util.win.top.location.href = '/login.html';
1449
+ }
1450
+ }
1451
+ } catch (error) {
1452
+ util.win.postMessage({ type: 1 }, '*');
1453
+ }
1454
+ })
1455
+ .catch((e) => {
1456
+ sessionStorage.removeItem('remind');
1457
+ });
1458
+ }, 2000);
1459
+ }
1460
+ },
1461
+ openPage(url, name, width, height) {
1462
+ let src = url;
1463
+ if (!util.startWith(url, ['http', '/'], true)) {
1464
+ let pathname = window.location.pathname;
1465
+ if (pathname !== '/') {
1466
+ pathname = pathname.split('/');
1467
+ pathname.splice(pathname.length - 1);
1468
+ pathname = pathname.join('/');
1469
+ }
1470
+ src = pathname + url.replace('./', '/');
1471
+ }
1472
+ if (name) {
1473
+ let w = 0;
1474
+ let h = 0;
1475
+ try {
1476
+ w = width ? width : util.win.top.screen.availWidth - 10;
1477
+ h = height ? height : util.win.top.screen.availHeight - 60;
1478
+ } catch (error) {
1479
+ w = width ? width : util.win.screen.availWidth - 10;
1480
+ h = height ? height : util.win.screen.availHeight - 60;
1481
+ }
1482
+ return util.win.open(
1483
+ src,
1484
+ name,
1485
+ `width=${w}px,height=${h}px,resizable=yes,status=yes,menubar=no,scrollbars=yes`
1486
+ );
1487
+ } else {
1488
+ return util.win.open(src);
1489
+ }
1490
+ },
1491
+ jumpMenu(res) {
1492
+ let apps = res.split(',');
1493
+ let obj = this.getMenu(this.menus, apps[apps.length - 1]);
1494
+ if (obj) {
1495
+ let i = util.indexOfObj(this.tabs, obj, 'id');
1496
+ if (i == -1) {
1497
+ this.tabs.push(this.setIframeType(obj));
1498
+ }
1499
+ this.activeName = obj.id;
1500
+ } else {
1501
+ this.$message.error('没有此菜单!');
1502
+ }
1503
+ }
1504
+ },
1505
+ beforeDestroy() {
1506
+ clearTimeout(this.timer);
1507
+ this.timer = null;
1508
+ if (this.webSocket) {
1509
+ this.webSocket.destroy();
1510
+ }
1511
+ }
1512
+ };
1513
+ </script>
1514
+
1515
+ <style lang="scss" scoped></style>