eoss-ui 0.7.27 → 0.7.29

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 (283) hide show
  1. package/lib/button-group.js +35 -16
  2. package/lib/button.js +35 -16
  3. package/lib/calogin.js +268 -249
  4. package/lib/checkbox-group.js +35 -16
  5. package/lib/data-table-form.js +35 -16
  6. package/lib/data-table.js +47 -24
  7. package/lib/date-picker.js +35 -16
  8. package/lib/dialog.js +35 -16
  9. package/lib/eoss-ui.common.js +1777 -1427
  10. package/lib/flow-group.js +38 -19
  11. package/lib/flow-list.js +116 -97
  12. package/lib/flow.js +478 -411
  13. package/lib/form.js +35 -16
  14. package/lib/handle-user.js +35 -16
  15. package/lib/handler.js +35 -16
  16. package/lib/icon.js +35 -16
  17. package/lib/index.js +1 -1
  18. package/lib/input-number.js +35 -16
  19. package/lib/input.js +35 -16
  20. package/lib/login.js +256 -126
  21. package/lib/main.js +742 -554
  22. package/lib/menu.js +0 -1
  23. package/lib/nav.js +35 -16
  24. package/lib/page.js +35 -16
  25. package/lib/pagination.js +35 -16
  26. package/lib/player.js +35 -16
  27. package/lib/qr-code.js +48 -29
  28. package/lib/radio-group.js +35 -16
  29. package/lib/retrial-auth.js +35 -16
  30. package/lib/select-ganged.js +35 -16
  31. package/lib/select.js +35 -16
  32. package/lib/selector-panel.js +35 -16
  33. package/lib/selector.js +35 -16
  34. package/lib/sizer.js +35 -16
  35. package/lib/steps.js +35 -16
  36. package/lib/switch.js +35 -16
  37. package/lib/table-form.js +35 -16
  38. package/lib/tabs.js +35 -16
  39. package/lib/tips.js +35 -16
  40. package/lib/tree-group.js +35 -16
  41. package/lib/tree.js +35 -16
  42. package/lib/upload.js +35 -16
  43. package/lib/utils/util.js +31 -12
  44. package/lib/wujie.js +35 -16
  45. package/lib/wxlogin.js +35 -16
  46. package/package.json +160 -160
  47. package/packages/.DS_Store +0 -0
  48. package/packages/button/index.js +5 -5
  49. package/packages/button/src/main.vue +418 -418
  50. package/packages/button-group/index.js +5 -5
  51. package/packages/button-group/src/main.vue +346 -346
  52. package/packages/calendar/index.js +5 -5
  53. package/packages/calogin/.DS_Store +0 -0
  54. package/packages/calogin/index.js +5 -5
  55. package/packages/calogin/src/main.vue +412 -412
  56. package/packages/calogin/src/plugin.js +915 -915
  57. package/packages/card/index.js +5 -5
  58. package/packages/card/src/main.vue +156 -156
  59. package/packages/cascader/index.js +5 -5
  60. package/packages/cascader/src/main.vue +168 -168
  61. package/packages/checkbox-group/index.js +5 -5
  62. package/packages/checkbox-group/src/main.vue +333 -333
  63. package/packages/clients/index.js +5 -5
  64. package/packages/clients/src/main.vue +151 -151
  65. package/packages/data-table/index.js +5 -5
  66. package/packages/data-table/src/children.vue +39 -39
  67. package/packages/data-table/src/column.vue +992 -988
  68. package/packages/data-table/src/main.vue +1831 -1831
  69. package/packages/data-table/src/sizer.vue +195 -195
  70. package/packages/data-table-form/index.js +5 -5
  71. package/packages/data-table-form/src/checkbox.vue +101 -101
  72. package/packages/data-table-form/src/colgroup.vue +17 -17
  73. package/packages/data-table-form/src/main.vue +181 -181
  74. package/packages/data-table-form/src/radio.vue +65 -65
  75. package/packages/data-table-form/src/table.vue +233 -233
  76. package/packages/data-table-form/src/tbody.vue +336 -336
  77. package/packages/data-table-form/src/thead.vue +68 -68
  78. package/packages/date-picker/.DS_Store +0 -0
  79. package/packages/date-picker/index.js +5 -5
  80. package/packages/date-picker/src/.DS_Store +0 -0
  81. package/packages/date-picker/src/main.vue +236 -236
  82. package/packages/dialog/index.js +5 -5
  83. package/packages/enable-drag/index.js +5 -5
  84. package/packages/enterprise/index.js +5 -5
  85. package/packages/enterprise/src/main.vue +66 -66
  86. package/packages/error-page/index.js +5 -5
  87. package/packages/error-page/src/main.vue +44 -44
  88. package/packages/flow/.DS_Store +0 -0
  89. package/packages/flow/index.js +5 -5
  90. package/packages/flow/src/.DS_Store +0 -0
  91. package/packages/flow/src/component/Circulate.vue +413 -413
  92. package/packages/flow/src/component/CommonOpinions.vue +373 -373
  93. package/packages/flow/src/component/CustomPreset.vue +322 -322
  94. package/packages/flow/src/component/FileList.vue +97 -97
  95. package/packages/flow/src/component/FreeCirculation.vue +240 -240
  96. package/packages/flow/src/component/Preset.vue +255 -255
  97. package/packages/flow/src/component/SendMsg.vue +242 -242
  98. package/packages/flow/src/component/TimeLimit.vue +190 -190
  99. package/packages/flow/src/component/taskUnionExamine.vue +755 -755
  100. package/packages/flow/src/form.vue +121 -121
  101. package/packages/flow/src/freeStartFlow.vue +2847 -2847
  102. package/packages/flow/src/main.vue +3855 -3854
  103. package/packages/flow/src/processForm.vue +1365 -1363
  104. package/packages/flow/src/processReject.vue +309 -309
  105. package/packages/flow/src/reset.vue +941 -941
  106. package/packages/flow/src/startTaskRead.vue +691 -691
  107. package/packages/flow/src/supervise.vue +159 -159
  108. package/packages/flow/src/table.vue +58 -58
  109. package/packages/flow-group/index.js +5 -5
  110. package/packages/flow-group/src/main.vue +717 -717
  111. package/packages/flow-list/.DS_Store +0 -0
  112. package/packages/flow-list/index.js +5 -5
  113. package/packages/flow-list/src/main.vue +1787 -1787
  114. package/packages/form/.DS_Store +0 -0
  115. package/packages/form/index.js +5 -5
  116. package/packages/form/src/main.vue +3901 -3901
  117. package/packages/form/src/table.vue +1512 -1512
  118. package/packages/handle-user/index.js +5 -5
  119. package/packages/handle-user/src/main.vue +137 -137
  120. package/packages/handler/index.js +5 -5
  121. package/packages/handler/src/main.vue +496 -496
  122. package/packages/icon/index.js +5 -5
  123. package/packages/icon/src/main.vue +104 -104
  124. package/packages/icons/index.js +5 -5
  125. package/packages/icons/src/main.vue +81 -81
  126. package/packages/input/index.js +5 -5
  127. package/packages/input/src/main.vue +356 -356
  128. package/packages/input-number/index.js +5 -5
  129. package/packages/input-number/src/main.vue +106 -106
  130. package/packages/label/index.js +5 -5
  131. package/packages/label/src/main.vue +457 -457
  132. package/packages/layout/index.js +5 -5
  133. package/packages/layout/src/item.vue +152 -152
  134. package/packages/layout/src/main.vue +31 -31
  135. package/packages/login/.DS_Store +0 -0
  136. package/packages/login/index.js +5 -5
  137. package/packages/login/src/main.vue +2068 -2020
  138. package/packages/login/src/resetPassword.vue +557 -557
  139. package/packages/main/.DS_Store +0 -0
  140. package/packages/main/index.js +5 -5
  141. package/packages/main/src/.DS_Store +0 -0
  142. package/packages/main/src/default/index.vue +2 -2
  143. package/packages/main/src/default/message.vue +249 -249
  144. package/packages/main/src/default/notice.vue +157 -157
  145. package/packages/main/src/default/userinfo.vue +502 -502
  146. package/packages/main/src/main.vue +165 -69
  147. package/packages/main/src/public/online.vue +89 -89
  148. package/packages/main/src/public/search.vue +464 -464
  149. package/packages/main/src/public/settings.vue +221 -221
  150. package/packages/main/src/simplicity/apps.vue +388 -388
  151. package/packages/main/src/simplicity/avatar.vue +82 -82
  152. package/packages/main/src/simplicity/handler.vue +144 -263
  153. package/packages/main/src/simplicity/index.vue +2253 -2135
  154. package/packages/main/src/simplicity/lists.vue +84 -84
  155. package/packages/main/src/simplicity/menu-list.vue +135 -135
  156. package/packages/main/src/simplicity/message.vue +259 -259
  157. package/packages/main/src/simplicity/notice.vue +190 -190
  158. package/packages/main/src/simplicity/router-page.vue +45 -45
  159. package/packages/main/src/simplicity/sub-menu.vue +266 -264
  160. package/packages/main/src/simplicity/user.vue +259 -259
  161. package/packages/main/src/simplicity/userinfo.vue +398 -398
  162. package/packages/menu/.DS_Store +0 -0
  163. package/packages/menu/index.js +5 -5
  164. package/packages/menu/src/main.vue +595 -596
  165. package/packages/nav/index.js +5 -5
  166. package/packages/nav/src/main.vue +351 -351
  167. package/packages/notify/index.js +5 -5
  168. package/packages/notify/src/main.vue +538 -538
  169. package/packages/page/index.js +5 -5
  170. package/packages/page/src/main.vue +167 -167
  171. package/packages/pagination/index.js +5 -5
  172. package/packages/pagination/src/main.vue +96 -96
  173. package/packages/player/index.js +5 -5
  174. package/packages/player/src/main.vue +194 -194
  175. package/packages/qr-code/index.js +5 -5
  176. package/packages/qr-code/src/main.vue +170 -170
  177. package/packages/radio-group/index.js +6 -6
  178. package/packages/radio-group/src/main.vue +319 -319
  179. package/packages/retrial-auth/index.js +5 -5
  180. package/packages/retrial-auth/src/main.vue +280 -280
  181. package/packages/select/.DS_Store +0 -0
  182. package/packages/select/index.js +5 -5
  183. package/packages/select/src/main.vue +782 -782
  184. package/packages/select-ganged/index.js +5 -5
  185. package/packages/select-ganged/src/main.vue +724 -724
  186. package/packages/selector/.DS_Store +0 -0
  187. package/packages/selector/index.js +5 -5
  188. package/packages/selector/src/main.vue +761 -761
  189. package/packages/selector-panel/.DS_Store +0 -0
  190. package/packages/selector-panel/index.js +5 -5
  191. package/packages/selector-panel/src/main.vue +1027 -1027
  192. package/packages/selector-panel/src/selection.vue +170 -170
  193. package/packages/selector-panel/src/tree.vue +129 -129
  194. package/packages/sizer/index.js +5 -5
  195. package/packages/sizer/src/main.vue +254 -254
  196. package/packages/steps/index.js +5 -5
  197. package/packages/steps/src/main.vue +181 -181
  198. package/packages/switch/index.js +5 -5
  199. package/packages/switch/src/main.vue +170 -170
  200. package/packages/table-form/index.js +5 -5
  201. package/packages/tabs/index.js +5 -5
  202. package/packages/tabs/src/main.vue +788 -788
  203. package/packages/tabs-panel/index.js +5 -5
  204. package/packages/tabs-panel/src/main.vue +29 -29
  205. package/packages/theme-chalk/src/.DS_Store +0 -0
  206. package/packages/theme-chalk/src/base.scss +261 -261
  207. package/packages/theme-chalk/src/button-group.scss +176 -176
  208. package/packages/theme-chalk/src/button.scss +24 -24
  209. package/packages/theme-chalk/src/calendar.scss +113 -113
  210. package/packages/theme-chalk/src/card.scss +99 -99
  211. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  212. package/packages/theme-chalk/src/clients.scss +87 -87
  213. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  214. package/packages/theme-chalk/src/data-table.scss +293 -293
  215. package/packages/theme-chalk/src/date-picker.scss +7 -7
  216. package/packages/theme-chalk/src/dialog.scss +77 -77
  217. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  218. package/packages/theme-chalk/src/enterprise.scss +5 -5
  219. package/packages/theme-chalk/src/error-page.scss +18 -18
  220. package/packages/theme-chalk/src/flow-group.scss +110 -110
  221. package/packages/theme-chalk/src/flow-list.scss +39 -39
  222. package/packages/theme-chalk/src/flow.scss +351 -351
  223. package/packages/theme-chalk/src/form.scss +501 -501
  224. package/packages/theme-chalk/src/handle-user.scss +40 -40
  225. package/packages/theme-chalk/src/handler.scss +148 -148
  226. package/packages/theme-chalk/src/icon.scss +1817 -1817
  227. package/packages/theme-chalk/src/icons.scss +99 -99
  228. package/packages/theme-chalk/src/input.scss +9 -9
  229. package/packages/theme-chalk/src/label.scss +24 -24
  230. package/packages/theme-chalk/src/layout.scss +46 -46
  231. package/packages/theme-chalk/src/login.scss +987 -987
  232. package/packages/theme-chalk/src/main.scss +663 -663
  233. package/packages/theme-chalk/src/menu.scss +224 -224
  234. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  235. package/packages/theme-chalk/src/nav.scss +111 -111
  236. package/packages/theme-chalk/src/page.scss +3 -3
  237. package/packages/theme-chalk/src/pagination.scss +29 -29
  238. package/packages/theme-chalk/src/player.scss +9 -9
  239. package/packages/theme-chalk/src/qr-code.scss +17 -17
  240. package/packages/theme-chalk/src/radio-group.scss +9 -9
  241. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  242. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  243. package/packages/theme-chalk/src/select.scss +8 -8
  244. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  245. package/packages/theme-chalk/src/selector.scss +92 -92
  246. package/packages/theme-chalk/src/simplicity.scss +1370 -1370
  247. package/packages/theme-chalk/src/sizer.scss +36 -36
  248. package/packages/theme-chalk/src/steps.scss +88 -88
  249. package/packages/theme-chalk/src/switch.scss +3 -3
  250. package/packages/theme-chalk/src/table-form.scss +1 -1
  251. package/packages/theme-chalk/src/tabs.scss +87 -87
  252. package/packages/theme-chalk/src/tips.scss +7 -7
  253. package/packages/theme-chalk/src/toolbar.scss +179 -179
  254. package/packages/theme-chalk/src/tree-group.scss +72 -72
  255. package/packages/theme-chalk/src/tree.scss +165 -165
  256. package/packages/theme-chalk/src/upload.scss +172 -172
  257. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  258. package/packages/tips/index.js +5 -5
  259. package/packages/tips/src/main.vue +141 -141
  260. package/packages/toolbar/index.js +5 -5
  261. package/packages/toolbar/src/main.vue +430 -430
  262. package/packages/tree/index.js +5 -5
  263. package/packages/tree-group/index.js +5 -5
  264. package/packages/upload/.DS_Store +0 -0
  265. package/packages/upload/index.js +5 -5
  266. package/packages/upload/src/main.vue +1343 -1343
  267. package/packages/upload/src/picture.js +15 -15
  268. package/packages/wujie/index.js +5 -5
  269. package/packages/wujie/src/main.vue +145 -145
  270. package/packages/wxlogin/index.js +5 -5
  271. package/packages/wxlogin/src/main.vue +128 -128
  272. package/src/.DS_Store +0 -0
  273. package/src/config/api.js +315 -315
  274. package/src/config/image.js +2 -2
  275. package/src/index.js +163 -163
  276. package/src/utils/.DS_Store +0 -0
  277. package/src/utils/bus.js +3 -3
  278. package/src/utils/date-util.js +312 -312
  279. package/src/utils/http.js +50 -50
  280. package/src/utils/rules.js +18 -18
  281. package/src/utils/store.js +21 -21
  282. package/src/utils/util.js +31 -12
  283. package/src/utils/webSocket.js +107 -107
@@ -1,82 +1,82 @@
1
- <template>
2
- <div class="es-simplicity-side-item es-simplicity-portrait">
3
- <!-- <img class="es-simplicity-portrait-image" :src="_userHead" /> -->
4
-
5
- <el-avatar
6
- class="es-simplicity-portrait-image"
7
- :src="_userHead"
8
- :size="size"
9
- >
10
- <img
11
- src=""
12
- />
13
- </el-avatar>
14
- <es-upload
15
- v-if="upload"
16
- portrait
17
- :request-files="false"
18
- :code="code"
19
- :ownId="user.personId"
20
- :on-success="handleSuccess"
21
- >
22
- <span>修改头像</span>
23
- </es-upload>
24
- </div>
25
- </template>
26
-
27
- <script>
28
- import util from 'eoss-ui/src/utils/util';
29
- import { downloadByAdjunctId } from 'eoss-ui/src/config/api.js';
30
- export default {
31
- name: 'Avatar',
32
- components: {},
33
- props: {
34
- size: {
35
- type: Number,
36
- default: 48
37
- },
38
- user: {
39
- type: Object,
40
- default() {
41
- return {};
42
- }
43
- },
44
- code: {
45
- String,
46
- default: 'USER_IMG'
47
- },
48
- upload: Boolean
49
- },
50
- data() {
51
- return {
52
- userHead: null,
53
- portrait: true
54
- };
55
- },
56
- computed: {
57
- //用户头像
58
- _userHead() {
59
- return this.userHead ? this.userHead : this.user.userHeadUrl;
60
- }
61
- },
62
- watch: {},
63
- created() {},
64
- mounted() {},
65
- methods: {
66
- handleSuccess(response, file, files, dochubConfig) {
67
- const res = file.response;
68
- if (res.url && util.startWith(res.url, ['http', 'https', '/'])) {
69
- this.userHead = res.url;
70
- } else {
71
- this.userHead =
72
- dochubConfig && dochubConfig.downloadDocumentUrl
73
- ? `${dochubConfig.downloadDocumentUrl}?documentId=${res.adjunctId}`
74
- : downloadByAdjunctId + '?adjunctId=' + res.adjunctId;
75
- }
76
- this.$emit('change', this.userHead);
77
- }
78
- }
79
- };
80
- </script>
81
-
82
- <style lang="scss" scoped></style>
1
+ <template>
2
+ <div class="es-simplicity-side-item es-simplicity-portrait">
3
+ <!-- <img class="es-simplicity-portrait-image" :src="_userHead" /> -->
4
+
5
+ <el-avatar
6
+ class="es-simplicity-portrait-image"
7
+ :src="_userHead"
8
+ :size="size"
9
+ >
10
+ <img
11
+ src=""
12
+ />
13
+ </el-avatar>
14
+ <es-upload
15
+ v-if="upload"
16
+ portrait
17
+ :request-files="false"
18
+ :code="code"
19
+ :ownId="user.personId"
20
+ :on-success="handleSuccess"
21
+ >
22
+ <span>修改头像</span>
23
+ </es-upload>
24
+ </div>
25
+ </template>
26
+
27
+ <script>
28
+ import util from 'eoss-ui/src/utils/util';
29
+ import { downloadByAdjunctId } from 'eoss-ui/src/config/api.js';
30
+ export default {
31
+ name: 'Avatar',
32
+ components: {},
33
+ props: {
34
+ size: {
35
+ type: Number,
36
+ default: 48
37
+ },
38
+ user: {
39
+ type: Object,
40
+ default() {
41
+ return {};
42
+ }
43
+ },
44
+ code: {
45
+ String,
46
+ default: 'USER_IMG'
47
+ },
48
+ upload: Boolean
49
+ },
50
+ data() {
51
+ return {
52
+ userHead: null,
53
+ portrait: true
54
+ };
55
+ },
56
+ computed: {
57
+ //用户头像
58
+ _userHead() {
59
+ return this.userHead ? this.userHead : this.user.userHeadUrl;
60
+ }
61
+ },
62
+ watch: {},
63
+ created() {},
64
+ mounted() {},
65
+ methods: {
66
+ handleSuccess(response, file, files, dochubConfig) {
67
+ const res = file.response;
68
+ if (res.url && util.startWith(res.url, ['http', 'https', '/'])) {
69
+ this.userHead = res.url;
70
+ } else {
71
+ this.userHead =
72
+ dochubConfig && dochubConfig.downloadDocumentUrl
73
+ ? `${dochubConfig.downloadDocumentUrl}?documentId=${res.adjunctId}`
74
+ : downloadByAdjunctId + '?adjunctId=' + res.adjunctId;
75
+ }
76
+ this.$emit('change', this.userHead);
77
+ }
78
+ }
79
+ };
80
+ </script>
81
+
82
+ <style lang="scss" scoped></style>
@@ -1,263 +1,144 @@
1
- <template>
2
- <div class="es-simplicity-handler">
3
- <template v-for="item in lists">
4
- <div
5
- v-if="item.type == 'contact'"
6
- class="es-simplicity-contact"
7
- :key="item.type"
8
- >
9
- <div class="es-contact-label">{{ item.label }}</div>
10
- <div class="es-contact-content">
11
- <div v-for="ele in item.content" :key="ele">{{ ele }}</div>
12
- </div>
13
- </div>
14
- <div
15
- class="es-simplicity-date-time"
16
- v-else-if="item.type === 'dateTime'"
17
- :key="item.type"
18
- >
19
- <div class="es-simplicity-handler-time">
20
- {{ time }}
21
- </div>
22
- <div class="es-simplicity-handler-date">
23
- {{ date }}
24
- </div>
25
- </div>
26
- <div
27
- v-else-if="item.type === 'online' || item.type === 'onlineUser'"
28
- class="es-simplicity-online"
29
- :key="item.type"
30
- >
31
- 当前
32
- <span
33
- class="es-simplicity-online-num"
34
- @click="isClick ? handleClick({ type: 'online' }) : ''"
35
- :class="{ 'es-pointer': isClick }"
36
- >
37
- {{ online }}
38
- </span>
39
- 人在线
40
- </div>
41
- <el-tooltip
42
- v-else
43
- :key="item.type"
44
- effect="dark"
45
- :content="item.title"
46
- placement="bottom"
47
- >
48
- <el-badge
49
- class="es-simplicity-handler-item"
50
- v-if="item.type === 'notice' || item.type === 'messsage'"
51
- :value="noticeNum"
52
- :max="99"
53
- :hidden="noticeNum < 1"
54
- >
55
- <es-icon
56
- class="es-simplicity-handler-icon"
57
- @click.stop="handleClick(item)"
58
- :contents="item.icon"
59
- ></es-icon>
60
- </el-badge>
61
- <es-icon
62
- v-else
63
- class="es-simplicity-handler-item es-simplicity-handler-icon"
64
- @click.stop="handleClick(item)"
65
- :contents="item.icon"
66
- ></es-icon>
67
- </el-tooltip>
68
- </template>
69
- </div>
70
- </template>
71
-
72
- <script>
73
- import util from 'eoss-ui/src/utils/util';
74
- export default {
75
- name: 'Handler',
76
- components: {},
77
- props: {
78
- contact: Object,
79
- dateTime: {
80
- type: [Boolean, Object],
81
- default() {
82
- return { type: 'dateTime' };
83
- },
84
- validator: (val) => {
85
- return val === false || typeof val === 'object';
86
- }
87
- },
88
- onlineUser: {
89
- type: [Boolean, Object],
90
- default() {
91
- return { type: 'onlineUser' };
92
- },
93
- validator: (val) => {
94
- return val === false || typeof val === 'object';
95
- }
96
- },
97
- search: {
98
- type: [Boolean, Object],
99
- default() {
100
- return {
101
- type: 'search',
102
- icon: 'es-icon-magnifier',
103
- title: '搜索'
104
- };
105
- },
106
- validator: (val) => {
107
- return val === false || typeof val === 'object';
108
- }
109
- },
110
- im: {
111
- type: [Boolean, Object],
112
- default() {
113
- return {
114
- type: 'im',
115
- icon: 'es-icon-liaotian',
116
- title: 'IM'
117
- };
118
- },
119
- validator: (val) => {
120
- return val === false || typeof val === 'object';
121
- }
122
- },
123
- index: {
124
- type: [Boolean, Object],
125
- default() {
126
- return {
127
- type: 'index',
128
- icon: 'es-icon-home',
129
- title: '门户'
130
- };
131
- },
132
- validator: (val) => {
133
- return val === false || typeof val === 'object';
134
- }
135
- },
136
- home: {
137
- type: [Boolean, Object],
138
- default() {
139
- return {
140
- type: 'home',
141
- icon: 'es-icon-zuomian',
142
- title: '个人工作台'
143
- };
144
- }
145
- },
146
- notice: {
147
- type: [Boolean, Object],
148
- default() {
149
- return {
150
- type: 'notice',
151
- icon: 'es-icon-tongzhi',
152
- title: '通知消息'
153
- };
154
- }
155
- },
156
- quit: {
157
- type: [Boolean, Object],
158
- default() {
159
- return {
160
- type: 'quit',
161
- icon: 'es-icon-guanji',
162
- title: '退出'
163
- };
164
- }
165
- },
166
- set: {
167
- type: [Boolean, Object],
168
- default() {
169
- return {
170
- type: 'set',
171
- icon: 'es-icon-xitongguanli',
172
- title: '设置'
173
- };
174
- },
175
- validator: (val) => {
176
- return val === false || typeof val === 'object';
177
- }
178
- },
179
- data: Array,
180
- hide: {
181
- type: Object,
182
- default() {
183
- return {};
184
- }
185
- },
186
- msgNum: {
187
- type: Number,
188
- default: 0
189
- },
190
- noticeNum: {
191
- type: Number,
192
- default: 0
193
- },
194
- online: {
195
- type: Number,
196
- default: 1
197
- }
198
- },
199
- data() {
200
- return {
201
- time: '',
202
- date: '',
203
- timer: null
204
- };
205
- },
206
- computed: {
207
- lists() {
208
- let hide = {
209
- old: true,
210
- im: true,
211
- ...this.hide
212
- };
213
- let data = this.data
214
- ? this.data
215
- : [
216
- this.contact ? { ...this.contact, type: 'contact' } : {},
217
- this.dateTime,
218
- this.onlineUser,
219
- this.search,
220
- this.im,
221
- this.index,
222
- this.home,
223
- this.notice,
224
- this.quit,
225
- this.set
226
- ];
227
- return data.filter((item) => {
228
- return (
229
- item && Object.keys(item).length && !item.hide && !hide[item.type]
230
- );
231
- });
232
- },
233
- isClick() {
234
- let useCaseCodes = util.getStorage('useCaseCodes');
235
- return useCaseCodes && useCaseCodes.includes('sys_user_onlineList');
236
- }
237
- },
238
- watch: {},
239
- created() {
240
- //this.time = util.timeCycle() + '好!';
241
- this.date = util.formatDate('', 'yyyy年M月d日');
242
- },
243
- mounted() {
244
- this.getTime();
245
- },
246
- methods: {
247
- getTime() {
248
- this.timer && clearInterval(this.timer);
249
- this.timer = setInterval(() => {
250
- this.time = util.formatDate('', 'HH:mm:ss');
251
- });
252
- },
253
- handleClick(res) {
254
- this.$emit('click', res);
255
- }
256
- },
257
- beforeDestroy() {
258
- clearInterval(this.timer);
259
- }
260
- };
261
- </script>
262
-
263
- <style lang="scss" scoped></style>
1
+ <template>
2
+ <div class="es-simplicity-handler">
3
+ <template v-for="item in data">
4
+ <div
5
+ v-if="item.type == 'contact'"
6
+ class="es-simplicity-contact"
7
+ :key="item.type"
8
+ >
9
+ <div class="es-contact-label">{{ item.label }}</div>
10
+ <div class="es-contact-content">
11
+ <div v-for="ele in item.content" :key="ele">{{ ele }}</div>
12
+ </div>
13
+ </div>
14
+ <div
15
+ class="es-simplicity-date-time"
16
+ v-else-if="item.type === 'dateTime'"
17
+ :key="item.type"
18
+ >
19
+ <div class="es-simplicity-handler-time">
20
+ {{ time }}
21
+ </div>
22
+ <div class="es-simplicity-handler-date">
23
+ {{ date }}
24
+ </div>
25
+ </div>
26
+ <div
27
+ v-else-if="item.type === 'online' || item.type === 'onlineUser'"
28
+ class="es-simplicity-online"
29
+ :key="item.type"
30
+ >
31
+ 当前
32
+ <span
33
+ class="es-simplicity-online-num"
34
+ @click="isClick ? handleClick({ type: 'online' }) : ''"
35
+ :class="{ 'es-pointer': isClick }"
36
+ >
37
+ {{ nums[item.type] }}
38
+ </span>
39
+ 人在线
40
+ </div>
41
+ <el-tooltip
42
+ v-else-if="showTitleType === 'tooltip'"
43
+ :key="item.type"
44
+ effect="dark"
45
+ :content="item.title"
46
+ placement="bottom"
47
+ >
48
+ <el-badge
49
+ class="es-simplicity-handler-item"
50
+ :hidden="!nums[item.type] && !item.num"
51
+ :value="nums[item.type] || item.num || 0"
52
+ :max="99"
53
+ >
54
+ <es-icon
55
+ class="es-simplicity-handler-icon"
56
+ @click.stop="handleClick(item)"
57
+ :contents="item.icon"
58
+ ></es-icon>
59
+ </el-badge>
60
+ </el-tooltip>
61
+ <div class="es-simplicity-handler-item" v-else :key="item.type">
62
+ <el-badge
63
+ class="es-simplicity-handler-item"
64
+ :hidden="!nums[item.type] && !item.num"
65
+ :value="nums[item.type] || item.num || 0"
66
+ :max="99"
67
+ >
68
+ <es-icon
69
+ class="es-simplicity-handler-icon"
70
+ @click.stop="handleClick(item)"
71
+ :contents="item.icon"
72
+ ></es-icon>
73
+ </el-badge>
74
+ <span class="" v-if="showTitleType === 'text'">{{ item.title }}</span>
75
+ </div>
76
+ </template>
77
+ </div>
78
+ </template>
79
+
80
+ <script>
81
+ import util from 'eoss-ui/src/utils/util';
82
+ export default {
83
+ name: 'Handler',
84
+ components: {},
85
+ props: {
86
+ data: {
87
+ type: Array,
88
+ default() {
89
+ return [];
90
+ }
91
+ },
92
+ nums: {
93
+ type: Object,
94
+ default() {
95
+ return {};
96
+ }
97
+ },
98
+ showTitleType: {
99
+ type: String,
100
+ default: 'tooltip',
101
+ validator: (val) => {
102
+ return val === 'text' || val === 'tooltip';
103
+ }
104
+ }
105
+ },
106
+ data() {
107
+ return {
108
+ time: '',
109
+ date: '',
110
+ timer: null
111
+ };
112
+ },
113
+ computed: {
114
+ isClick() {
115
+ let useCaseCodes = util.getStorage('useCaseCodes');
116
+ return useCaseCodes && useCaseCodes.includes('sys_user_onlineList');
117
+ }
118
+ },
119
+ watch: {},
120
+ created() {
121
+ //this.time = util.timeCycle() + '好!';
122
+ this.date = util.formatDate('', 'yyyy年M月d日');
123
+ },
124
+ mounted() {
125
+ this.getTime();
126
+ },
127
+ methods: {
128
+ getTime() {
129
+ this.timer && clearInterval(this.timer);
130
+ this.timer = setInterval(() => {
131
+ this.time = util.formatDate('', 'HH:mm:ss');
132
+ });
133
+ },
134
+ handleClick(res) {
135
+ this.$emit('click', res);
136
+ }
137
+ },
138
+ beforeDestroy() {
139
+ clearInterval(this.timer);
140
+ }
141
+ };
142
+ </script>
143
+
144
+ <style lang="scss" scoped></style>