eoss-ui 0.6.46 → 0.6.48

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 (259) hide show
  1. package/lib/button-group.js +132 -117
  2. package/lib/button.js +132 -117
  3. package/lib/checkbox-group.js +134 -119
  4. package/lib/config/api.js +10 -0
  5. package/lib/data-table-form.js +134 -119
  6. package/lib/data-table.js +137 -122
  7. package/lib/date-picker.js +132 -117
  8. package/lib/dialog.js +132 -117
  9. package/lib/eoss-ui.common.js +1704 -1319
  10. package/lib/flow-group.js +132 -117
  11. package/lib/flow-list.js +463 -272
  12. package/lib/flow.js +1090 -881
  13. package/lib/form.js +138 -123
  14. package/lib/handle-user.js +133 -118
  15. package/lib/handler.js +133 -118
  16. package/lib/icon.js +133 -118
  17. package/lib/index.js +1 -1
  18. package/lib/input-number.js +132 -117
  19. package/lib/input.js +132 -117
  20. package/lib/login.js +146 -131
  21. package/lib/main.js +299 -284
  22. package/lib/nav.js +132 -117
  23. package/lib/notify.js +135 -120
  24. package/lib/page.js +132 -117
  25. package/lib/pagination.js +132 -117
  26. package/lib/player.js +132 -117
  27. package/lib/qr-code.js +145 -130
  28. package/lib/radio-group.js +134 -119
  29. package/lib/retrial-auth.js +136 -121
  30. package/lib/select-ganged.js +134 -119
  31. package/lib/select.js +134 -119
  32. package/lib/selector-panel.js +150 -135
  33. package/lib/selector.js +133 -118
  34. package/lib/sizer.js +134 -119
  35. package/lib/steps.js +132 -117
  36. package/lib/switch.js +132 -117
  37. package/lib/table-form.js +138 -123
  38. package/lib/tabs.js +132 -117
  39. package/lib/theme-chalk/flow.css +1 -1
  40. package/lib/theme-chalk/index.css +1 -1
  41. package/lib/tips.js +133 -118
  42. package/lib/tree-group.js +132 -117
  43. package/lib/tree.js +133 -118
  44. package/lib/upload.js +145 -130
  45. package/lib/wujie.js +132 -117
  46. package/lib/wxlogin.js +132 -117
  47. package/package.json +159 -159
  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 +298 -298
  52. package/packages/calendar/index.js +5 -5
  53. package/packages/card/index.js +5 -5
  54. package/packages/card/src/main.vue +156 -156
  55. package/packages/cascader/index.js +5 -5
  56. package/packages/cascader/src/main.vue +168 -168
  57. package/packages/checkbox-group/index.js +5 -5
  58. package/packages/checkbox-group/src/main.vue +333 -333
  59. package/packages/clients/index.js +5 -5
  60. package/packages/clients/src/main.vue +144 -144
  61. package/packages/data-table/index.js +5 -5
  62. package/packages/data-table/src/children.vue +39 -39
  63. package/packages/data-table/src/column.vue +989 -989
  64. package/packages/data-table/src/main.vue +1822 -1822
  65. package/packages/data-table/src/sizer.vue +195 -195
  66. package/packages/data-table-form/index.js +5 -5
  67. package/packages/data-table-form/src/checkbox.vue +101 -101
  68. package/packages/data-table-form/src/colgroup.vue +17 -17
  69. package/packages/data-table-form/src/main.vue +181 -181
  70. package/packages/data-table-form/src/radio.vue +65 -65
  71. package/packages/data-table-form/src/table.vue +233 -233
  72. package/packages/data-table-form/src/tbody.vue +336 -336
  73. package/packages/data-table-form/src/thead.vue +68 -68
  74. package/packages/date-picker/index.js +5 -5
  75. package/packages/date-picker/src/main.vue +236 -236
  76. package/packages/dialog/index.js +5 -5
  77. package/packages/enable-drag/index.js +5 -5
  78. package/packages/enterprise/index.js +5 -5
  79. package/packages/enterprise/src/main.vue +66 -66
  80. package/packages/error-page/index.js +5 -5
  81. package/packages/error-page/src/main.vue +44 -44
  82. package/packages/flow/index.js +5 -5
  83. package/packages/flow/src/component/CommonOpinions.vue +345 -345
  84. package/packages/flow/src/component/CustomPreset.vue +322 -322
  85. package/packages/flow/src/component/FileList.vue +99 -99
  86. package/packages/flow/src/component/Preset.vue +255 -255
  87. package/packages/flow/src/component/SendMsg.vue +229 -229
  88. package/packages/flow/src/component/TimeLimit.vue +190 -190
  89. package/packages/flow/src/component/taskUnionExamine.vue +611 -611
  90. package/packages/flow/src/form.vue +121 -121
  91. package/packages/flow/src/freeStartFlow.vue +2843 -2843
  92. package/packages/flow/src/main.vue +3107 -2964
  93. package/packages/flow/src/processForm.vue +1031 -1018
  94. package/packages/flow/src/processReject.vue +293 -293
  95. package/packages/flow/src/reset.vue +902 -899
  96. package/packages/flow/src/startTaskRead.vue +597 -596
  97. package/packages/flow/src/supervise.vue +138 -138
  98. package/packages/flow/src/table.vue +58 -58
  99. package/packages/flow-group/index.js +5 -5
  100. package/packages/flow-group/src/main.vue +688 -688
  101. package/packages/flow-list/index.js +5 -5
  102. package/packages/flow-list/src/main.vue +1411 -1183
  103. package/packages/form/index.js +5 -5
  104. package/packages/form/src/main.vue +3583 -3583
  105. package/packages/form/src/table.vue +1426 -1426
  106. package/packages/handle-user/index.js +5 -5
  107. package/packages/handle-user/src/main.vue +138 -138
  108. package/packages/handler/index.js +5 -5
  109. package/packages/handler/src/main.vue +491 -491
  110. package/packages/icon/index.js +5 -5
  111. package/packages/icon/src/main.vue +101 -101
  112. package/packages/icons/index.js +5 -5
  113. package/packages/icons/src/main.vue +81 -81
  114. package/packages/input/index.js +5 -5
  115. package/packages/input/src/main.vue +356 -356
  116. package/packages/input-number/index.js +5 -5
  117. package/packages/input-number/src/main.vue +106 -106
  118. package/packages/label/index.js +5 -5
  119. package/packages/label/src/main.vue +457 -457
  120. package/packages/layout/index.js +5 -5
  121. package/packages/layout/src/item.vue +152 -152
  122. package/packages/layout/src/main.vue +31 -31
  123. package/packages/login/index.js +5 -5
  124. package/packages/login/src/main.vue +1935 -1935
  125. package/packages/login/src/resetPassword.vue +562 -562
  126. package/packages/main/index.js +5 -5
  127. package/packages/main/src/default/message.vue +249 -249
  128. package/packages/main/src/default/notice.vue +157 -157
  129. package/packages/main/src/default/userinfo.vue +505 -505
  130. package/packages/main/src/public/online.vue +89 -89
  131. package/packages/main/src/public/search.vue +461 -461
  132. package/packages/main/src/public/settings.vue +221 -221
  133. package/packages/main/src/simplicity/apps.vue +388 -388
  134. package/packages/main/src/simplicity/avatar.vue +82 -82
  135. package/packages/main/src/simplicity/handler.vue +259 -259
  136. package/packages/main/src/simplicity/index.vue +2049 -2049
  137. package/packages/main/src/simplicity/lists.vue +84 -84
  138. package/packages/main/src/simplicity/menu-list.vue +128 -128
  139. package/packages/main/src/simplicity/message.vue +259 -259
  140. package/packages/main/src/simplicity/notice.vue +190 -190
  141. package/packages/main/src/simplicity/router-page.vue +45 -45
  142. package/packages/main/src/simplicity/sub-menu.vue +241 -241
  143. package/packages/main/src/simplicity/user.vue +257 -257
  144. package/packages/main/src/simplicity/userinfo.vue +312 -312
  145. package/packages/menu/index.js +5 -5
  146. package/packages/menu/src/main.vue +536 -536
  147. package/packages/nav/index.js +5 -5
  148. package/packages/nav/src/main.vue +351 -351
  149. package/packages/notify/index.js +5 -5
  150. package/packages/notify/src/main.vue +538 -538
  151. package/packages/page/index.js +5 -5
  152. package/packages/page/src/main.vue +167 -167
  153. package/packages/pagination/index.js +5 -5
  154. package/packages/pagination/src/main.vue +96 -96
  155. package/packages/player/index.js +5 -5
  156. package/packages/player/src/main.vue +194 -194
  157. package/packages/qr-code/index.js +5 -5
  158. package/packages/qr-code/src/main.vue +170 -170
  159. package/packages/radio-group/index.js +6 -6
  160. package/packages/radio-group/src/main.vue +319 -319
  161. package/packages/retrial-auth/index.js +5 -5
  162. package/packages/retrial-auth/src/main.vue +280 -280
  163. package/packages/select/index.js +5 -5
  164. package/packages/select/src/main.vue +775 -775
  165. package/packages/select-ganged/index.js +5 -5
  166. package/packages/select-ganged/src/main.vue +724 -724
  167. package/packages/selector/index.js +5 -5
  168. package/packages/selector/src/main.vue +689 -689
  169. package/packages/selector-panel/index.js +5 -5
  170. package/packages/selector-panel/src/main.vue +1027 -1027
  171. package/packages/selector-panel/src/selection.vue +177 -177
  172. package/packages/selector-panel/src/tree.vue +129 -129
  173. package/packages/sizer/index.js +5 -5
  174. package/packages/sizer/src/main.vue +254 -254
  175. package/packages/steps/index.js +5 -5
  176. package/packages/steps/src/main.vue +181 -181
  177. package/packages/switch/index.js +5 -5
  178. package/packages/switch/src/main.vue +154 -154
  179. package/packages/table-form/index.js +5 -5
  180. package/packages/tabs/index.js +5 -5
  181. package/packages/tabs/src/main.vue +788 -788
  182. package/packages/tabs-panel/index.js +5 -5
  183. package/packages/tabs-panel/src/main.vue +29 -29
  184. package/packages/theme-chalk/lib/flow.css +1 -1
  185. package/packages/theme-chalk/lib/index.css +1 -1
  186. package/packages/theme-chalk/src/base.scss +260 -260
  187. package/packages/theme-chalk/src/button-group.scss +175 -175
  188. package/packages/theme-chalk/src/button.scss +24 -24
  189. package/packages/theme-chalk/src/calendar.scss +113 -113
  190. package/packages/theme-chalk/src/card.scss +99 -99
  191. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  192. package/packages/theme-chalk/src/clients.scss +87 -87
  193. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  194. package/packages/theme-chalk/src/data-table.scss +293 -293
  195. package/packages/theme-chalk/src/date-picker.scss +7 -7
  196. package/packages/theme-chalk/src/dialog.scss +77 -77
  197. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  198. package/packages/theme-chalk/src/enterprise.scss +5 -5
  199. package/packages/theme-chalk/src/error-page.scss +18 -18
  200. package/packages/theme-chalk/src/flow-group.scss +110 -110
  201. package/packages/theme-chalk/src/flow-list.scss +36 -36
  202. package/packages/theme-chalk/src/flow.scss +335 -318
  203. package/packages/theme-chalk/src/form.scss +496 -496
  204. package/packages/theme-chalk/src/handle-user.scss +40 -40
  205. package/packages/theme-chalk/src/handler.scss +143 -143
  206. package/packages/theme-chalk/src/icon.scss +1789 -1789
  207. package/packages/theme-chalk/src/icons.scss +99 -99
  208. package/packages/theme-chalk/src/input.scss +9 -9
  209. package/packages/theme-chalk/src/label.scss +24 -24
  210. package/packages/theme-chalk/src/layout.scss +46 -46
  211. package/packages/theme-chalk/src/login.scss +969 -969
  212. package/packages/theme-chalk/src/main.scss +656 -656
  213. package/packages/theme-chalk/src/menu.scss +222 -222
  214. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  215. package/packages/theme-chalk/src/nav.scss +111 -111
  216. package/packages/theme-chalk/src/page.scss +3 -3
  217. package/packages/theme-chalk/src/pagination.scss +29 -29
  218. package/packages/theme-chalk/src/player.scss +9 -9
  219. package/packages/theme-chalk/src/qr-code.scss +17 -17
  220. package/packages/theme-chalk/src/radio-group.scss +9 -9
  221. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  222. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  223. package/packages/theme-chalk/src/select.scss +8 -8
  224. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  225. package/packages/theme-chalk/src/selector.scss +91 -91
  226. package/packages/theme-chalk/src/simplicity.scss +1265 -1265
  227. package/packages/theme-chalk/src/sizer.scss +36 -36
  228. package/packages/theme-chalk/src/steps.scss +88 -88
  229. package/packages/theme-chalk/src/switch.scss +3 -3
  230. package/packages/theme-chalk/src/table-form.scss +1 -1
  231. package/packages/theme-chalk/src/tabs.scss +87 -87
  232. package/packages/theme-chalk/src/tips.scss +7 -7
  233. package/packages/theme-chalk/src/toolbar.scss +179 -179
  234. package/packages/theme-chalk/src/tree-group.scss +72 -72
  235. package/packages/theme-chalk/src/tree.scss +165 -165
  236. package/packages/theme-chalk/src/upload.scss +167 -167
  237. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  238. package/packages/tips/index.js +5 -5
  239. package/packages/tips/src/main.vue +141 -141
  240. package/packages/toolbar/index.js +5 -5
  241. package/packages/toolbar/src/main.vue +430 -430
  242. package/packages/tree/index.js +5 -5
  243. package/packages/tree-group/index.js +5 -5
  244. package/packages/upload/index.js +5 -5
  245. package/packages/upload/src/main.vue +1335 -1335
  246. package/packages/upload/src/picture.js +15 -15
  247. package/packages/wujie/index.js +5 -5
  248. package/packages/wujie/src/main.vue +145 -145
  249. package/packages/wxlogin/index.js +5 -5
  250. package/packages/wxlogin/src/main.vue +128 -128
  251. package/src/config/api.js +281 -251
  252. package/src/config/image.js +2 -2
  253. package/src/index.js +1 -1
  254. package/src/utils/bus.js +3 -3
  255. package/src/utils/date-util.js +312 -312
  256. package/src/utils/http.js +50 -50
  257. package/src/utils/rules.js +18 -18
  258. package/src/utils/store.js +21 -21
  259. package/src/utils/webSocket.js +107 -107
@@ -1,68 +1,68 @@
1
- <template>
2
- <thead class="es-data-form-head">
3
- <tr v-for="(items, indexs) in thead">
4
- <th v-if="numbers" :colspan="thead.length">序号</th>
5
- <th v-for="(item, index) in items" :key="index">
6
- <expand-dom
7
- v-if="item.render"
8
- class="cell"
9
- :key="index"
10
- :item="item"
11
- :render="item.render"
12
- ></expand-dom>
13
- <div
14
- v-else
15
- class="cell"
16
- :class="{ 'es-required': required(item.rules) }"
17
- >
18
- {{ item.title || item.label || item.text }}
19
- </div>
20
- </th>
21
- </tr>
22
- </thead>
23
- </template>
24
- <script>
25
- // import rules from 'eoss-ui/src/utils/rules.js';
26
- //import util from 'eoss-ui/src/utils/util';
27
- export default {
28
- name: 'EoThead',
29
- components: {
30
- expandDom: {
31
- functional: true,
32
- props: {
33
- item: Object,
34
- render: [Function, String]
35
- },
36
- render: (h, ctx) => {
37
- if (typeof ctx.props.render == 'string') {
38
- try {
39
- return util.toFunction(ctx.props.render)(h, params);
40
- } catch (error) {
41
- throw error;
42
- }
43
- }
44
- return ctx.props.render(h, ctx.props.item);
45
- }
46
- }
47
- },
48
- props: {
49
- numbers: Boolean,
50
- thead: Array
51
- },
52
- methods: {
53
- required(rules) {
54
- if (!rules) {
55
- return false;
56
- }
57
- if (Array.isArray(rules)) {
58
- for (let i = 0; i < rules.length; i++) {
59
- if (rules[i].required) {
60
- return true;
61
- }
62
- }
63
- }
64
- return rules.required;
65
- }
66
- }
67
- };
68
- </script>
1
+ <template>
2
+ <thead class="es-data-form-head">
3
+ <tr v-for="(items, indexs) in thead">
4
+ <th v-if="numbers" :colspan="thead.length">序号</th>
5
+ <th v-for="(item, index) in items" :key="index">
6
+ <expand-dom
7
+ v-if="item.render"
8
+ class="cell"
9
+ :key="index"
10
+ :item="item"
11
+ :render="item.render"
12
+ ></expand-dom>
13
+ <div
14
+ v-else
15
+ class="cell"
16
+ :class="{ 'es-required': required(item.rules) }"
17
+ >
18
+ {{ item.title || item.label || item.text }}
19
+ </div>
20
+ </th>
21
+ </tr>
22
+ </thead>
23
+ </template>
24
+ <script>
25
+ // import rules from 'eoss-ui/src/utils/rules.js';
26
+ //import util from 'eoss-ui/src/utils/util';
27
+ export default {
28
+ name: 'EoThead',
29
+ components: {
30
+ expandDom: {
31
+ functional: true,
32
+ props: {
33
+ item: Object,
34
+ render: [Function, String]
35
+ },
36
+ render: (h, ctx) => {
37
+ if (typeof ctx.props.render == 'string') {
38
+ try {
39
+ return util.toFunction(ctx.props.render)(h, params);
40
+ } catch (error) {
41
+ throw error;
42
+ }
43
+ }
44
+ return ctx.props.render(h, ctx.props.item);
45
+ }
46
+ }
47
+ },
48
+ props: {
49
+ numbers: Boolean,
50
+ thead: Array
51
+ },
52
+ methods: {
53
+ required(rules) {
54
+ if (!rules) {
55
+ return false;
56
+ }
57
+ if (Array.isArray(rules)) {
58
+ for (let i = 0; i < rules.length; i++) {
59
+ if (rules[i].required) {
60
+ return true;
61
+ }
62
+ }
63
+ }
64
+ return rules.required;
65
+ }
66
+ }
67
+ };
68
+ </script>
@@ -1,5 +1,5 @@
1
- import EsDatePicker from './src/main';
2
-
3
- EsDatePicker.install = Vue => Vue.component(EsDatePicker.name, EsDatePicker);
4
-
5
- export default EsDatePicker;
1
+ import EsDatePicker from './src/main';
2
+
3
+ EsDatePicker.install = Vue => Vue.component(EsDatePicker.name, EsDatePicker);
4
+
5
+ export default EsDatePicker;
@@ -1,236 +1,236 @@
1
- <script>
2
- import util from 'eoss-ui/src/utils/util';
3
- const formats = {
4
- date: 'yyyy-MM-dd',
5
- month: 'yyyy-MM',
6
- datetime: 'yyyy-MM-dd HH:mm:ss',
7
- time: 'HH:mm:ss',
8
- week: 'yyyy年第WW周',
9
- timerange: 'HH:mm:ss',
10
- daterange: 'yyyy-MM-dd',
11
- monthrange: 'yyyy-MM',
12
- datetimerange: 'yyyy-MM-dd HH:mm:ss',
13
- year: 'yyyy',
14
- halfyear: 'bb',
15
- quarter: 'qq'
16
- };
17
- export default {
18
- name: 'EsDatePicker',
19
- inheritAttrs: false,
20
- inject: {
21
- esForm: {
22
- default: ''
23
- }
24
- },
25
- props: {
26
- value: [String, Array, Number, Date],
27
- display: {
28
- type: Boolean,
29
- default: true
30
- },
31
- hide: {
32
- type: Boolean,
33
- default: false
34
- },
35
- range: {
36
- type: Boolean,
37
- default: false
38
- },
39
- // 提交数据时是否转成时间戳
40
- timestamp: {
41
- type: Boolean,
42
- default: false
43
- },
44
- unlinkPanels: {
45
- type: Boolean,
46
- default: true
47
- },
48
- type: {
49
- type: String,
50
- default: 'date'
51
- },
52
- rangeSeparator: {
53
- type: String,
54
- default: '-'
55
- },
56
- format: String,
57
- readonly: Boolean,
58
- plain: Boolean,
59
- default: Boolean,
60
- setFormKeys: Array
61
- },
62
- data() {
63
- return {
64
- date: ''
65
- };
66
- },
67
- computed: {
68
- models: {
69
- get() {
70
- return this.value ? this.value : this.dae;
71
- },
72
- set(val) {
73
- return val;
74
- }
75
- },
76
- formats() {
77
- return this.format ? this.format : formats[this.dateType];
78
- },
79
- dateType() {
80
- return (this.type === 'datetime' ||
81
- this.type === 'dater' ||
82
- this.type === 'month') &&
83
- this.range
84
- ? this.type + 'range'
85
- : this.type;
86
- },
87
- config() {
88
- return this.range ||
89
- this.type === 'datetimerange' ||
90
- this.type === 'daterange' ||
91
- this.type === 'monthrange'
92
- ? {
93
- startPlaceholder: '开始时间',
94
- endPlaceholder: '结束时间',
95
- unlinkPanels: this.unlinkPanels
96
- }
97
- : {};
98
- },
99
- class() {
100
- return this.range ||
101
- this.type === 'datetimerange' ||
102
- this.type === 'daterange' ||
103
- this.type === 'monthrange'
104
- ? 'es-date-picker-range'
105
- : '';
106
- }
107
- },
108
- watch: {
109
- models: {
110
- deep: true,
111
- handler(val) {
112
- if (
113
- this.setFormKeys &&
114
- this.esForm &&
115
- this.dateType.indexOf('range') > -1
116
- ) {
117
- let obj = this.esForm.models;
118
- this.setFormKeys.forEach((item, index) => {
119
- if (val && val.length) {
120
- obj[item] = val[index];
121
- } else {
122
- delete obj[item];
123
- }
124
- });
125
- this.esForm.models = obj;
126
- }
127
- }
128
- },
129
- 'esForm.models': {
130
- deep: true,
131
- handler(val) {
132
- if (
133
- this.setFormKeys &&
134
- this.dateType.indexOf('range') > -1 &&
135
- !util.isExist(this.value)
136
- ) {
137
- this.date = this.setFormKeys.map((item) => {
138
- return val[item] || '';
139
- });
140
- }
141
- }
142
- }
143
- },
144
- mounted() {},
145
- methods: {
146
- getData(val) {
147
- if (val) {
148
- if (
149
- typeof val === 'number' ||
150
- (typeof val === 'string' && this.format)
151
- ) {
152
- return this.dateFormat(val);
153
- }
154
- if (Array.isArray(val)) {
155
- val
156
- .map((item) => {
157
- if (item) {
158
- return typeof item === 'number' ||
159
- (typeof item === 'string' && this.format)
160
- ? this.dateFormat(item)
161
- : item;
162
- }
163
- return '';
164
- })
165
- .join(this.rangeSeparator);
166
- }
167
- return val;
168
- }
169
- return '';
170
- },
171
- dateFormat(date) {
172
- let newDate = '';
173
- switch (this.dateType) {
174
- case 'year':
175
- newDate = util.formatDate(date, this.formats);
176
- break;
177
- case 'halfyear':
178
- newDate = util.formatDate(date, this.formats);
179
- break;
180
- case 'month':
181
- newDate = util.formatDate(date, this.formats);
182
- break;
183
- case 'time':
184
- newDate = util.formatDate(date, this.formats);
185
- break;
186
- case 'datetime':
187
- newDate = util.formatDate(date, this.formats);
188
- break;
189
- case 'quarter':
190
- newDate = util.formatDate(date, this.formats);
191
- break;
192
- default:
193
- newDate = util.formatDate(date, this.formats);
194
- }
195
- return newDate;
196
- },
197
- showPicker() {
198
- this.$refs.elDate.showPicker();
199
- }
200
- },
201
- render(h) {
202
- if (!this.hide) {
203
- if (this.readonly) {
204
- return h(
205
- 'div',
206
- { class: ['es-input__inner', { 'es-plain': this.plain }] },
207
- [this.getData(this.models)]
208
- );
209
- }
210
- return h('el-date-picker', {
211
- class: ['es-date-picker', this.class],
212
- attrs: {
213
- ...this.$attrs,
214
- ...this.config,
215
- type: this.dateType,
216
- valueFormat: this.timestamp ? 'timestamp' : this.formats,
217
- rangeSeparator: this.rangeSeparator,
218
- format: this.formats,
219
- editable: false,
220
- value: this.models
221
- },
222
- ref: 'elDate',
223
- on: this.$listeners,
224
- directives: [
225
- {
226
- name: 'show',
227
- value: this.display
228
- }
229
- ]
230
- });
231
- } else {
232
- return '';
233
- }
234
- }
235
- };
236
- </script>
1
+ <script>
2
+ import util from 'eoss-ui/src/utils/util';
3
+ const formats = {
4
+ date: 'yyyy-MM-dd',
5
+ month: 'yyyy-MM',
6
+ datetime: 'yyyy-MM-dd HH:mm:ss',
7
+ time: 'HH:mm:ss',
8
+ week: 'yyyy年第WW周',
9
+ timerange: 'HH:mm:ss',
10
+ daterange: 'yyyy-MM-dd',
11
+ monthrange: 'yyyy-MM',
12
+ datetimerange: 'yyyy-MM-dd HH:mm:ss',
13
+ year: 'yyyy',
14
+ halfyear: 'bb',
15
+ quarter: 'qq'
16
+ };
17
+ export default {
18
+ name: 'EsDatePicker',
19
+ inheritAttrs: false,
20
+ inject: {
21
+ esForm: {
22
+ default: ''
23
+ }
24
+ },
25
+ props: {
26
+ value: [String, Array, Number, Date],
27
+ display: {
28
+ type: Boolean,
29
+ default: true
30
+ },
31
+ hide: {
32
+ type: Boolean,
33
+ default: false
34
+ },
35
+ range: {
36
+ type: Boolean,
37
+ default: false
38
+ },
39
+ // 提交数据时是否转成时间戳
40
+ timestamp: {
41
+ type: Boolean,
42
+ default: false
43
+ },
44
+ unlinkPanels: {
45
+ type: Boolean,
46
+ default: true
47
+ },
48
+ type: {
49
+ type: String,
50
+ default: 'date'
51
+ },
52
+ rangeSeparator: {
53
+ type: String,
54
+ default: '-'
55
+ },
56
+ format: String,
57
+ readonly: Boolean,
58
+ plain: Boolean,
59
+ default: Boolean,
60
+ setFormKeys: Array
61
+ },
62
+ data() {
63
+ return {
64
+ date: ''
65
+ };
66
+ },
67
+ computed: {
68
+ models: {
69
+ get() {
70
+ return this.value ? this.value : this.dae;
71
+ },
72
+ set(val) {
73
+ return val;
74
+ }
75
+ },
76
+ formats() {
77
+ return this.format ? this.format : formats[this.dateType];
78
+ },
79
+ dateType() {
80
+ return (this.type === 'datetime' ||
81
+ this.type === 'dater' ||
82
+ this.type === 'month') &&
83
+ this.range
84
+ ? this.type + 'range'
85
+ : this.type;
86
+ },
87
+ config() {
88
+ return this.range ||
89
+ this.type === 'datetimerange' ||
90
+ this.type === 'daterange' ||
91
+ this.type === 'monthrange'
92
+ ? {
93
+ startPlaceholder: '开始时间',
94
+ endPlaceholder: '结束时间',
95
+ unlinkPanels: this.unlinkPanels
96
+ }
97
+ : {};
98
+ },
99
+ class() {
100
+ return this.range ||
101
+ this.type === 'datetimerange' ||
102
+ this.type === 'daterange' ||
103
+ this.type === 'monthrange'
104
+ ? 'es-date-picker-range'
105
+ : '';
106
+ }
107
+ },
108
+ watch: {
109
+ models: {
110
+ deep: true,
111
+ handler(val) {
112
+ if (
113
+ this.setFormKeys &&
114
+ this.esForm &&
115
+ this.dateType.indexOf('range') > -1
116
+ ) {
117
+ let obj = this.esForm.models;
118
+ this.setFormKeys.forEach((item, index) => {
119
+ if (val && val.length) {
120
+ obj[item] = val[index];
121
+ } else {
122
+ delete obj[item];
123
+ }
124
+ });
125
+ this.esForm.models = obj;
126
+ }
127
+ }
128
+ },
129
+ 'esForm.models': {
130
+ deep: true,
131
+ handler(val) {
132
+ if (
133
+ this.setFormKeys &&
134
+ this.dateType.indexOf('range') > -1 &&
135
+ !util.isExist(this.value)
136
+ ) {
137
+ this.date = this.setFormKeys.map((item) => {
138
+ return val[item] || '';
139
+ });
140
+ }
141
+ }
142
+ }
143
+ },
144
+ mounted() {},
145
+ methods: {
146
+ getData(val) {
147
+ if (val) {
148
+ if (
149
+ typeof val === 'number' ||
150
+ (typeof val === 'string' && this.format)
151
+ ) {
152
+ return this.dateFormat(val);
153
+ }
154
+ if (Array.isArray(val)) {
155
+ val
156
+ .map((item) => {
157
+ if (item) {
158
+ return typeof item === 'number' ||
159
+ (typeof item === 'string' && this.format)
160
+ ? this.dateFormat(item)
161
+ : item;
162
+ }
163
+ return '';
164
+ })
165
+ .join(this.rangeSeparator);
166
+ }
167
+ return val;
168
+ }
169
+ return '';
170
+ },
171
+ dateFormat(date) {
172
+ let newDate = '';
173
+ switch (this.dateType) {
174
+ case 'year':
175
+ newDate = util.formatDate(date, this.formats);
176
+ break;
177
+ case 'halfyear':
178
+ newDate = util.formatDate(date, this.formats);
179
+ break;
180
+ case 'month':
181
+ newDate = util.formatDate(date, this.formats);
182
+ break;
183
+ case 'time':
184
+ newDate = util.formatDate(date, this.formats);
185
+ break;
186
+ case 'datetime':
187
+ newDate = util.formatDate(date, this.formats);
188
+ break;
189
+ case 'quarter':
190
+ newDate = util.formatDate(date, this.formats);
191
+ break;
192
+ default:
193
+ newDate = util.formatDate(date, this.formats);
194
+ }
195
+ return newDate;
196
+ },
197
+ showPicker() {
198
+ this.$refs.elDate.showPicker();
199
+ }
200
+ },
201
+ render(h) {
202
+ if (!this.hide) {
203
+ if (this.readonly) {
204
+ return h(
205
+ 'div',
206
+ { class: ['es-input__inner', { 'es-plain': this.plain }] },
207
+ [this.getData(this.models)]
208
+ );
209
+ }
210
+ return h('el-date-picker', {
211
+ class: ['es-date-picker', this.class],
212
+ attrs: {
213
+ ...this.$attrs,
214
+ ...this.config,
215
+ type: this.dateType,
216
+ valueFormat: this.timestamp ? 'timestamp' : this.formats,
217
+ rangeSeparator: this.rangeSeparator,
218
+ format: this.formats,
219
+ editable: false,
220
+ value: this.models
221
+ },
222
+ ref: 'elDate',
223
+ on: this.$listeners,
224
+ directives: [
225
+ {
226
+ name: 'show',
227
+ value: this.display
228
+ }
229
+ ]
230
+ });
231
+ } else {
232
+ return '';
233
+ }
234
+ }
235
+ };
236
+ </script>
@@ -1,5 +1,5 @@
1
- import EsDialog from './src/main';
2
-
3
- EsDialog.install = Vue => Vue.component(EsDialog.name, EsDialog);
4
-
5
- export default EsDialog;
1
+ import EsDialog from './src/main';
2
+
3
+ EsDialog.install = Vue => Vue.component(EsDialog.name, EsDialog);
4
+
5
+ export default EsDialog;
@@ -1,5 +1,5 @@
1
- import EsEnableDrag from './src/main';
2
-
3
- EsEnableDrag.install = Vue => Vue.component(EsEnableDrag.name, EsEnableDrag);
4
-
5
- export default EsEnableDrag;
1
+ import EsEnableDrag from './src/main';
2
+
3
+ EsEnableDrag.install = Vue => Vue.component(EsEnableDrag.name, EsEnableDrag);
4
+
5
+ export default EsEnableDrag;
@@ -1,5 +1,5 @@
1
- import Enterprise from './src/main';
2
-
3
- Enterprise.install = Vue => Vue.component(Enterprise.name, Enterprise);
4
-
5
- export default Enterprise;
1
+ import Enterprise from './src/main';
2
+
3
+ Enterprise.install = Vue => Vue.component(Enterprise.name, Enterprise);
4
+
5
+ export default Enterprise;