eoss-ui 0.7.14 → 0.7.16

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