eoss-ui 0.7.53 → 0.7.55

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 (306) hide show
  1. package/lib/button-group.js +2 -2
  2. package/lib/button.js +2 -2
  3. package/lib/calogin.js +235 -235
  4. package/lib/checkbox-group.js +2 -2
  5. package/lib/config/api.js +1 -1
  6. package/lib/data-table-form.js +2 -2
  7. package/lib/data-table.js +2 -2
  8. package/lib/date-picker.js +2 -2
  9. package/lib/dialog.js +2 -2
  10. package/lib/eoss-ui.common.js +882 -795
  11. package/lib/flow-group.js +2 -2
  12. package/lib/flow-list.js +83 -83
  13. package/lib/flow.js +294 -292
  14. package/lib/form.js +2 -2
  15. package/lib/handle-user.js +2 -2
  16. package/lib/handler.js +2 -2
  17. package/lib/icon.js +2 -2
  18. package/lib/icons.js +1 -1
  19. package/lib/index.js +1 -1
  20. package/lib/input-number.js +2 -2
  21. package/lib/input.js +2 -2
  22. package/lib/login.js +6 -6
  23. package/lib/main.js +238 -153
  24. package/lib/nav.js +2 -2
  25. package/lib/notify.js +2 -2
  26. package/lib/page.js +2 -2
  27. package/lib/pagination.js +2 -2
  28. package/lib/player.js +2 -2
  29. package/lib/qr-code.js +15 -15
  30. package/lib/radio-group.js +2 -2
  31. package/lib/retrial-auth.js +2 -2
  32. package/lib/select-ganged.js +2 -2
  33. package/lib/select.js +2 -2
  34. package/lib/selector-panel.js +2 -2
  35. package/lib/selector.js +2 -2
  36. package/lib/sizer.js +2 -2
  37. package/lib/steps.js +2 -2
  38. package/lib/switch.js +2 -2
  39. package/lib/table-form.js +2 -2
  40. package/lib/tabs.js +2 -2
  41. package/lib/theme-chalk/base.css +1 -1
  42. package/lib/theme-chalk/fonts/iconfont.ttf +0 -0
  43. package/lib/theme-chalk/fonts/iconfont.woff +0 -0
  44. package/lib/theme-chalk/icon.css +1 -1
  45. package/lib/theme-chalk/index.css +1 -1
  46. package/lib/theme-chalk/main.css +1 -1
  47. package/lib/theme-chalk/menu.css +1 -1
  48. package/lib/theme-chalk/simplicity.css +1 -1
  49. package/lib/theme-chalk/sizer.css +1 -1
  50. package/lib/theme-chalk/upload.css +1 -1
  51. package/lib/tips.js +2 -2
  52. package/lib/tree-group.js +2 -2
  53. package/lib/tree.js +2 -2
  54. package/lib/upload.js +15 -15
  55. package/lib/wujie.js +2 -2
  56. package/lib/wxlogin.js +2 -2
  57. package/package.json +160 -160
  58. package/packages/.DS_Store +0 -0
  59. package/packages/button/index.js +5 -5
  60. package/packages/button/src/main.vue +418 -418
  61. package/packages/button-group/index.js +5 -5
  62. package/packages/button-group/src/main.vue +346 -346
  63. package/packages/calendar/index.js +5 -5
  64. package/packages/calogin/.DS_Store +0 -0
  65. package/packages/calogin/index.js +5 -5
  66. package/packages/calogin/src/main.vue +412 -412
  67. package/packages/calogin/src/plugin.js +915 -915
  68. package/packages/card/index.js +5 -5
  69. package/packages/card/src/main.vue +156 -156
  70. package/packages/cascader/index.js +5 -5
  71. package/packages/cascader/src/main.vue +168 -168
  72. package/packages/checkbox-group/index.js +5 -5
  73. package/packages/checkbox-group/src/main.vue +333 -333
  74. package/packages/clients/index.js +5 -5
  75. package/packages/clients/src/main.vue +151 -151
  76. package/packages/data-table/index.js +5 -5
  77. package/packages/data-table/src/children.vue +39 -39
  78. package/packages/data-table/src/column.vue +992 -992
  79. package/packages/data-table/src/main.vue +1840 -1840
  80. package/packages/data-table/src/sizer.vue +195 -195
  81. package/packages/data-table-form/index.js +5 -5
  82. package/packages/data-table-form/src/checkbox.vue +101 -101
  83. package/packages/data-table-form/src/colgroup.vue +17 -17
  84. package/packages/data-table-form/src/main.vue +181 -181
  85. package/packages/data-table-form/src/radio.vue +65 -65
  86. package/packages/data-table-form/src/table.vue +233 -233
  87. package/packages/data-table-form/src/tbody.vue +336 -336
  88. package/packages/data-table-form/src/thead.vue +68 -68
  89. package/packages/date-picker/.DS_Store +0 -0
  90. package/packages/date-picker/index.js +5 -5
  91. package/packages/date-picker/src/.DS_Store +0 -0
  92. package/packages/date-picker/src/main.vue +236 -236
  93. package/packages/dialog/.DS_Store +0 -0
  94. package/packages/dialog/index.js +5 -5
  95. package/packages/enable-drag/index.js +5 -5
  96. package/packages/enterprise/index.js +5 -5
  97. package/packages/enterprise/src/main.vue +66 -66
  98. package/packages/error-page/index.js +5 -5
  99. package/packages/error-page/src/main.vue +44 -44
  100. package/packages/flow/.DS_Store +0 -0
  101. package/packages/flow/index.js +5 -5
  102. package/packages/flow/src/.DS_Store +0 -0
  103. package/packages/flow/src/component/Circulate.vue +413 -413
  104. package/packages/flow/src/component/CommonOpinions.vue +373 -373
  105. package/packages/flow/src/component/CustomPreset.vue +322 -322
  106. package/packages/flow/src/component/FileList.vue +97 -97
  107. package/packages/flow/src/component/FreeCirculation.vue +241 -240
  108. package/packages/flow/src/component/Preset.vue +255 -255
  109. package/packages/flow/src/component/SendMsg.vue +242 -242
  110. package/packages/flow/src/component/TimeLimit.vue +190 -190
  111. package/packages/flow/src/component/taskUnionExamine.vue +756 -756
  112. package/packages/flow/src/form.vue +121 -121
  113. package/packages/flow/src/freeStartFlow.vue +2846 -2846
  114. package/packages/flow/src/main.vue +3878 -3878
  115. package/packages/flow/src/processForm.vue +1365 -1365
  116. package/packages/flow/src/processReject.vue +309 -309
  117. package/packages/flow/src/reset.vue +942 -942
  118. package/packages/flow/src/startTaskRead.vue +692 -692
  119. package/packages/flow/src/supervise.vue +159 -159
  120. package/packages/flow/src/table.vue +58 -58
  121. package/packages/flow-group/index.js +5 -5
  122. package/packages/flow-group/src/main.vue +717 -717
  123. package/packages/flow-list/.DS_Store +0 -0
  124. package/packages/flow-list/index.js +5 -5
  125. package/packages/flow-list/src/main.vue +1801 -1801
  126. package/packages/form/.DS_Store +0 -0
  127. package/packages/form/index.js +5 -5
  128. package/packages/form/src/main.vue +3901 -3901
  129. package/packages/form/src/table.vue +1512 -1512
  130. package/packages/handle-user/index.js +5 -5
  131. package/packages/handle-user/src/main.vue +137 -137
  132. package/packages/handler/index.js +5 -5
  133. package/packages/handler/src/main.vue +496 -496
  134. package/packages/icon/.DS_Store +0 -0
  135. package/packages/icon/index.js +5 -5
  136. package/packages/icon/src/main.vue +104 -104
  137. package/packages/icons/index.js +5 -5
  138. package/packages/icons/src/icon.json +1 -1
  139. package/packages/icons/src/main.vue +81 -81
  140. package/packages/input/index.js +5 -5
  141. package/packages/input/src/main.vue +356 -356
  142. package/packages/input-number/index.js +5 -5
  143. package/packages/input-number/src/main.vue +106 -106
  144. package/packages/label/index.js +5 -5
  145. package/packages/label/src/main.vue +457 -457
  146. package/packages/layout/index.js +5 -5
  147. package/packages/layout/src/item.vue +152 -152
  148. package/packages/layout/src/main.vue +31 -31
  149. package/packages/login/.DS_Store +0 -0
  150. package/packages/login/index.js +5 -5
  151. package/packages/login/src/main.vue +2082 -2082
  152. package/packages/login/src/resetPassword.vue +557 -557
  153. package/packages/main/.DS_Store +0 -0
  154. package/packages/main/index.js +5 -5
  155. package/packages/main/src/.DS_Store +0 -0
  156. package/packages/main/src/default/message.vue +249 -249
  157. package/packages/main/src/default/notice.vue +157 -157
  158. package/packages/main/src/default/userinfo.vue +503 -503
  159. package/packages/main/src/public/online.vue +89 -89
  160. package/packages/main/src/public/search.vue +464 -464
  161. package/packages/main/src/public/settings.vue +227 -227
  162. package/packages/main/src/simplicity/apps.vue +388 -388
  163. package/packages/main/src/simplicity/avatar.vue +82 -82
  164. package/packages/main/src/simplicity/handler.vue +160 -160
  165. package/packages/main/src/simplicity/index.vue +2307 -2277
  166. package/packages/main/src/simplicity/lists.vue +84 -84
  167. package/packages/main/src/simplicity/menu-list.vue +135 -135
  168. package/packages/main/src/simplicity/message.vue +293 -293
  169. package/packages/main/src/simplicity/notice.vue +222 -222
  170. package/packages/main/src/simplicity/router-page.vue +45 -45
  171. package/packages/main/src/simplicity/sub-menu.vue +274 -274
  172. package/packages/main/src/simplicity/user.vue +259 -259
  173. package/packages/main/src/simplicity/userinfo.vue +401 -401
  174. package/packages/menu/.DS_Store +0 -0
  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/.DS_Store +0 -0
  194. package/packages/select/index.js +5 -5
  195. package/packages/select/src/main.vue +782 -782
  196. package/packages/select-ganged/index.js +5 -5
  197. package/packages/select-ganged/src/main.vue +724 -724
  198. package/packages/selector/.DS_Store +0 -0
  199. package/packages/selector/index.js +5 -5
  200. package/packages/selector/src/main.vue +761 -761
  201. package/packages/selector-panel/.DS_Store +0 -0
  202. package/packages/selector-panel/index.js +5 -5
  203. package/packages/selector-panel/src/main.vue +1027 -1027
  204. package/packages/selector-panel/src/selection.vue +170 -170
  205. package/packages/selector-panel/src/tree.vue +129 -129
  206. package/packages/sizer/index.js +5 -5
  207. package/packages/sizer/src/main.vue +254 -254
  208. package/packages/steps/index.js +5 -5
  209. package/packages/steps/src/main.vue +181 -181
  210. package/packages/switch/index.js +5 -5
  211. package/packages/switch/src/main.vue +170 -170
  212. package/packages/table-form/index.js +5 -5
  213. package/packages/tabs/index.js +5 -5
  214. package/packages/tabs/src/main.vue +788 -788
  215. package/packages/tabs-panel/index.js +5 -5
  216. package/packages/tabs-panel/src/main.vue +29 -29
  217. package/packages/theme-chalk/lib/base.css +1 -1
  218. package/packages/theme-chalk/lib/fonts/iconfont.ttf +0 -0
  219. package/packages/theme-chalk/lib/fonts/iconfont.woff +0 -0
  220. package/packages/theme-chalk/lib/icon.css +1 -1
  221. package/packages/theme-chalk/lib/index.css +1 -1
  222. package/packages/theme-chalk/lib/main.css +1 -1
  223. package/packages/theme-chalk/lib/menu.css +1 -1
  224. package/packages/theme-chalk/lib/simplicity.css +1 -1
  225. package/packages/theme-chalk/lib/sizer.css +1 -1
  226. package/packages/theme-chalk/lib/upload.css +1 -1
  227. package/packages/theme-chalk/src/.DS_Store +0 -0
  228. package/packages/theme-chalk/src/base.scss +261 -261
  229. package/packages/theme-chalk/src/button-group.scss +176 -176
  230. package/packages/theme-chalk/src/button.scss +24 -24
  231. package/packages/theme-chalk/src/calendar.scss +113 -113
  232. package/packages/theme-chalk/src/card.scss +99 -99
  233. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  234. package/packages/theme-chalk/src/clients.scss +87 -87
  235. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  236. package/packages/theme-chalk/src/data-table.scss +297 -297
  237. package/packages/theme-chalk/src/date-picker.scss +7 -7
  238. package/packages/theme-chalk/src/dialog.scss +77 -77
  239. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  240. package/packages/theme-chalk/src/enterprise.scss +5 -5
  241. package/packages/theme-chalk/src/error-page.scss +18 -18
  242. package/packages/theme-chalk/src/flow-group.scss +110 -110
  243. package/packages/theme-chalk/src/flow-list.scss +39 -39
  244. package/packages/theme-chalk/src/flow.scss +351 -351
  245. package/packages/theme-chalk/src/fonts/iconfont.ttf +0 -0
  246. package/packages/theme-chalk/src/fonts/iconfont.woff +0 -0
  247. package/packages/theme-chalk/src/form.scss +501 -501
  248. package/packages/theme-chalk/src/handle-user.scss +40 -40
  249. package/packages/theme-chalk/src/handler.scss +148 -148
  250. package/packages/theme-chalk/src/icon.scss +1608 -1540
  251. package/packages/theme-chalk/src/icons.scss +99 -99
  252. package/packages/theme-chalk/src/input.scss +9 -9
  253. package/packages/theme-chalk/src/label.scss +24 -24
  254. package/packages/theme-chalk/src/layout.scss +46 -46
  255. package/packages/theme-chalk/src/login.scss +1006 -1006
  256. package/packages/theme-chalk/src/main.scss +663 -663
  257. package/packages/theme-chalk/src/menu.scss +224 -224
  258. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  259. package/packages/theme-chalk/src/nav.scss +111 -111
  260. package/packages/theme-chalk/src/page.scss +3 -3
  261. package/packages/theme-chalk/src/pagination.scss +29 -29
  262. package/packages/theme-chalk/src/player.scss +9 -9
  263. package/packages/theme-chalk/src/qr-code.scss +17 -17
  264. package/packages/theme-chalk/src/radio-group.scss +9 -9
  265. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  266. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  267. package/packages/theme-chalk/src/select.scss +8 -8
  268. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  269. package/packages/theme-chalk/src/selector.scss +114 -114
  270. package/packages/theme-chalk/src/simplicity.scss +1404 -1395
  271. package/packages/theme-chalk/src/sizer.scss +36 -36
  272. package/packages/theme-chalk/src/steps.scss +88 -88
  273. package/packages/theme-chalk/src/switch.scss +3 -3
  274. package/packages/theme-chalk/src/table-form.scss +1 -1
  275. package/packages/theme-chalk/src/tabs.scss +87 -87
  276. package/packages/theme-chalk/src/tips.scss +7 -7
  277. package/packages/theme-chalk/src/toolbar.scss +179 -179
  278. package/packages/theme-chalk/src/tree-group.scss +72 -72
  279. package/packages/theme-chalk/src/tree.scss +165 -165
  280. package/packages/theme-chalk/src/upload.scss +172 -172
  281. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  282. package/packages/tips/index.js +5 -5
  283. package/packages/tips/src/main.vue +141 -141
  284. package/packages/toolbar/index.js +5 -5
  285. package/packages/toolbar/src/main.vue +430 -430
  286. package/packages/tree/index.js +5 -5
  287. package/packages/tree-group/index.js +5 -5
  288. package/packages/upload/.DS_Store +0 -0
  289. package/packages/upload/index.js +5 -5
  290. package/packages/upload/src/main.vue +1344 -1344
  291. package/packages/upload/src/picture.js +15 -15
  292. package/packages/wujie/index.js +5 -5
  293. package/packages/wujie/src/main.vue +145 -145
  294. package/packages/wxlogin/index.js +5 -5
  295. package/packages/wxlogin/src/main.vue +128 -128
  296. package/src/.DS_Store +0 -0
  297. package/src/config/api.js +317 -317
  298. package/src/config/image.js +2 -2
  299. package/src/index.js +163 -163
  300. package/src/utils/.DS_Store +0 -0
  301. package/src/utils/bus.js +3 -3
  302. package/src/utils/date-util.js +312 -312
  303. package/src/utils/http.js +50 -50
  304. package/src/utils/rules.js +18 -18
  305. package/src/utils/store.js +21 -21
  306. package/src/utils/webSocket.js +107 -107
@@ -1,346 +1,346 @@
1
- <template>
2
- <el-button-group class="es-button-group">
3
- <template v-if="length > 1">
4
- <template v-for="(item, index) in showBtns">
5
- <template v-if="item && !item.hide">
6
- <es-upload
7
- v-if="item.upload || (item.code && item.ownId)"
8
- :key="index"
9
- v-bind="{
10
- ...exclAttribute({
11
- data: item,
12
- attrs: ['events']
13
- }),
14
- ...parseProps(),
15
- method: 'post',
16
- btnSize: size,
17
- showFileList: false,
18
- selectType: mode == 'plus' ? 'text' : item.type
19
- }"
20
- v-on="item.events"
21
- ></es-upload>
22
- <el-tooltip
23
- :key="index"
24
- v-else-if="item.showTooltip"
25
- :effect="item.effect ? item.effect : 'dark'"
26
- :content="item.tips"
27
- :placement="item.placement ? item.placement : 'top'"
28
- >
29
- <es-button
30
- :stop="stop"
31
- :data="data"
32
- :outside="outside"
33
- v-bind="
34
- exclAttribute({
35
- data: item,
36
- attrs: ['events']
37
- })
38
- "
39
- :size="size"
40
- :type="mode == 'plus' ? 'text' : item.type"
41
- v-on="item.events"
42
- @click="handleClick({ ...data, handle: item })"
43
- >
44
- {{
45
- item.template
46
- ? item.template({ ...data, config: item })
47
- : item.text
48
- }}
49
- </es-button>
50
- </el-tooltip>
51
- <es-button
52
- v-else
53
- :stop="stop"
54
- :data="data"
55
- :outside="outside"
56
- v-bind="
57
- exclAttribute({
58
- data: item,
59
- attrs: ['events']
60
- })
61
- "
62
- :key="index"
63
- :size="size"
64
- :type="mode == 'plus' ? 'text' : item.type"
65
- v-on="item.events"
66
- @click="handleClick({ ...data, handle: item })"
67
- >
68
- {{
69
- item.template
70
- ? item.template({ ...data, config: item })
71
- : item.text
72
- }}
73
- </es-button>
74
- </template>
75
- </template>
76
- </template>
77
- <el-dropdown
78
- v-if="other.length > 0"
79
- ref="dropdown"
80
- @command="handleCommand"
81
- @visible-change="handleChange"
82
- :trigger="trigger"
83
- >
84
- <el-button :size="size" :type="mode == 'plus' ? 'text' : ''">
85
- <el-badge v-bind="badges">
86
- <template v-if="mode == 'plus'">更多</template>
87
- <template v-else-if="moreText">
88
- {{ moreText }}
89
- <i
90
- :class="{
91
- 'el-icon-arrow-down': !show,
92
- 'el-icon-arrow-up': show
93
- }"
94
- ></i>
95
- </template>
96
- <i v-else class="es-icon-more"></i>
97
- </el-badge>
98
- </el-button>
99
- <el-dropdown-menu slot="dropdown">
100
- <el-dropdown-item
101
- v-for="(item, index) in other"
102
- :key="index"
103
- :command="item"
104
- :class="{ 'es-dropdown-padding': item.upload || item.selector }"
105
- v-show="!item.hide"
106
- >
107
- <es-upload
108
- v-if="item.upload || (item.code && item.ownId)"
109
- class="es-dropdown-upload"
110
- v-bind="{
111
- ...exclAttribute({
112
- data: item,
113
- attrs: ['events']
114
- }),
115
- ...parseProps(),
116
- method: 'post',
117
- showFileList: false,
118
- selectType: 'text'
119
- }"
120
- v-on="item.events"
121
- ></es-upload>
122
- <es-selector
123
- v-else-if="item.selector"
124
- class="es-dropdown-selector"
125
- v-bind="{
126
- reset: true,
127
- ...exclAttribute({
128
- data: item,
129
- attrs: ['events', 'type', 'value']
130
- }),
131
- businessData: data
132
- }"
133
- v-on="item.events"
134
- :button="{ size: 'medium', type: 'text' }"
135
- >
136
- <i :class="item.icon" v-if="item.icon"></i
137
- >{{
138
- item.template
139
- ? item.template({ ...data, config: item })
140
- : item.text
141
- }}
142
- </es-selector>
143
- <el-tooltip
144
- :key="index"
145
- v-else-if="item.showTooltip"
146
- :effect="item.effect ? item.effect : 'dark'"
147
- :content="item.tips"
148
- :placement="item.placement ? item.placement : 'top'"
149
- >
150
- <span type="text">
151
- {{
152
- item.template
153
- ? item.template({ ...data, config: item })
154
- : item.text
155
- }}
156
- </span></el-tooltip
157
- >
158
- <template v-else>
159
- <i :class="item.icon" v-if="item.icon"></i
160
- >{{
161
- item.template
162
- ? item.template({ ...data, config: item })
163
- : item.text
164
- }}
165
- </template>
166
- <el-badge
167
- v-if="item.badge"
168
- v-bind="
169
- typeof item.badge === 'number'
170
- ? { value: item.badge }
171
- : item.badge
172
- "
173
- ></el-badge>
174
- </el-dropdown-item>
175
- </el-dropdown-menu>
176
- </el-dropdown>
177
- </el-button-group>
178
- </template>
179
- <script>
180
- import util from 'eoss-ui/src/utils/util';
181
- export default {
182
- name: 'EsButtonGroup',
183
- provide() {
184
- return {
185
- btnGroup: this
186
- };
187
- },
188
- props: {
189
- mode: String,
190
- value: String,
191
- data: Object,
192
- contents: { type: Array, default: [] },
193
- length: {
194
- type: Number,
195
- default: 3
196
- },
197
- rules: Function,
198
- stop: Boolean,
199
- trigger: {
200
- type: String,
201
- default: 'hover'
202
- },
203
- useCaseCodeKey: String,
204
- moreText: String,
205
- size: {
206
- type: String,
207
- default: 'mini'
208
- },
209
- placement: {
210
- type: String,
211
- default: 'bottom'
212
- },
213
- parseData: Function,
214
- badge: Object,
215
- sort: Boolean,
216
- outside: {
217
- type: Boolean,
218
- default: true
219
- }
220
- },
221
- computed: {
222
- btns() {
223
- return this.getBtns();
224
- },
225
- showBtns() {
226
- return this.btns.length > this.length
227
- ? this.btns.slice(0, this.length - 1)
228
- : this.btns;
229
- },
230
- other() {
231
- let btns =
232
- this.length > 0 && (this.btns.length > this.length || this.length == 1)
233
- ? this.btns.slice(this.length - 1, this.btns.length)
234
- : [];
235
- return btns;
236
- },
237
- badges() {
238
- if (
239
- this.other.length &&
240
- this.other.filter((item) => {
241
- return item.badge;
242
- }).length
243
- ) {
244
- return this.badge ? { isDot: true, ...this.badge } : { isDot: true };
245
- }
246
- return this.badge
247
- ? { isDot: true, hidden: true, ...this.badge }
248
- : { isDot: true, hidden: true };
249
- }
250
- },
251
- watch: {},
252
- data() {
253
- return {
254
- show: false
255
- };
256
- },
257
- mounted() {
258
- this.resetWidth();
259
- },
260
- methods: {
261
- exclAttribute({ data, attrs }) {
262
- return util.exclAttribute({ data, attrs });
263
- },
264
- getBtns() {
265
- let useCaseCodes = util.getStorage('useCaseCodes');
266
- let keyword =
267
- this.data && this.useCaseCodeKey
268
- ? this.data.row[this.useCaseCodeKey]
269
- : null;
270
- let arry = this.contents.filter((item) => {
271
- if (Object.prototype.hasOwnProperty.call(item, 'rules')) {
272
- if (useCaseCodes && (item.useCaseCode || keyword)) {
273
- return (
274
- item.rules(this.data.row) &&
275
- useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
276
- );
277
- }
278
- return item.rules(this.data.row);
279
- }
280
- if (this.rules !== undefined) {
281
- if (useCaseCodes && (item.useCaseCode || keyword)) {
282
- return (
283
- this.rules(this.data.row) &&
284
- useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
285
- );
286
- }
287
- return this.rules(this.data.row);
288
- }
289
- if (useCaseCodes && (item.useCaseCode || keyword)) {
290
- return useCaseCodes.indexOf(item.useCaseCode || keyword) > -1;
291
- }
292
- return item.hide !== true;
293
- });
294
- let newBtns = arry.map((item) => {
295
- let badge, tips;
296
- if (item.badge && typeof item.badge === 'function') {
297
- badge = item.badge(this.data.row);
298
- }
299
- if (item.tips && typeof item.tips === 'function') {
300
- item.tips = item.tips(this.data.row);
301
- }
302
- return badge ? { ...item, badge: badge } : { ...item };
303
- });
304
- if (this.sort) {
305
- newBtns = newBtns.sort((a, b) => {
306
- return (b.badge ? 1 : 0) - (a.badge ? 1 : 0);
307
- });
308
- }
309
- return newBtns;
310
- },
311
- handleChange(res) {
312
- this.show = res;
313
- },
314
- handleClick(obj) {
315
- this.$emit('handleClick', obj);
316
- this.$emit('handle-click', obj);
317
- },
318
- handleCommand(res) {
319
- if (res.upload || res.selector) {
320
- this.$refs.dropdown.hide();
321
- return false;
322
- }
323
- this.$emit('handleClick', { ...this.data, handle: res });
324
- this.$emit('handle-click', { ...this.data, handle: res });
325
- },
326
- resetWidth() {
327
- this.$nextTick(() => {
328
- let childNodes = this.$el.childNodes;
329
- let width = parseInt(this.value, 10);
330
- let w = 0;
331
- for (let i = 0; i < childNodes.length; i++) {
332
- let item = childNodes[i];
333
- w += item.clientWidth ? item.clientWidth : 0;
334
- }
335
- w += 20 + childNodes.length + 10;
336
- if (w > width) {
337
- this.$emit('input', w + 'px');
338
- }
339
- });
340
- },
341
- parseProps() {
342
- return this.parseData && this.data ? this.parseData(this.data) : {};
343
- }
344
- }
345
- };
346
- </script>
1
+ <template>
2
+ <el-button-group class="es-button-group">
3
+ <template v-if="length > 1">
4
+ <template v-for="(item, index) in showBtns">
5
+ <template v-if="item && !item.hide">
6
+ <es-upload
7
+ v-if="item.upload || (item.code && item.ownId)"
8
+ :key="index"
9
+ v-bind="{
10
+ ...exclAttribute({
11
+ data: item,
12
+ attrs: ['events']
13
+ }),
14
+ ...parseProps(),
15
+ method: 'post',
16
+ btnSize: size,
17
+ showFileList: false,
18
+ selectType: mode == 'plus' ? 'text' : item.type
19
+ }"
20
+ v-on="item.events"
21
+ ></es-upload>
22
+ <el-tooltip
23
+ :key="index"
24
+ v-else-if="item.showTooltip"
25
+ :effect="item.effect ? item.effect : 'dark'"
26
+ :content="item.tips"
27
+ :placement="item.placement ? item.placement : 'top'"
28
+ >
29
+ <es-button
30
+ :stop="stop"
31
+ :data="data"
32
+ :outside="outside"
33
+ v-bind="
34
+ exclAttribute({
35
+ data: item,
36
+ attrs: ['events']
37
+ })
38
+ "
39
+ :size="size"
40
+ :type="mode == 'plus' ? 'text' : item.type"
41
+ v-on="item.events"
42
+ @click="handleClick({ ...data, handle: item })"
43
+ >
44
+ {{
45
+ item.template
46
+ ? item.template({ ...data, config: item })
47
+ : item.text
48
+ }}
49
+ </es-button>
50
+ </el-tooltip>
51
+ <es-button
52
+ v-else
53
+ :stop="stop"
54
+ :data="data"
55
+ :outside="outside"
56
+ v-bind="
57
+ exclAttribute({
58
+ data: item,
59
+ attrs: ['events']
60
+ })
61
+ "
62
+ :key="index"
63
+ :size="size"
64
+ :type="mode == 'plus' ? 'text' : item.type"
65
+ v-on="item.events"
66
+ @click="handleClick({ ...data, handle: item })"
67
+ >
68
+ {{
69
+ item.template
70
+ ? item.template({ ...data, config: item })
71
+ : item.text
72
+ }}
73
+ </es-button>
74
+ </template>
75
+ </template>
76
+ </template>
77
+ <el-dropdown
78
+ v-if="other.length > 0"
79
+ ref="dropdown"
80
+ @command="handleCommand"
81
+ @visible-change="handleChange"
82
+ :trigger="trigger"
83
+ >
84
+ <el-button :size="size" :type="mode == 'plus' ? 'text' : ''">
85
+ <el-badge v-bind="badges">
86
+ <template v-if="mode == 'plus'">更多</template>
87
+ <template v-else-if="moreText">
88
+ {{ moreText }}
89
+ <i
90
+ :class="{
91
+ 'el-icon-arrow-down': !show,
92
+ 'el-icon-arrow-up': show
93
+ }"
94
+ ></i>
95
+ </template>
96
+ <i v-else class="es-icon-more"></i>
97
+ </el-badge>
98
+ </el-button>
99
+ <el-dropdown-menu slot="dropdown">
100
+ <el-dropdown-item
101
+ v-for="(item, index) in other"
102
+ :key="index"
103
+ :command="item"
104
+ :class="{ 'es-dropdown-padding': item.upload || item.selector }"
105
+ v-show="!item.hide"
106
+ >
107
+ <es-upload
108
+ v-if="item.upload || (item.code && item.ownId)"
109
+ class="es-dropdown-upload"
110
+ v-bind="{
111
+ ...exclAttribute({
112
+ data: item,
113
+ attrs: ['events']
114
+ }),
115
+ ...parseProps(),
116
+ method: 'post',
117
+ showFileList: false,
118
+ selectType: 'text'
119
+ }"
120
+ v-on="item.events"
121
+ ></es-upload>
122
+ <es-selector
123
+ v-else-if="item.selector"
124
+ class="es-dropdown-selector"
125
+ v-bind="{
126
+ reset: true,
127
+ ...exclAttribute({
128
+ data: item,
129
+ attrs: ['events', 'type', 'value']
130
+ }),
131
+ businessData: data
132
+ }"
133
+ v-on="item.events"
134
+ :button="{ size: 'medium', type: 'text' }"
135
+ >
136
+ <i :class="item.icon" v-if="item.icon"></i
137
+ >{{
138
+ item.template
139
+ ? item.template({ ...data, config: item })
140
+ : item.text
141
+ }}
142
+ </es-selector>
143
+ <el-tooltip
144
+ :key="index"
145
+ v-else-if="item.showTooltip"
146
+ :effect="item.effect ? item.effect : 'dark'"
147
+ :content="item.tips"
148
+ :placement="item.placement ? item.placement : 'top'"
149
+ >
150
+ <span type="text">
151
+ {{
152
+ item.template
153
+ ? item.template({ ...data, config: item })
154
+ : item.text
155
+ }}
156
+ </span></el-tooltip
157
+ >
158
+ <template v-else>
159
+ <i :class="item.icon" v-if="item.icon"></i
160
+ >{{
161
+ item.template
162
+ ? item.template({ ...data, config: item })
163
+ : item.text
164
+ }}
165
+ </template>
166
+ <el-badge
167
+ v-if="item.badge"
168
+ v-bind="
169
+ typeof item.badge === 'number'
170
+ ? { value: item.badge }
171
+ : item.badge
172
+ "
173
+ ></el-badge>
174
+ </el-dropdown-item>
175
+ </el-dropdown-menu>
176
+ </el-dropdown>
177
+ </el-button-group>
178
+ </template>
179
+ <script>
180
+ import util from 'eoss-ui/src/utils/util';
181
+ export default {
182
+ name: 'EsButtonGroup',
183
+ provide() {
184
+ return {
185
+ btnGroup: this
186
+ };
187
+ },
188
+ props: {
189
+ mode: String,
190
+ value: String,
191
+ data: Object,
192
+ contents: { type: Array, default: [] },
193
+ length: {
194
+ type: Number,
195
+ default: 3
196
+ },
197
+ rules: Function,
198
+ stop: Boolean,
199
+ trigger: {
200
+ type: String,
201
+ default: 'hover'
202
+ },
203
+ useCaseCodeKey: String,
204
+ moreText: String,
205
+ size: {
206
+ type: String,
207
+ default: 'mini'
208
+ },
209
+ placement: {
210
+ type: String,
211
+ default: 'bottom'
212
+ },
213
+ parseData: Function,
214
+ badge: Object,
215
+ sort: Boolean,
216
+ outside: {
217
+ type: Boolean,
218
+ default: true
219
+ }
220
+ },
221
+ computed: {
222
+ btns() {
223
+ return this.getBtns();
224
+ },
225
+ showBtns() {
226
+ return this.btns.length > this.length
227
+ ? this.btns.slice(0, this.length - 1)
228
+ : this.btns;
229
+ },
230
+ other() {
231
+ let btns =
232
+ this.length > 0 && (this.btns.length > this.length || this.length == 1)
233
+ ? this.btns.slice(this.length - 1, this.btns.length)
234
+ : [];
235
+ return btns;
236
+ },
237
+ badges() {
238
+ if (
239
+ this.other.length &&
240
+ this.other.filter((item) => {
241
+ return item.badge;
242
+ }).length
243
+ ) {
244
+ return this.badge ? { isDot: true, ...this.badge } : { isDot: true };
245
+ }
246
+ return this.badge
247
+ ? { isDot: true, hidden: true, ...this.badge }
248
+ : { isDot: true, hidden: true };
249
+ }
250
+ },
251
+ watch: {},
252
+ data() {
253
+ return {
254
+ show: false
255
+ };
256
+ },
257
+ mounted() {
258
+ this.resetWidth();
259
+ },
260
+ methods: {
261
+ exclAttribute({ data, attrs }) {
262
+ return util.exclAttribute({ data, attrs });
263
+ },
264
+ getBtns() {
265
+ let useCaseCodes = util.getStorage('useCaseCodes');
266
+ let keyword =
267
+ this.data && this.useCaseCodeKey
268
+ ? this.data.row[this.useCaseCodeKey]
269
+ : null;
270
+ let arry = this.contents.filter((item) => {
271
+ if (Object.prototype.hasOwnProperty.call(item, 'rules')) {
272
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
273
+ return (
274
+ item.rules(this.data.row) &&
275
+ useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
276
+ );
277
+ }
278
+ return item.rules(this.data.row);
279
+ }
280
+ if (this.rules !== undefined) {
281
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
282
+ return (
283
+ this.rules(this.data.row) &&
284
+ useCaseCodes.indexOf(item.useCaseCode || keyword) > -1
285
+ );
286
+ }
287
+ return this.rules(this.data.row);
288
+ }
289
+ if (useCaseCodes && (item.useCaseCode || keyword)) {
290
+ return useCaseCodes.indexOf(item.useCaseCode || keyword) > -1;
291
+ }
292
+ return item.hide !== true;
293
+ });
294
+ let newBtns = arry.map((item) => {
295
+ let badge, tips;
296
+ if (item.badge && typeof item.badge === 'function') {
297
+ badge = item.badge(this.data.row);
298
+ }
299
+ if (item.tips && typeof item.tips === 'function') {
300
+ item.tips = item.tips(this.data.row);
301
+ }
302
+ return badge ? { ...item, badge: badge } : { ...item };
303
+ });
304
+ if (this.sort) {
305
+ newBtns = newBtns.sort((a, b) => {
306
+ return (b.badge ? 1 : 0) - (a.badge ? 1 : 0);
307
+ });
308
+ }
309
+ return newBtns;
310
+ },
311
+ handleChange(res) {
312
+ this.show = res;
313
+ },
314
+ handleClick(obj) {
315
+ this.$emit('handleClick', obj);
316
+ this.$emit('handle-click', obj);
317
+ },
318
+ handleCommand(res) {
319
+ if (res.upload || res.selector) {
320
+ this.$refs.dropdown.hide();
321
+ return false;
322
+ }
323
+ this.$emit('handleClick', { ...this.data, handle: res });
324
+ this.$emit('handle-click', { ...this.data, handle: res });
325
+ },
326
+ resetWidth() {
327
+ this.$nextTick(() => {
328
+ let childNodes = this.$el.childNodes;
329
+ let width = parseInt(this.value, 10);
330
+ let w = 0;
331
+ for (let i = 0; i < childNodes.length; i++) {
332
+ let item = childNodes[i];
333
+ w += item.clientWidth ? item.clientWidth : 0;
334
+ }
335
+ w += 20 + childNodes.length + 10;
336
+ if (w > width) {
337
+ this.$emit('input', w + 'px');
338
+ }
339
+ });
340
+ },
341
+ parseProps() {
342
+ return this.parseData && this.data ? this.parseData(this.data) : {};
343
+ }
344
+ }
345
+ };
346
+ </script>