eoss-ui 0.7.51 → 0.7.53

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 (322) hide show
  1. package/lib/button-group.js +290 -279
  2. package/lib/button.js +290 -280
  3. package/lib/calendar.js +2 -2
  4. package/lib/calogin.js +523 -512
  5. package/lib/card.js +2 -2
  6. package/lib/cascader.js +2 -2
  7. package/lib/checkbox-group.js +294 -283
  8. package/lib/clients.js +2 -2
  9. package/lib/config/api.js +3 -1
  10. package/lib/data-table-form.js +293 -282
  11. package/lib/data-table.js +292 -281
  12. package/lib/date-picker.js +290 -280
  13. package/lib/dialog.js +293 -282
  14. package/lib/enable-drag.js +2 -2
  15. package/lib/enterprise.js +2 -2
  16. package/lib/eoss-ui.common.js +5515 -5675
  17. package/lib/error-page.js +2 -2
  18. package/lib/flow-group.js +354 -362
  19. package/lib/flow-list.js +435 -412
  20. package/lib/flow.js +608 -599
  21. package/lib/form.js +295 -284
  22. package/lib/handle-user.js +384 -392
  23. package/lib/handler.js +290 -280
  24. package/lib/icon.js +291 -281
  25. package/lib/icons.js +5 -5
  26. package/lib/index.js +1 -1
  27. package/lib/input-number.js +290 -280
  28. package/lib/input.js +294 -284
  29. package/lib/label.js +2 -2
  30. package/lib/layout.js +4 -4
  31. package/lib/login.js +303 -292
  32. package/lib/main.js +466 -455
  33. package/lib/menu.js +4 -4
  34. package/lib/nav.js +292 -282
  35. package/lib/notify.js +74 -71
  36. package/lib/page.js +290 -280
  37. package/lib/pagination.js +290 -280
  38. package/lib/player.js +373 -385
  39. package/lib/qr-code.js +305 -295
  40. package/lib/radio-group.js +301 -291
  41. package/lib/retrial-auth.js +294 -284
  42. package/lib/select-ganged.js +292 -282
  43. package/lib/select.js +299 -289
  44. package/lib/selector-panel.js +295 -284
  45. package/lib/selector.js +292 -282
  46. package/lib/sizer.js +290 -280
  47. package/lib/steps.js +292 -282
  48. package/lib/switch.js +290 -280
  49. package/lib/table-form.js +297 -287
  50. package/lib/tabs-panel.js +2 -2
  51. package/lib/tabs.js +290 -280
  52. package/lib/theme-chalk/base.css +1 -1
  53. package/lib/theme-chalk/data-table.css +1 -1
  54. package/lib/theme-chalk/fonts/iconfont.ttf +0 -0
  55. package/lib/theme-chalk/fonts/iconfont.woff +0 -0
  56. package/lib/theme-chalk/icon.css +1 -1
  57. package/lib/theme-chalk/index.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.css +1 -1
  61. package/lib/theme-chalk/sizer.css +1 -1
  62. package/lib/theme-chalk/upload.css +1 -1
  63. package/lib/tips.js +292 -282
  64. package/lib/toolbar.js +2 -2
  65. package/lib/tree-group.js +290 -280
  66. package/lib/tree.js +292 -282
  67. package/lib/upload.js +304 -293
  68. package/lib/utils/util.js +8 -12
  69. package/lib/wujie.js +290 -280
  70. package/lib/wxlogin.js +290 -280
  71. package/package.json +160 -160
  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/button-group/src/main.vue +346 -346
  76. package/packages/calendar/index.js +5 -5
  77. package/packages/calogin/index.js +5 -5
  78. package/packages/calogin/src/main.vue +412 -412
  79. package/packages/calogin/src/plugin.js +915 -915
  80. package/packages/card/index.js +5 -5
  81. package/packages/card/src/main.vue +156 -156
  82. package/packages/cascader/index.js +5 -5
  83. package/packages/cascader/src/main.vue +168 -168
  84. package/packages/checkbox-group/index.js +5 -5
  85. package/packages/checkbox-group/src/main.vue +333 -333
  86. package/packages/clients/index.js +5 -5
  87. package/packages/clients/src/main.vue +151 -151
  88. package/packages/data-table/index.js +5 -5
  89. package/packages/data-table/src/children.vue +39 -39
  90. package/packages/data-table/src/column.vue +992 -992
  91. package/packages/data-table/src/main.vue +1840 -1840
  92. package/packages/data-table/src/sizer.vue +195 -195
  93. package/packages/data-table-form/index.js +5 -5
  94. package/packages/data-table-form/src/checkbox.vue +101 -101
  95. package/packages/data-table-form/src/colgroup.vue +17 -17
  96. package/packages/data-table-form/src/main.vue +181 -181
  97. package/packages/data-table-form/src/radio.vue +65 -65
  98. package/packages/data-table-form/src/table.vue +233 -233
  99. package/packages/data-table-form/src/tbody.vue +336 -336
  100. package/packages/data-table-form/src/thead.vue +68 -68
  101. package/packages/date-picker/index.js +5 -5
  102. package/packages/date-picker/src/main.vue +236 -236
  103. package/packages/dialog/index.js +5 -5
  104. package/packages/enable-drag/index.js +5 -5
  105. package/packages/enterprise/index.js +5 -5
  106. package/packages/enterprise/src/main.vue +66 -66
  107. package/packages/error-page/index.js +5 -5
  108. package/packages/error-page/src/main.vue +44 -44
  109. package/packages/flow/index.js +5 -5
  110. package/packages/flow/src/component/Circulate.vue +413 -413
  111. package/packages/flow/src/component/CommonOpinions.vue +373 -373
  112. package/packages/flow/src/component/CustomPreset.vue +322 -322
  113. package/packages/flow/src/component/FileList.vue +97 -97
  114. package/packages/flow/src/component/FreeCirculation.vue +240 -240
  115. package/packages/flow/src/component/Preset.vue +255 -255
  116. package/packages/flow/src/component/SendMsg.vue +242 -242
  117. package/packages/flow/src/component/TimeLimit.vue +190 -190
  118. package/packages/flow/src/component/taskUnionExamine.vue +756 -756
  119. package/packages/flow/src/form.vue +121 -121
  120. package/packages/flow/src/freeStartFlow.vue +2846 -2846
  121. package/packages/flow/src/main.vue +3878 -3879
  122. package/packages/flow/src/processForm.vue +1365 -1365
  123. package/packages/flow/src/processReject.vue +309 -309
  124. package/packages/flow/src/reset.vue +942 -942
  125. package/packages/flow/src/startTaskRead.vue +692 -692
  126. package/packages/flow/src/supervise.vue +159 -159
  127. package/packages/flow/src/table.vue +58 -58
  128. package/packages/flow-group/index.js +5 -5
  129. package/packages/flow-group/src/main.vue +717 -717
  130. package/packages/flow-list/index.js +5 -5
  131. package/packages/flow-list/src/main.vue +1801 -1787
  132. package/packages/form/index.js +5 -5
  133. package/packages/form/src/main.vue +3901 -3901
  134. package/packages/form/src/table.vue +1512 -1512
  135. package/packages/handle-user/index.js +5 -5
  136. package/packages/handle-user/src/main.vue +137 -137
  137. package/packages/handler/index.js +5 -5
  138. package/packages/handler/src/main.vue +496 -496
  139. package/packages/icon/index.js +5 -5
  140. package/packages/icon/src/main.vue +104 -104
  141. package/packages/icons/index.js +5 -5
  142. package/packages/icons/src/icon.json +1 -1
  143. package/packages/icons/src/main.vue +81 -81
  144. package/packages/input/index.js +5 -5
  145. package/packages/input/src/main.vue +356 -356
  146. package/packages/input-number/index.js +5 -5
  147. package/packages/input-number/src/main.vue +106 -106
  148. package/packages/label/index.js +5 -5
  149. package/packages/label/src/main.vue +457 -457
  150. package/packages/layout/index.js +5 -5
  151. package/packages/layout/src/item.vue +152 -152
  152. package/packages/layout/src/main.vue +31 -31
  153. package/packages/login/index.js +5 -5
  154. package/packages/login/src/main.vue +2082 -2082
  155. package/packages/login/src/resetPassword.vue +557 -557
  156. package/packages/main/index.js +5 -5
  157. package/packages/main/src/default/message.vue +249 -249
  158. package/packages/main/src/default/notice.vue +157 -157
  159. package/packages/main/src/default/userinfo.vue +503 -503
  160. package/packages/main/src/public/online.vue +89 -89
  161. package/packages/main/src/public/search.vue +464 -464
  162. package/packages/main/src/public/settings.vue +227 -227
  163. package/packages/main/src/simplicity/apps.vue +388 -388
  164. package/packages/main/src/simplicity/avatar.vue +82 -82
  165. package/packages/main/src/simplicity/handler.vue +160 -160
  166. package/packages/main/src/simplicity/index.vue +2277 -2277
  167. package/packages/main/src/simplicity/lists.vue +84 -84
  168. package/packages/main/src/simplicity/menu-list.vue +135 -135
  169. package/packages/main/src/simplicity/message.vue +293 -293
  170. package/packages/main/src/simplicity/notice.vue +222 -222
  171. package/packages/main/src/simplicity/router-page.vue +45 -45
  172. package/packages/main/src/simplicity/sub-menu.vue +274 -274
  173. package/packages/main/src/simplicity/user.vue +259 -259
  174. package/packages/main/src/simplicity/userinfo.vue +401 -401
  175. package/packages/menu/index.js +5 -5
  176. package/packages/menu/src/main.vue +595 -595
  177. package/packages/nav/index.js +5 -5
  178. package/packages/nav/src/main.vue +351 -351
  179. package/packages/notify/index.js +5 -5
  180. package/packages/notify/src/main.vue +538 -538
  181. package/packages/page/index.js +5 -5
  182. package/packages/page/src/main.vue +167 -167
  183. package/packages/pagination/index.js +5 -5
  184. package/packages/pagination/src/main.vue +96 -96
  185. package/packages/player/index.js +5 -5
  186. package/packages/player/src/main.vue +194 -194
  187. package/packages/qr-code/index.js +5 -5
  188. package/packages/qr-code/src/main.vue +170 -170
  189. package/packages/radio-group/index.js +6 -6
  190. package/packages/radio-group/src/main.vue +319 -319
  191. package/packages/retrial-auth/index.js +5 -5
  192. package/packages/retrial-auth/src/main.vue +280 -280
  193. package/packages/select/index.js +5 -5
  194. package/packages/select/src/main.vue +782 -782
  195. package/packages/select-ganged/index.js +5 -5
  196. package/packages/select-ganged/src/main.vue +724 -724
  197. package/packages/selector/index.js +5 -5
  198. package/packages/selector/src/main.vue +761 -761
  199. package/packages/selector-panel/index.js +5 -5
  200. package/packages/selector-panel/src/main.vue +1027 -1027
  201. package/packages/selector-panel/src/selection.vue +170 -170
  202. package/packages/selector-panel/src/tree.vue +129 -129
  203. package/packages/sizer/index.js +5 -5
  204. package/packages/sizer/src/main.vue +254 -254
  205. package/packages/steps/index.js +5 -5
  206. package/packages/steps/src/main.vue +181 -181
  207. package/packages/switch/index.js +5 -5
  208. package/packages/switch/src/main.vue +170 -170
  209. package/packages/table-form/index.js +5 -5
  210. package/packages/tabs/index.js +5 -5
  211. package/packages/tabs/src/main.vue +788 -788
  212. package/packages/tabs-panel/index.js +5 -5
  213. package/packages/tabs-panel/src/main.vue +29 -29
  214. package/packages/theme-chalk/lib/base.css +1 -1
  215. package/packages/theme-chalk/lib/data-table.css +1 -1
  216. package/packages/theme-chalk/lib/fonts/iconfont.ttf +0 -0
  217. package/packages/theme-chalk/lib/fonts/iconfont.woff +0 -0
  218. package/packages/theme-chalk/lib/icon.css +1 -1
  219. package/packages/theme-chalk/lib/index.css +1 -1
  220. package/packages/theme-chalk/lib/main.css +1 -1
  221. package/packages/theme-chalk/lib/menu.css +1 -1
  222. package/packages/theme-chalk/lib/simplicity.css +1 -1
  223. package/packages/theme-chalk/lib/sizer.css +1 -1
  224. package/packages/theme-chalk/lib/upload.css +1 -1
  225. package/packages/theme-chalk/src/base.scss +261 -261
  226. package/packages/theme-chalk/src/button-group.scss +176 -176
  227. package/packages/theme-chalk/src/button.scss +24 -24
  228. package/packages/theme-chalk/src/calendar.scss +113 -113
  229. package/packages/theme-chalk/src/card.scss +99 -99
  230. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  231. package/packages/theme-chalk/src/clients.scss +87 -87
  232. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  233. package/packages/theme-chalk/src/data-table.scss +297 -293
  234. package/packages/theme-chalk/src/date-picker.scss +7 -7
  235. package/packages/theme-chalk/src/dialog.scss +77 -77
  236. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  237. package/packages/theme-chalk/src/enterprise.scss +5 -5
  238. package/packages/theme-chalk/src/error-page.scss +18 -18
  239. package/packages/theme-chalk/src/flow-group.scss +110 -110
  240. package/packages/theme-chalk/src/flow-list.scss +39 -39
  241. package/packages/theme-chalk/src/flow.scss +351 -351
  242. package/packages/theme-chalk/src/fonts/iconfont.ttf +0 -0
  243. package/packages/theme-chalk/src/fonts/iconfont.woff +0 -0
  244. package/packages/theme-chalk/src/form.scss +501 -501
  245. package/packages/theme-chalk/src/handle-user.scss +40 -40
  246. package/packages/theme-chalk/src/handler.scss +148 -148
  247. package/packages/theme-chalk/src/icon.scss +1540 -1456
  248. package/packages/theme-chalk/src/icons.scss +99 -99
  249. package/packages/theme-chalk/src/input.scss +9 -9
  250. package/packages/theme-chalk/src/label.scss +24 -24
  251. package/packages/theme-chalk/src/layout.scss +46 -46
  252. package/packages/theme-chalk/src/login.scss +1006 -1006
  253. package/packages/theme-chalk/src/main.scss +663 -663
  254. package/packages/theme-chalk/src/menu.scss +224 -224
  255. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  256. package/packages/theme-chalk/src/nav.scss +111 -111
  257. package/packages/theme-chalk/src/page.scss +3 -3
  258. package/packages/theme-chalk/src/pagination.scss +29 -29
  259. package/packages/theme-chalk/src/player.scss +9 -9
  260. package/packages/theme-chalk/src/qr-code.scss +17 -17
  261. package/packages/theme-chalk/src/radio-group.scss +9 -9
  262. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  263. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  264. package/packages/theme-chalk/src/select.scss +8 -8
  265. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  266. package/packages/theme-chalk/src/selector.scss +114 -114
  267. package/packages/theme-chalk/src/simplicity.scss +1395 -1395
  268. package/packages/theme-chalk/src/sizer.scss +36 -36
  269. package/packages/theme-chalk/src/steps.scss +88 -88
  270. package/packages/theme-chalk/src/switch.scss +3 -3
  271. package/packages/theme-chalk/src/table-form.scss +1 -1
  272. package/packages/theme-chalk/src/tabs.scss +87 -87
  273. package/packages/theme-chalk/src/tips.scss +7 -7
  274. package/packages/theme-chalk/src/toolbar.scss +179 -179
  275. package/packages/theme-chalk/src/tree-group.scss +72 -72
  276. package/packages/theme-chalk/src/tree.scss +165 -165
  277. package/packages/theme-chalk/src/upload.scss +172 -172
  278. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  279. package/packages/tips/index.js +5 -5
  280. package/packages/tips/src/main.vue +141 -141
  281. package/packages/toolbar/index.js +5 -5
  282. package/packages/toolbar/src/main.vue +430 -430
  283. package/packages/tree/index.js +5 -5
  284. package/packages/tree-group/index.js +5 -5
  285. package/packages/upload/index.js +5 -5
  286. package/packages/upload/src/main.vue +1344 -1344
  287. package/packages/upload/src/picture.js +15 -15
  288. package/packages/wujie/index.js +5 -5
  289. package/packages/wujie/src/main.vue +145 -145
  290. package/packages/wxlogin/index.js +5 -5
  291. package/packages/wxlogin/src/main.vue +128 -128
  292. package/src/config/api.js +317 -315
  293. package/src/config/image.js +2 -2
  294. package/src/index.js +163 -163
  295. package/src/utils/bus.js +3 -3
  296. package/src/utils/date-util.js +312 -312
  297. package/src/utils/http.js +50 -50
  298. package/src/utils/rules.js +18 -18
  299. package/src/utils/store.js +21 -21
  300. package/src/utils/util.js +7 -10
  301. package/src/utils/webSocket.js +107 -107
  302. package/packages/.DS_Store +0 -0
  303. package/packages/calogin/.DS_Store +0 -0
  304. package/packages/date-picker/.DS_Store +0 -0
  305. package/packages/date-picker/src/.DS_Store +0 -0
  306. package/packages/dialog/.DS_Store +0 -0
  307. package/packages/flow/.DS_Store +0 -0
  308. package/packages/flow/src/.DS_Store +0 -0
  309. package/packages/flow-list/.DS_Store +0 -0
  310. package/packages/form/.DS_Store +0 -0
  311. package/packages/icon/.DS_Store +0 -0
  312. package/packages/login/.DS_Store +0 -0
  313. package/packages/main/.DS_Store +0 -0
  314. package/packages/main/src/.DS_Store +0 -0
  315. package/packages/menu/.DS_Store +0 -0
  316. package/packages/select/.DS_Store +0 -0
  317. package/packages/selector/.DS_Store +0 -0
  318. package/packages/selector-panel/.DS_Store +0 -0
  319. package/packages/theme-chalk/src/.DS_Store +0 -0
  320. package/packages/upload/.DS_Store +0 -0
  321. package/src/.DS_Store +0 -0
  322. package/src/utils/.DS_Store +0 -0
@@ -1,496 +1,496 @@
1
- <template>
2
- <ul class="es-handler">
3
- <template v-for="(item, index) in lists">
4
- <li v-if="!item.hide" :key="index" class="es-handler-item">
5
- <es-handle-user
6
- v-if="item.type === 'user'"
7
- class="es-handler-user"
8
- :data="item"
9
- :userModel="userModel"
10
- :job-scrollbar="jobScrollbar"
11
- @visible-change="handleVisibleChange"
12
- @click="handleClick"
13
- @change="handleChange"
14
- ></es-handle-user>
15
- <div
16
- v-else-if="item.type == 'contact'"
17
- class="es-handler-contact"
18
- :key="item.type"
19
- >
20
- <div class="es-contact-label">{{ item.label }}</div>
21
- <div class="es-contact-content">
22
- <div v-for="ele in item.content" :key="ele">{{ ele }}</div>
23
- </div>
24
- </div>
25
- <div v-else-if="item.type === 'dateTime'" class="es-handler-date">
26
- <div>
27
- {{ time }}
28
- <span v-if="show"
29
- >当前<span
30
- class="es-online-num"
31
- :class="{ 'es-pointer': onlineList }"
32
- @click.stop="onlineList ? handleClick({ type: 'online' }) : ''"
33
- >{{ online }}</span
34
- >人在线</span
35
- >
36
- </div>
37
- <div>今 天:{{ date }}</div>
38
- </div>
39
- <el-popover
40
- v-else-if="item.type === 'system'"
41
- placement="bottom"
42
- trigger="hover"
43
- ref="system"
44
- :popper-class="
45
- systemData.length > 4
46
- ? 'es-popper-sub-system is-width'
47
- : 'es-popper-sub-system'
48
- "
49
- @show="showPopper = true"
50
- @hide="showPopper = false"
51
- >
52
- <el-scrollbar :max-height="maxHeight" v-if="systemData.length">
53
- <ul class="es-sub-system">
54
- <li
55
- v-for="ele in systemData"
56
- class="es-sub-system-item"
57
- :class="{
58
- 'es-disabled':
59
- (application && !ele.hasPermission) ||
60
- (ele.extendData && ele.extendData.businessStatus == 0)
61
- }"
62
- :key="ele.id"
63
- :title="ele.text"
64
- @click.stop="handleSelect({ node: ele })"
65
- >
66
- <el-badge
67
- :is-dot="typeof ele.tips === 'boolean'"
68
- :hidden="!ele.tips"
69
- :max="99"
70
- :value="typeof ele.tips !== 'boolean' ? ele.tips : 0"
71
- >
72
- <es-icon
73
- class="es-sub-system-icon"
74
- :contents="ele.icons || 'es-icon-yingyong'"
75
- ></es-icon>
76
- </el-badge>
77
- <div class="es-sub-system-title">{{ ele.text }}</div>
78
- </li>
79
- </ul>
80
- </el-scrollbar>
81
- <div
82
- slot="reference"
83
- class="es-handler-icon"
84
- :title="item.title"
85
- :class="item.icon"
86
- ></div>
87
- </el-popover>
88
- <el-tooltip
89
- v-else
90
- :key="item.type"
91
- effect="dark"
92
- :content="item.title"
93
- placement="bottom"
94
- >
95
- <el-badge
96
- class="es-badge"
97
- v-if="item.type === 'notice'"
98
- :value="noticeNum"
99
- :max="99"
100
- :hidden="noticeNum < 1"
101
- >
102
- <es-icon
103
- class="es-handler-icon"
104
- @click.stop="handleClick(item)"
105
- :contents="item.icon"
106
- ></es-icon>
107
- </el-badge>
108
- <es-icon
109
- v-else
110
- class="es-handler-icon"
111
- @click.stop="handleClick(item)"
112
- :contents="item.icon"
113
- ></es-icon>
114
- </el-tooltip>
115
- </li>
116
- </template>
117
- </ul>
118
- </template>
119
- <script>
120
- import { logout } from 'eoss-ui/src/config/api.js';
121
- import util from 'eoss-ui/src/utils/util';
122
- export default {
123
- name: 'EsHandler',
124
- inheritAttrs: false,
125
- inject: {
126
- onQuit: {
127
- default: ''
128
- }
129
- },
130
- props: {
131
- contact: Object,
132
- jobScrollbar: Boolean,
133
- data: Array,
134
- color: {
135
- type: String,
136
- default: '#333333'
137
- },
138
- userModel: Object,
139
- subSystem: {
140
- type: Array,
141
- default() {
142
- return [];
143
- }
144
- },
145
- hide: {
146
- type: Object,
147
- default() {
148
- return {};
149
- }
150
- },
151
- photo: String,
152
- storage: String,
153
- application: {
154
- type: Boolean,
155
- default: false
156
- },
157
- maxHeight: {
158
- type: String,
159
- default: '100%'
160
- },
161
- user: {
162
- type: Object,
163
- default() {
164
- return {
165
- type: 'user'
166
- };
167
- }
168
- },
169
- dateTime: {
170
- type: Object,
171
- default() {
172
- return {
173
- type: 'dateTime'
174
- };
175
- }
176
- },
177
- system: {
178
- type: Object,
179
- default() {
180
- return {
181
- type: 'system',
182
- icon: 'es-icon-yingyong',
183
- title: '切换子系统'
184
- };
185
- }
186
- },
187
- home: {
188
- type: Object,
189
- default() {
190
- return {
191
- type: 'home',
192
- icon: 'es-icon-zuomian',
193
- title: '个人工作台'
194
- };
195
- }
196
- },
197
- search: {
198
- type: Object,
199
- default() {
200
- return {
201
- type: 'search',
202
- icon: 'es-icon-sousuo',
203
- title: '搜索'
204
- };
205
- }
206
- },
207
- im: {
208
- type: Object,
209
- default() {
210
- return {
211
- type: 'im',
212
- icon: 'es-icon-message',
213
- title: 'IM'
214
- };
215
- }
216
- },
217
- index: {
218
- type: Object,
219
- default() {
220
- return {
221
- type: 'index',
222
- icon: 'es-icon-home',
223
- title: '门户'
224
- };
225
- }
226
- },
227
- home: {
228
- type: Object,
229
- default() {
230
- return {
231
- type: 'home',
232
- icon: 'es-icon-zhuye',
233
- title: '个人工作台'
234
- };
235
- }
236
- },
237
- notice: {
238
- type: Object,
239
- default() {
240
- return {
241
- type: 'notice',
242
- icon: 'es-icon-xiaoxi',
243
- title: '通知消息'
244
- };
245
- }
246
- },
247
- refresh: {
248
- type: Object,
249
- default() {
250
- return {
251
- type: 'refresh',
252
- icon: 'es-icon-shuaxin',
253
- title: '刷新'
254
- };
255
- }
256
- },
257
- quit: {
258
- type: Object,
259
- default() {
260
- return {
261
- type: 'quit',
262
- icon: 'es-icon-tuichu',
263
- title: '退出'
264
- };
265
- }
266
- },
267
- set: {
268
- type: Object,
269
- default() {
270
- return {
271
- type: 'set',
272
- icon: 'es-icon-shezhi',
273
- title: '设置'
274
- };
275
- }
276
- },
277
- msgNum: {
278
- type: Number,
279
- default: 0
280
- },
281
- noticeNum: {
282
- type: Number,
283
- default: 0
284
- },
285
- online: {
286
- type: Number,
287
- default: 1
288
- },
289
- singleLogout: Array
290
- },
291
- watch: {
292
- subSystem: {
293
- handler(val) {
294
- if (this.showPopper) {
295
- this.$refs.system[0].doClose();
296
- this.$nextTick(this.$refs.system[0].doShow);
297
- }
298
- }
299
- }
300
- },
301
- computed: {
302
- lists() {
303
- let hide = {
304
- system: true,
305
- new: true,
306
- //im: true,
307
- ...this.hide
308
- };
309
- let data = this.data
310
- ? this.data
311
- : [
312
- this.user,
313
- this.contact ? { ...this.contact, type: 'contact' } : {},
314
- this.dateTime,
315
- this.system,
316
- this.search,
317
- this.im,
318
- this.index,
319
- this.home,
320
- this.notice,
321
- this.refresh,
322
- this.quit,
323
- this.set
324
- ];
325
- return data.filter((item) => {
326
- return (
327
- item && Object.keys(item).length && !item.hide && !hide[item.type]
328
- );
329
- });
330
- },
331
- systemData() {
332
- return this.subSystem;
333
- },
334
- show() {
335
- if (this.online === false) {
336
- return false;
337
- }
338
- return true;
339
- },
340
- onlineList() {
341
- return (
342
- this.useCaseCodes && this.useCaseCodes.includes('sys_user_onlineList')
343
- );
344
- }
345
- },
346
- data() {
347
- return {
348
- date: '',
349
- time: '',
350
- showPopper: false,
351
- useCaseCodes: util.getStorage('useCaseCodes')
352
- };
353
- },
354
- created() {
355
- this.time = util.timeCycle() + '好!';
356
- this.date = util.formatDate('', 'yyyy 年 M 月 d 日 ');
357
- },
358
- methods: {
359
- unicode(res) {
360
- if (!res) {
361
- return false;
362
- }
363
- var reg = new RegExp(/^es-\S+/, 'g');
364
- let len = res.match(reg) ? res.match(reg).length : 0;
365
- return len;
366
- },
367
- handleClick(res) {
368
- const { type, event } = res;
369
- if (event) {
370
- event();
371
- } else {
372
- switch (type) {
373
- case 'quit':
374
- this.handleQuit();
375
- break;
376
- }
377
- this.$emit('click', res);
378
- }
379
- },
380
- handleChange(item) {
381
- this.$emit('change', item);
382
- },
383
- handleSelect(res) {
384
- const { node } = res;
385
- if (node.extendData && node.extendData.businessStatus == 0) {
386
- this.$alert(
387
- node.extendData.businessWarnMsg
388
- ? node.extendData.businessWarnMsg
389
- : '此模块还在开发中',
390
- '提示',
391
- {
392
- type: 'warning'
393
- }
394
- );
395
- } else if (!this.application && !node.hasPermission) {
396
- this.$emit('select', res);
397
- }
398
- },
399
- handleQuit() {
400
- this.$confirm('确定退出吗?', '退出系统', {
401
- confirmButtonText: '确定',
402
- cancelButtonText: '取消',
403
- type: 'warning'
404
- })
405
- .then(() => {
406
- let iframes = document.getElementsByTagName('iframe');
407
- for (let i = 0; i < iframes.length; i++) {
408
- let src = iframes[i] ? iframes[i].src : null;
409
- let origin = util.win.location.origin;
410
- if (
411
- src &&
412
- util.startWith(src, 'http') &&
413
- src.indexOf(origin) === -1
414
- ) {
415
- iframes[i] && iframes[i].contentWindow.postMessage('logout', '*');
416
- }
417
- }
418
- if (this.singleLogout) {
419
- for (let i = 0; i < this.singleLogout.length; i++) {
420
- let iframe = document.createElement('iframe');
421
- iframe.style.display = 'none';
422
- iframe.src = this.singleLogout[i];
423
- document.body.appendChild(iframe);
424
- }
425
- }
426
- util
427
- .ajax({ method: 'post', url: logout })
428
- .then((res) => {
429
- if (res.rCode == 0) {
430
- util.removeStorage([
431
- 'Authorization',
432
- 'token',
433
- 'ssId',
434
- 'userId',
435
- 'userName',
436
- 'auth',
437
- 'deviceUnique',
438
- 'menus',
439
- 'useCaseCodes',
440
- 'mainConfig',
441
- 'jump'
442
- ]);
443
- if (this.onQuit && typeof this.onQuit === 'function') {
444
- this.onQuit();
445
- } else {
446
- try {
447
- const loginPage =
448
- util.getStorage('login') || util.getStorage('loginPage');
449
- if (loginPage) {
450
- let src;
451
- if (!util.startWith(loginPage, ['http', '/'], true)) {
452
- let pathname = util.win.top.location.pathname;
453
- if (pathname !== '/') {
454
- pathname = pathname.split('/');
455
- pathname.splice(pathname.length - 1);
456
- pathname = pathname.join('/');
457
- src = pathname + '/' + loginPage.replace('./', '');
458
- } else {
459
- src = pathname + loginPage.replace('./', '');
460
- }
461
- } else {
462
- src = loginPage;
463
- }
464
- util.win.top.location.href = src;
465
- } else if (
466
- util.win.top.location.href.indexOf('main.html') > -1
467
- ) {
468
- util.win.top.location.href = './login.html';
469
- } else {
470
- const hash = util.win.top.location.hash;
471
- if (hash) {
472
- const len = util.win.top.location.href.indexOf(hash);
473
- util.win.top.location.href =
474
- util.win.location.href.slice(0, len) + '#/login';
475
- } else {
476
- util.win.top.location.href = '/login.html';
477
- }
478
- }
479
- } catch (error) {}
480
- }
481
- }
482
- })
483
- .catch((err) => {
484
- if (err.message && err.message !== 'canceled') {
485
- this.$message.error(err.message);
486
- }
487
- });
488
- })
489
- .catch((e) => {});
490
- },
491
- handleVisibleChange(res) {
492
- this.$emit('visible-change', res);
493
- }
494
- }
495
- };
496
- </script>
1
+ <template>
2
+ <ul class="es-handler">
3
+ <template v-for="(item, index) in lists">
4
+ <li v-if="!item.hide" :key="index" class="es-handler-item">
5
+ <es-handle-user
6
+ v-if="item.type === 'user'"
7
+ class="es-handler-user"
8
+ :data="item"
9
+ :userModel="userModel"
10
+ :job-scrollbar="jobScrollbar"
11
+ @visible-change="handleVisibleChange"
12
+ @click="handleClick"
13
+ @change="handleChange"
14
+ ></es-handle-user>
15
+ <div
16
+ v-else-if="item.type == 'contact'"
17
+ class="es-handler-contact"
18
+ :key="item.type"
19
+ >
20
+ <div class="es-contact-label">{{ item.label }}</div>
21
+ <div class="es-contact-content">
22
+ <div v-for="ele in item.content" :key="ele">{{ ele }}</div>
23
+ </div>
24
+ </div>
25
+ <div v-else-if="item.type === 'dateTime'" class="es-handler-date">
26
+ <div>
27
+ {{ time }}
28
+ <span v-if="show"
29
+ >当前<span
30
+ class="es-online-num"
31
+ :class="{ 'es-pointer': onlineList }"
32
+ @click.stop="onlineList ? handleClick({ type: 'online' }) : ''"
33
+ >{{ online }}</span
34
+ >人在线</span
35
+ >
36
+ </div>
37
+ <div>今 天:{{ date }}</div>
38
+ </div>
39
+ <el-popover
40
+ v-else-if="item.type === 'system'"
41
+ placement="bottom"
42
+ trigger="hover"
43
+ ref="system"
44
+ :popper-class="
45
+ systemData.length > 4
46
+ ? 'es-popper-sub-system is-width'
47
+ : 'es-popper-sub-system'
48
+ "
49
+ @show="showPopper = true"
50
+ @hide="showPopper = false"
51
+ >
52
+ <el-scrollbar :max-height="maxHeight" v-if="systemData.length">
53
+ <ul class="es-sub-system">
54
+ <li
55
+ v-for="ele in systemData"
56
+ class="es-sub-system-item"
57
+ :class="{
58
+ 'es-disabled':
59
+ (application && !ele.hasPermission) ||
60
+ (ele.extendData && ele.extendData.businessStatus == 0)
61
+ }"
62
+ :key="ele.id"
63
+ :title="ele.text"
64
+ @click.stop="handleSelect({ node: ele })"
65
+ >
66
+ <el-badge
67
+ :is-dot="typeof ele.tips === 'boolean'"
68
+ :hidden="!ele.tips"
69
+ :max="99"
70
+ :value="typeof ele.tips !== 'boolean' ? ele.tips : 0"
71
+ >
72
+ <es-icon
73
+ class="es-sub-system-icon"
74
+ :contents="ele.icons || 'es-icon-yingyong'"
75
+ ></es-icon>
76
+ </el-badge>
77
+ <div class="es-sub-system-title">{{ ele.text }}</div>
78
+ </li>
79
+ </ul>
80
+ </el-scrollbar>
81
+ <div
82
+ slot="reference"
83
+ class="es-handler-icon"
84
+ :title="item.title"
85
+ :class="item.icon"
86
+ ></div>
87
+ </el-popover>
88
+ <el-tooltip
89
+ v-else
90
+ :key="item.type"
91
+ effect="dark"
92
+ :content="item.title"
93
+ placement="bottom"
94
+ >
95
+ <el-badge
96
+ class="es-badge"
97
+ v-if="item.type === 'notice'"
98
+ :value="noticeNum"
99
+ :max="99"
100
+ :hidden="noticeNum < 1"
101
+ >
102
+ <es-icon
103
+ class="es-handler-icon"
104
+ @click.stop="handleClick(item)"
105
+ :contents="item.icon"
106
+ ></es-icon>
107
+ </el-badge>
108
+ <es-icon
109
+ v-else
110
+ class="es-handler-icon"
111
+ @click.stop="handleClick(item)"
112
+ :contents="item.icon"
113
+ ></es-icon>
114
+ </el-tooltip>
115
+ </li>
116
+ </template>
117
+ </ul>
118
+ </template>
119
+ <script>
120
+ import { logout } from 'eoss-ui/src/config/api.js';
121
+ import util from 'eoss-ui/src/utils/util';
122
+ export default {
123
+ name: 'EsHandler',
124
+ inheritAttrs: false,
125
+ inject: {
126
+ onQuit: {
127
+ default: ''
128
+ }
129
+ },
130
+ props: {
131
+ contact: Object,
132
+ jobScrollbar: Boolean,
133
+ data: Array,
134
+ color: {
135
+ type: String,
136
+ default: '#333333'
137
+ },
138
+ userModel: Object,
139
+ subSystem: {
140
+ type: Array,
141
+ default() {
142
+ return [];
143
+ }
144
+ },
145
+ hide: {
146
+ type: Object,
147
+ default() {
148
+ return {};
149
+ }
150
+ },
151
+ photo: String,
152
+ storage: String,
153
+ application: {
154
+ type: Boolean,
155
+ default: false
156
+ },
157
+ maxHeight: {
158
+ type: String,
159
+ default: '100%'
160
+ },
161
+ user: {
162
+ type: Object,
163
+ default() {
164
+ return {
165
+ type: 'user'
166
+ };
167
+ }
168
+ },
169
+ dateTime: {
170
+ type: Object,
171
+ default() {
172
+ return {
173
+ type: 'dateTime'
174
+ };
175
+ }
176
+ },
177
+ system: {
178
+ type: Object,
179
+ default() {
180
+ return {
181
+ type: 'system',
182
+ icon: 'es-icon-yingyong',
183
+ title: '切换子系统'
184
+ };
185
+ }
186
+ },
187
+ home: {
188
+ type: Object,
189
+ default() {
190
+ return {
191
+ type: 'home',
192
+ icon: 'es-icon-zuomian',
193
+ title: '个人工作台'
194
+ };
195
+ }
196
+ },
197
+ search: {
198
+ type: Object,
199
+ default() {
200
+ return {
201
+ type: 'search',
202
+ icon: 'es-icon-sousuo',
203
+ title: '搜索'
204
+ };
205
+ }
206
+ },
207
+ im: {
208
+ type: Object,
209
+ default() {
210
+ return {
211
+ type: 'im',
212
+ icon: 'es-icon-message',
213
+ title: 'IM'
214
+ };
215
+ }
216
+ },
217
+ index: {
218
+ type: Object,
219
+ default() {
220
+ return {
221
+ type: 'index',
222
+ icon: 'es-icon-home',
223
+ title: '门户'
224
+ };
225
+ }
226
+ },
227
+ home: {
228
+ type: Object,
229
+ default() {
230
+ return {
231
+ type: 'home',
232
+ icon: 'es-icon-zhuye',
233
+ title: '个人工作台'
234
+ };
235
+ }
236
+ },
237
+ notice: {
238
+ type: Object,
239
+ default() {
240
+ return {
241
+ type: 'notice',
242
+ icon: 'es-icon-xiaoxi',
243
+ title: '通知消息'
244
+ };
245
+ }
246
+ },
247
+ refresh: {
248
+ type: Object,
249
+ default() {
250
+ return {
251
+ type: 'refresh',
252
+ icon: 'es-icon-shuaxin',
253
+ title: '刷新'
254
+ };
255
+ }
256
+ },
257
+ quit: {
258
+ type: Object,
259
+ default() {
260
+ return {
261
+ type: 'quit',
262
+ icon: 'es-icon-tuichu',
263
+ title: '退出'
264
+ };
265
+ }
266
+ },
267
+ set: {
268
+ type: Object,
269
+ default() {
270
+ return {
271
+ type: 'set',
272
+ icon: 'es-icon-shezhi',
273
+ title: '设置'
274
+ };
275
+ }
276
+ },
277
+ msgNum: {
278
+ type: Number,
279
+ default: 0
280
+ },
281
+ noticeNum: {
282
+ type: Number,
283
+ default: 0
284
+ },
285
+ online: {
286
+ type: Number,
287
+ default: 1
288
+ },
289
+ singleLogout: Array
290
+ },
291
+ watch: {
292
+ subSystem: {
293
+ handler(val) {
294
+ if (this.showPopper) {
295
+ this.$refs.system[0].doClose();
296
+ this.$nextTick(this.$refs.system[0].doShow);
297
+ }
298
+ }
299
+ }
300
+ },
301
+ computed: {
302
+ lists() {
303
+ let hide = {
304
+ system: true,
305
+ new: true,
306
+ //im: true,
307
+ ...this.hide
308
+ };
309
+ let data = this.data
310
+ ? this.data
311
+ : [
312
+ this.user,
313
+ this.contact ? { ...this.contact, type: 'contact' } : {},
314
+ this.dateTime,
315
+ this.system,
316
+ this.search,
317
+ this.im,
318
+ this.index,
319
+ this.home,
320
+ this.notice,
321
+ this.refresh,
322
+ this.quit,
323
+ this.set
324
+ ];
325
+ return data.filter((item) => {
326
+ return (
327
+ item && Object.keys(item).length && !item.hide && !hide[item.type]
328
+ );
329
+ });
330
+ },
331
+ systemData() {
332
+ return this.subSystem;
333
+ },
334
+ show() {
335
+ if (this.online === false) {
336
+ return false;
337
+ }
338
+ return true;
339
+ },
340
+ onlineList() {
341
+ return (
342
+ this.useCaseCodes && this.useCaseCodes.includes('sys_user_onlineList')
343
+ );
344
+ }
345
+ },
346
+ data() {
347
+ return {
348
+ date: '',
349
+ time: '',
350
+ showPopper: false,
351
+ useCaseCodes: util.getStorage('useCaseCodes')
352
+ };
353
+ },
354
+ created() {
355
+ this.time = util.timeCycle() + '好!';
356
+ this.date = util.formatDate('', 'yyyy 年 M 月 d 日 ');
357
+ },
358
+ methods: {
359
+ unicode(res) {
360
+ if (!res) {
361
+ return false;
362
+ }
363
+ var reg = new RegExp(/^es-\S+/, 'g');
364
+ let len = res.match(reg) ? res.match(reg).length : 0;
365
+ return len;
366
+ },
367
+ handleClick(res) {
368
+ const { type, event } = res;
369
+ if (event) {
370
+ event();
371
+ } else {
372
+ switch (type) {
373
+ case 'quit':
374
+ this.handleQuit();
375
+ break;
376
+ }
377
+ this.$emit('click', res);
378
+ }
379
+ },
380
+ handleChange(item) {
381
+ this.$emit('change', item);
382
+ },
383
+ handleSelect(res) {
384
+ const { node } = res;
385
+ if (node.extendData && node.extendData.businessStatus == 0) {
386
+ this.$alert(
387
+ node.extendData.businessWarnMsg
388
+ ? node.extendData.businessWarnMsg
389
+ : '此模块还在开发中',
390
+ '提示',
391
+ {
392
+ type: 'warning'
393
+ }
394
+ );
395
+ } else if (!this.application && !node.hasPermission) {
396
+ this.$emit('select', res);
397
+ }
398
+ },
399
+ handleQuit() {
400
+ this.$confirm('确定退出吗?', '退出系统', {
401
+ confirmButtonText: '确定',
402
+ cancelButtonText: '取消',
403
+ type: 'warning'
404
+ })
405
+ .then(() => {
406
+ let iframes = document.getElementsByTagName('iframe');
407
+ for (let i = 0; i < iframes.length; i++) {
408
+ let src = iframes[i] ? iframes[i].src : null;
409
+ let origin = util.win.location.origin;
410
+ if (
411
+ src &&
412
+ util.startWith(src, 'http') &&
413
+ src.indexOf(origin) === -1
414
+ ) {
415
+ iframes[i] && iframes[i].contentWindow.postMessage('logout', '*');
416
+ }
417
+ }
418
+ if (this.singleLogout) {
419
+ for (let i = 0; i < this.singleLogout.length; i++) {
420
+ let iframe = document.createElement('iframe');
421
+ iframe.style.display = 'none';
422
+ iframe.src = this.singleLogout[i];
423
+ document.body.appendChild(iframe);
424
+ }
425
+ }
426
+ util
427
+ .ajax({ method: 'post', url: logout })
428
+ .then((res) => {
429
+ if (res.rCode == 0) {
430
+ util.removeStorage([
431
+ 'Authorization',
432
+ 'token',
433
+ 'ssId',
434
+ 'userId',
435
+ 'userName',
436
+ 'auth',
437
+ 'deviceUnique',
438
+ 'menus',
439
+ 'useCaseCodes',
440
+ 'mainConfig',
441
+ 'jump'
442
+ ]);
443
+ if (this.onQuit && typeof this.onQuit === 'function') {
444
+ this.onQuit();
445
+ } else {
446
+ try {
447
+ const loginPage =
448
+ util.getStorage('login') || util.getStorage('loginPage');
449
+ if (loginPage) {
450
+ let src;
451
+ if (!util.startWith(loginPage, ['http', '/'], true)) {
452
+ let pathname = util.win.top.location.pathname;
453
+ if (pathname !== '/') {
454
+ pathname = pathname.split('/');
455
+ pathname.splice(pathname.length - 1);
456
+ pathname = pathname.join('/');
457
+ src = pathname + '/' + loginPage.replace('./', '');
458
+ } else {
459
+ src = pathname + loginPage.replace('./', '');
460
+ }
461
+ } else {
462
+ src = loginPage;
463
+ }
464
+ util.win.top.location.href = src;
465
+ } else if (
466
+ util.win.top.location.href.indexOf('main.html') > -1
467
+ ) {
468
+ util.win.top.location.href = './login.html';
469
+ } else {
470
+ const hash = util.win.top.location.hash;
471
+ if (hash) {
472
+ const len = util.win.top.location.href.indexOf(hash);
473
+ util.win.top.location.href =
474
+ util.win.location.href.slice(0, len) + '#/login';
475
+ } else {
476
+ util.win.top.location.href = '/login.html';
477
+ }
478
+ }
479
+ } catch (error) {}
480
+ }
481
+ }
482
+ })
483
+ .catch((err) => {
484
+ if (err.message && err.message !== 'canceled') {
485
+ this.$message.error(err.message);
486
+ }
487
+ });
488
+ })
489
+ .catch((e) => {});
490
+ },
491
+ handleVisibleChange(res) {
492
+ this.$emit('visible-change', res);
493
+ }
494
+ }
495
+ };
496
+ </script>