eoss-ui 0.6.58 → 0.6.59

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