cy-element-ui 1.0.28 → 1.0.30

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 (210) hide show
  1. package/README.md +23 -14
  2. package/lib/alert.js +4 -4
  3. package/lib/aside.js +2 -2
  4. package/lib/autocomplete.js +4 -4
  5. package/lib/avatar.js +2 -2
  6. package/lib/backtop.js +4 -4
  7. package/lib/badge.js +4 -4
  8. package/lib/breadcrumb-item.js +4 -4
  9. package/lib/breadcrumb.js +2 -2
  10. package/lib/button-group.js +2 -2
  11. package/lib/button.js +2 -2
  12. package/lib/calendar.js +6 -6
  13. package/lib/card.js +2 -2
  14. package/lib/carousel-item.js +4 -4
  15. package/lib/carousel.js +2 -2
  16. package/lib/cascader-panel.js +4 -4
  17. package/lib/cascader.js +4 -4
  18. package/lib/checkbox-button.js +4 -4
  19. package/lib/checkbox-group.js +2 -2
  20. package/lib/checkbox.js +4 -4
  21. package/lib/col.js +2 -2
  22. package/lib/collapse-item.js +4 -4
  23. package/lib/collapse.js +2 -2
  24. package/lib/color-picker.js +45 -45
  25. package/lib/container.js +2 -2
  26. package/lib/date-picker.js +49 -45
  27. package/lib/descriptions-item.js +2 -2
  28. package/lib/descriptions.js +2 -2
  29. package/lib/dialog.js +4 -4
  30. package/lib/divider.js +4 -4
  31. package/lib/drawer.js +6 -6
  32. package/lib/dropdown-item.js +2 -2
  33. package/lib/dropdown-menu.js +2 -2
  34. package/lib/dropdown.js +10 -10
  35. package/lib/element-ui.common.js +1801 -388
  36. package/lib/empty.js +4 -4
  37. package/lib/fileUpload.js +978 -0
  38. package/lib/footer.js +2 -2
  39. package/lib/form-item.js +4 -4
  40. package/lib/form.js +4 -4
  41. package/lib/header.js +2 -2
  42. package/lib/icon.js +2 -2
  43. package/lib/image.js +12 -12
  44. package/lib/index.js +1 -1
  45. package/lib/infinite-scroll.js +2 -2
  46. package/lib/input-number.js +2 -2
  47. package/lib/input.js +4 -4
  48. package/lib/link.js +2 -2
  49. package/lib/loading.js +4 -4
  50. package/lib/locale/format.js +0 -1
  51. package/lib/main.js +2 -2
  52. package/lib/menu-item-group.js +4 -4
  53. package/lib/menu-item.js +2 -2
  54. package/lib/menu.js +3 -3
  55. package/lib/message-box.js +7 -7
  56. package/lib/message.js +4 -4
  57. package/lib/notification.js +4 -4
  58. package/lib/option-group.js +2 -2
  59. package/lib/option.js +2 -2
  60. package/lib/page-header.js +2 -2
  61. package/lib/pagination.js +4 -4
  62. package/lib/popconfirm.js +12 -12
  63. package/lib/popover.js +4 -4
  64. package/lib/progress.js +4 -4
  65. package/lib/radio-button.js +4 -4
  66. package/lib/radio-group.js +2 -2
  67. package/lib/radio.js +4 -4
  68. package/lib/rate.js +9 -9
  69. package/lib/result.js +2 -2
  70. package/lib/row.js +2 -2
  71. package/lib/scrollbar.js +2 -2
  72. package/lib/select.js +2 -2
  73. package/lib/skeleton-item.js +2 -2
  74. package/lib/skeleton.js +2 -2
  75. package/lib/slider.js +4 -4
  76. package/lib/spinner.js +2 -2
  77. package/lib/statistic.js +4 -4
  78. package/lib/step.js +4 -4
  79. package/lib/steps.js +11 -11
  80. package/lib/subTitle.js +293 -0
  81. package/lib/submenu.js +2 -3
  82. package/lib/switch.js +2 -2
  83. package/lib/tab-pane.js +2 -2
  84. package/lib/tabDialog.js +787 -0
  85. package/lib/table-column.js +4 -4
  86. package/lib/table.js +19 -16
  87. package/lib/tabs.js +4 -4
  88. package/lib/tag.js +2 -2
  89. package/lib/time-picker.js +2 -2
  90. package/lib/time-select.js +2 -2
  91. package/lib/timeline-item.js +4 -4
  92. package/lib/timeline.js +2 -2
  93. package/lib/tooltip.js +2 -2
  94. package/lib/transfer.js +7 -7
  95. package/lib/tree.js +11 -11
  96. package/lib/{treeselect.js → treeSelect.js} +31 -31
  97. package/lib/upload.js +14 -14
  98. package/package.json +5 -1
  99. package/packages/alert/src/main.vue +1 -1
  100. package/packages/autocomplete/src/autocomplete.vue +3 -3
  101. package/packages/avatar/src/main.vue +5 -5
  102. package/packages/backtop/src/main.vue +3 -3
  103. package/packages/badge/src/main.vue +1 -1
  104. package/packages/breadcrumb/src/breadcrumb-item.vue +1 -1
  105. package/packages/calendar/src/date-table.vue +3 -3
  106. package/packages/calendar/src/main.vue +5 -5
  107. package/packages/carousel/src/item.vue +1 -1
  108. package/packages/cascader/src/cascader.vue +2 -2
  109. package/packages/cascader-panel/src/cascader-menu.vue +4 -4
  110. package/packages/cascader-panel/src/node.js +3 -4
  111. package/packages/cascader-panel/src/store.js +1 -2
  112. package/packages/checkbox/src/checkbox-button.vue +8 -8
  113. package/packages/checkbox/src/checkbox.vue +1 -1
  114. package/packages/col/src/col.js +5 -5
  115. package/packages/collapse/src/collapse-item.vue +1 -1
  116. package/packages/color-picker/src/color.js +4 -4
  117. package/packages/color-picker/src/components/alpha-slider.vue +12 -12
  118. package/packages/color-picker/src/components/hue-slider.vue +6 -6
  119. package/packages/color-picker/src/components/picker-dropdown.vue +1 -1
  120. package/packages/color-picker/src/components/predefine.vue +4 -4
  121. package/packages/color-picker/src/components/sv-panel.vue +4 -4
  122. package/packages/color-picker/src/main.vue +8 -8
  123. package/packages/date-picker/src/basic/date-table.vue +19 -19
  124. package/packages/date-picker/src/basic/month-table.vue +8 -9
  125. package/packages/date-picker/src/basic/year-table.vue +38 -38
  126. package/packages/date-picker/src/panel/date-range.vue +1 -1
  127. package/packages/date-picker/src/panel/date.vue +5 -5
  128. package/packages/date-picker/src/panel/month-range.vue +1 -1
  129. package/packages/descriptions/src/descriptions-row.js +3 -3
  130. package/packages/descriptions/src/index.js +1 -1
  131. package/packages/divider/src/main.vue +1 -1
  132. package/packages/drawer/src/main.vue +2 -2
  133. package/packages/dropdown/src/dropdown.vue +1 -1
  134. package/packages/empty/src/index.vue +1 -1
  135. package/packages/fileUpload/index.js +8 -0
  136. package/packages/fileUpload/src/main.vue +430 -0
  137. package/packages/form/src/form-item.vue +3 -3
  138. package/packages/form/src/form.vue +1 -1
  139. package/packages/image/src/image-viewer.vue +4 -4
  140. package/packages/infinite-scroll/src/main.js +2 -3
  141. package/packages/input/src/calcTextareaHeight.js +2 -2
  142. package/packages/input/src/input.vue +15 -15
  143. package/packages/menu/src/menu-item-group.vue +1 -1
  144. package/packages/menu/src/menu.vue +4 -4
  145. package/packages/menu/src/submenu.vue +3 -4
  146. package/packages/message/src/main.js +1 -1
  147. package/packages/notification/src/main.js +1 -1
  148. package/packages/pagination/src/pager.vue +1 -1
  149. package/packages/popconfirm/src/main.vue +28 -28
  150. package/packages/popover/src/main.vue +1 -1
  151. package/packages/progress/src/progress.vue +10 -10
  152. package/packages/radio/src/radio-button.vue +2 -2
  153. package/packages/radio/src/radio.vue +1 -1
  154. package/packages/row/src/row.js +3 -3
  155. package/packages/scrollbar/src/main.js +2 -2
  156. package/packages/scrollbar/src/util.js +1 -1
  157. package/packages/slider/src/main.vue +2 -2
  158. package/packages/statistic/src/main.vue +6 -7
  159. package/packages/steps/src/step.vue +2 -2
  160. package/packages/steps/src/steps.vue +4 -4
  161. package/packages/subTitle/index.js +8 -0
  162. package/packages/subTitle/src/main.vue +33 -0
  163. package/packages/tabDialog/index.js +23 -0
  164. package/packages/tabDialog/src/dialog/drag.js +63 -0
  165. package/packages/tabDialog/src/dialog/dragHeight.js +34 -0
  166. package/packages/tabDialog/src/dialog/dragWidth.js +30 -0
  167. package/packages/tabDialog/src/main.vue +277 -0
  168. package/packages/table/src/filter-panel.vue +7 -7
  169. package/packages/table/src/store/index.js +1 -1
  170. package/packages/table/src/table-body.js +2 -2
  171. package/packages/table/src/table-column.js +1 -1
  172. package/packages/table/src/table-header.js +1 -1
  173. package/packages/table/src/table-layout.js +1 -1
  174. package/packages/table/src/table.vue +16 -16
  175. package/packages/tabs/src/tab-bar.vue +3 -3
  176. package/packages/tabs/src/tab-nav.vue +13 -13
  177. package/packages/tabs/src/tabs.vue +3 -3
  178. package/packages/tag/src/tag.vue +3 -3
  179. package/packages/theme-cy/lib/element.css +1 -0
  180. package/packages/theme-cy/lib/fileUpload.css +1 -0
  181. package/packages/theme-cy/lib/index.css +1 -1
  182. package/packages/theme-cy/lib/subTitle.css +1 -0
  183. package/packages/theme-cy/lib/tabDialog.css +1 -0
  184. package/packages/theme-cy/lib/treeSelect.css +1 -0
  185. package/packages/theme-cy/src/element.scss +45 -0
  186. package/packages/theme-cy/src/fileUpload.scss +30 -0
  187. package/packages/theme-cy/src/index.scss +5 -1
  188. package/packages/theme-cy/src/subTitle.scss +26 -0
  189. package/packages/theme-cy/src/tabDialog.scss +43 -0
  190. package/packages/theme-cy/src/{treeselect.scss → treeSelect.scss} +93 -87
  191. package/packages/timeline/src/item.vue +2 -2
  192. package/packages/tooltip/src/main.js +1 -1
  193. package/packages/tree/src/tree-node.vue +3 -3
  194. package/packages/treeSelect/index.js +8 -0
  195. package/packages/{treeselect → treeSelect}/src/main.vue +246 -243
  196. package/packages/upload/src/ajax.js +3 -3
  197. package/packages/upload/src/upload-list.vue +1 -1
  198. package/packages/upload/src/upload.vue +1 -1
  199. package/src/index.js +13 -5
  200. package/src/locale/format.js +1 -2
  201. package/src/mixins/migrating.js +2 -2
  202. package/src/utils/types.js +1 -1
  203. package/types/element-ui.d.ts +18 -5
  204. package/types/fileUpload.d.ts +5 -0
  205. package/types/subTitle.d.ts +5 -0
  206. package/types/tabDialog.d.ts +5 -0
  207. package/types/treeSelect.d.ts +5 -0
  208. package/packages/theme-cy/lib/treeselect.css +0 -1
  209. package/packages/treeselect/index.js +0 -8
  210. package/types/treeselect.d.ts +0 -5
@@ -1,243 +1,246 @@
1
- <template>
2
- <div class="cy-treeselect">
3
- <el-popover v-model="popoverOpen" placement="bottom-start" width="300" trigger="click" :popper-class="popperClass" @show="popoverOpen = true" @hide="popoverOpen = false">
4
- <div class="cy-treeselect-select-con">
5
- <div v-if="showCheckStrictly" class="cy-treeselect-select-con-t">
6
- <el-checkbox v-model="isCheckStrictly">父子节点联动</el-checkbox>
7
- </div>
8
-
9
- <div class="cy-treeselect-select-con-c">
10
- <el-tree
11
- ref="tree"
12
- :data="treeOptions"
13
- :show-checkbox="multiple"
14
- :node-key="defaultOptions.id"
15
- :check-strictly="!isCheckStrictly"
16
- :props="defaultOptions"
17
- :expand-on-click-node="false"
18
- :default-expand-all="defaultExpandAll"
19
- @check="treeCheck"
20
- @node-click="treeClick"
21
- ></el-tree>
22
- </div>
23
- </div>
24
-
25
- <div slot="reference" class="cy-treeselect-select" :class="size" :style="vStyle">
26
- <div class="cy-treeselect-select-v">
27
- <span v-if="checkedArr.length < 1" class="cy-treeselect-select-v-placeholder">{{ placeholder }}</span>
28
- <span v-else>{{ checkedArr.map(item => item[defaultOptions.label]).join() }}</span>
29
- </div>
30
-
31
- <div class="cy-treeselect-select-v-icon" @mouseenter="isClearIcon = true" @mouseleave="isClearIcon = false">
32
- <i v-if="isClearIcon && clearable" class="el-icon-circle-close" @click.stop="handleClear"></i>
33
- <i v-else class="el-icon-arrow-down cy-treeselect-select-v-arrow" :class="{ 'cy-treeselect-select-v-arrow-show': popoverOpen }"></i>
34
- </div>
35
- </div>
36
- </el-popover>
37
- </div>
38
- </template>
39
-
40
- <script>
41
- import ElCheckbox from 'element-ui/packages/checkbox';
42
- import ElPopover from 'element-ui/packages/popover';
43
-
44
- export default {
45
- name: 'CyTreeselect',
46
- mixins: [ElCheckbox, ElPopover],
47
- model: {
48
- prop: 'value',
49
- event: 'change',
50
- },
51
- props: {
52
- value: {
53
- type: [String, Number, Array],
54
- default: ''
55
- },
56
-
57
- options: {
58
- type: Array,
59
- default: []
60
- },
61
-
62
- placeholder: {
63
- type: String,
64
- default: ''
65
- },
66
-
67
- // 尺寸
68
- size: {
69
- type: String,
70
- },
71
-
72
- // 是否显示 父子节点是否联动 多选框
73
- showCheckStrictly: {
74
- type: Boolean,
75
- default: true
76
- },
77
-
78
- // 父子节点是否联动
79
- checkStrictly: {
80
- type: Boolean,
81
- default: true
82
- },
83
-
84
- // 是否显示清空按钮
85
- clearable: {
86
- type: Boolean,
87
- default: false
88
- },
89
-
90
- // 是否多选
91
- multiple: {
92
- type: Boolean,
93
- default: false,
94
- },
95
-
96
- // 默认数据参数选项
97
- defaultOptions: {
98
- type: Object,
99
- default: () => {
100
- return {
101
- children: 'children',
102
- label: 'label',
103
- id: 'id'
104
- }
105
- }
106
- },
107
-
108
- // 树数据区域的样式
109
- vStyle: {
110
- type: [Array, String, Object],
111
- default: ''
112
- },
113
-
114
- // 树数据区域外层popover的class
115
- popperClass: {
116
- type: String,
117
- default: ''
118
- },
119
-
120
- // 是否默认展开所有节点
121
- defaultExpandAll: {
122
- type: Boolean,
123
- default: false
124
- }
125
- },
126
- data() {
127
- return {
128
- isCheckStrictly: true, // 父子节点是否联动
129
- popoverOpen: false, // 显示状态
130
- isClearIcon: false, // 清空按钮显示状态
131
-
132
- treeOptions: [], // 部门树列表
133
- treeArr: [], // 部门列表
134
- }
135
- },
136
- computed: {
137
- // 当前选中的数组
138
- checkedArr() {
139
- if (this.multiple) {
140
- let arr = [];
141
- this.value && this.value.forEach(id => {
142
- let cItem = this.treeArr.filter(tItem => tItem[this.defaultOptions.id] === id)[0];
143
- if (cItem) arr.push(cItem);
144
- })
145
- return arr
146
- } else {
147
- let cItem = this.treeArr.filter(tItem => tItem[this.defaultOptions.id] === Number(this.value))[0];
148
- return cItem ? [cItem] : []
149
- }
150
- }
151
- },
152
- watch: {
153
- checkStrictly: {
154
- immediate: true,
155
- handler() {
156
- this.isCheckStrictly = this.checkStrictly;
157
- }
158
- },
159
-
160
- value: {
161
- immediate: true,
162
- deep: true,
163
- handler() {
164
- this.$nextTick(() => {
165
- this.init();
166
- })
167
- }
168
- },
169
-
170
- options: {
171
- deep: true,
172
- immediate: true,
173
- handler() {
174
- this.treeOptions = this.options;
175
- this.treeArr = this.turnFormatTreeData([], this.treeOptions, 0);
176
- }
177
- }
178
- },
179
- created() {
180
-
181
- },
182
- methods: {
183
- init() {
184
- // 初始化是根据value,设置已选中项
185
- let arr = [];
186
- if (this.multiple) {
187
- arr = this.value ? this.value : [];
188
- } else {
189
- arr = this.value ? [this.value] : []
190
- }
191
- this.$nextTick(() => {
192
- this.$refs.tree.setCheckedKeys(arr);
193
- })
194
- },
195
-
196
- /**
197
- * 树复选框点击
198
- */
199
- treeCheck(value, { checkedKeys, checkedNodes }) {
200
- let arr = [];
201
- arr = checkedNodes;
202
- let idArr = arr.map(item => item[this.defaultOptions.id]);
203
- // 返回id数组
204
- this.$emit('change', this.multiple ? idArr : idArr[0], this.multiple ? arr : arr[0]);
205
- },
206
-
207
- /**
208
- * 树节点点击
209
- */
210
- treeClick(value, node, event) {
211
- if (this.multiple) return;
212
-
213
- this.$emit('change', value.id, value);
214
- this.popoverOpen = false;
215
- },
216
-
217
- /**
218
- * 清空
219
- */
220
- handleClear() {
221
- this.$emit('change', this.multiple ? [] : '', this.multiple ? [] : null);
222
- this.$refs.tree.setCheckedKeys([]);
223
- },
224
-
225
- /**
226
- * 部门树 格式化为 单例数组
227
- */
228
- turnFormatTreeData(arr, data, pId) {
229
- data.forEach(item => {
230
- let cItem = JSON.parse(JSON.stringify(item));
231
- delete cItem[this.defaultOptions.children];
232
- cItem.pId = pId;
233
- arr.push(cItem);
234
-
235
- if (item[this.defaultOptions.children] && item[this.defaultOptions.children].length > 0) {
236
- this.turnFormatTreeData(arr, item[this.defaultOptions.children], item[this.defaultOptions.id]);
237
- }
238
- })
239
- return arr
240
- },
241
- }
242
- };
243
- </script>
1
+ <template>
2
+ <div class="cy-tree-select">
3
+ <el-popover v-model="popoverOpen" placement="bottom-start" width="300" trigger="click" :popper-class="popperClass" @show="popoverOpen = true" @hide="popoverOpen = false">
4
+ <div class="cy-tree-select-select-con">
5
+ <div v-if="showCheckStrictly" class="cy-tree-select-select-con-t">
6
+ <el-checkbox v-model="isCheckStrictly">父子节点联动</el-checkbox>
7
+ </div>
8
+
9
+ <div class="cy-tree-select-select-con-c">
10
+ <el-tree
11
+ ref="tree"
12
+ :data="treeOptions"
13
+ :show-checkbox="multiple"
14
+ :node-key="defaultOptions.id"
15
+ :check-strictly="!isCheckStrictly"
16
+ :props="defaultOptions"
17
+ :expand-on-click-node="false"
18
+ :default-expand-all="defaultExpandAll"
19
+ @check="treeCheck"
20
+ @node-click="treeClick"
21
+ ></el-tree>
22
+ </div>
23
+ </div>
24
+
25
+ <div slot="reference" class="cy-tree-select-select" :class="size" :style="vStyle">
26
+ <div class="cy-tree-select-select-v">
27
+ <span v-if="checkedArr.length < 1" class="cy-tree-select-select-v-placeholder">{{ placeholder }}</span>
28
+ <span v-else>{{ checkedArr.map(item => item[defaultOptions.label]).join() }}</span>
29
+ </div>
30
+
31
+ <div class="cy-tree-select-select-v-icon" @mouseenter="isClearIcon = true" @mouseleave="isClearIcon = false">
32
+ <i v-if="isClearIcon && clearable" class="el-icon-circle-close" @click.stop="handleClear"></i>
33
+ <i v-else class="el-icon-arrow-down cy-tree-select-select-v-arrow" :class="{ 'cy-tree-select-select-v-arrow-show': popoverOpen }"></i>
34
+ </div>
35
+ </div>
36
+ </el-popover>
37
+ </div>
38
+ </template>
39
+
40
+ <script>
41
+ import ElCheckbox from 'element-ui/packages/checkbox';
42
+ import ElPopover from 'element-ui/packages/popover';
43
+
44
+ export default {
45
+ name: 'CyTreeSelect',
46
+ components: [
47
+ ElCheckbox,
48
+ ElPopover
49
+ ],
50
+ model: {
51
+ prop: 'value',
52
+ event: 'change',
53
+ },
54
+ props: {
55
+ value: {
56
+ type: [String, Number, Array],
57
+ default: ''
58
+ },
59
+
60
+ options: {
61
+ type: Array,
62
+ default: []
63
+ },
64
+
65
+ placeholder: {
66
+ type: String,
67
+ default: ''
68
+ },
69
+
70
+ // 尺寸
71
+ size: {
72
+ type: String,
73
+ },
74
+
75
+ // 是否显示 父子节点是否联动 多选框
76
+ showCheckStrictly: {
77
+ type: Boolean,
78
+ default: true
79
+ },
80
+
81
+ // 父子节点是否联动
82
+ checkStrictly: {
83
+ type: Boolean,
84
+ default: true
85
+ },
86
+
87
+ // 是否显示清空按钮
88
+ clearable: {
89
+ type: Boolean,
90
+ default: false
91
+ },
92
+
93
+ // 是否多选
94
+ multiple: {
95
+ type: Boolean,
96
+ default: false,
97
+ },
98
+
99
+ // 默认数据参数选项
100
+ defaultOptions: {
101
+ type: Object,
102
+ default: () => {
103
+ return {
104
+ children: 'children',
105
+ label: 'label',
106
+ id: 'id'
107
+ }
108
+ }
109
+ },
110
+
111
+ // 显示的文本框样式
112
+ vStyle: {
113
+ type: [Array, String, Object],
114
+ default: ''
115
+ },
116
+
117
+ // 树数据区域外层popover的class
118
+ popperClass: {
119
+ type: String,
120
+ default: ''
121
+ },
122
+
123
+ // 是否默认展开所有节点
124
+ defaultExpandAll: {
125
+ type: Boolean,
126
+ default: false
127
+ }
128
+ },
129
+ data() {
130
+ return {
131
+ isCheckStrictly: true, // 父子节点是否联动
132
+ popoverOpen: false, // 显示状态
133
+ isClearIcon: false, // 清空按钮显示状态
134
+
135
+ treeOptions: [], // 部门树列表
136
+ treeArr: [], // 部门列表
137
+ }
138
+ },
139
+ computed: {
140
+ // 当前选中的数组
141
+ checkedArr() {
142
+ if (this.multiple) {
143
+ let arr = [];
144
+ this.value && this.value.forEach(id => {
145
+ let cItem = this.treeArr.filter(tItem => tItem[this.defaultOptions.id] === id)[0];
146
+ if (cItem) arr.push(cItem);
147
+ })
148
+ return arr
149
+ } else {
150
+ let cItem = this.treeArr.filter(tItem => tItem[this.defaultOptions.id] === Number(this.value))[0];
151
+ return cItem ? [cItem] : []
152
+ }
153
+ }
154
+ },
155
+ watch: {
156
+ checkStrictly: {
157
+ immediate: true,
158
+ handler() {
159
+ this.isCheckStrictly = this.checkStrictly;
160
+ }
161
+ },
162
+
163
+ value: {
164
+ immediate: true,
165
+ deep: true,
166
+ handler() {
167
+ this.$nextTick(() => {
168
+ this.init();
169
+ })
170
+ }
171
+ },
172
+
173
+ options: {
174
+ deep: true,
175
+ immediate: true,
176
+ handler() {
177
+ this.treeOptions = this.options;
178
+ this.treeArr = this.turnFormatTreeData([], this.treeOptions, 0);
179
+ }
180
+ }
181
+ },
182
+ created() {
183
+
184
+ },
185
+ methods: {
186
+ init() {
187
+ // 初始化是根据value,设置已选中项
188
+ let arr = [];
189
+ if (this.multiple) {
190
+ arr = this.value ? this.value : [];
191
+ } else {
192
+ arr = this.value ? [this.value] : []
193
+ }
194
+ this.$nextTick(() => {
195
+ this.$refs.tree.setCheckedKeys(arr);
196
+ })
197
+ },
198
+
199
+ /**
200
+ * 树复选框点击
201
+ */
202
+ treeCheck(value, { checkedKeys, checkedNodes }) {
203
+ let arr = [];
204
+ arr = checkedNodes;
205
+ let idArr = arr.map(item => item[this.defaultOptions.id]);
206
+ // 返回id数组
207
+ this.$emit('change', this.multiple ? idArr : idArr[0], this.multiple ? arr : arr[0]);
208
+ },
209
+
210
+ /**
211
+ * 树节点点击
212
+ */
213
+ treeClick(value, node, event) {
214
+ if (this.multiple) return;
215
+
216
+ this.$emit('change', value.id, value);
217
+ this.popoverOpen = false;
218
+ },
219
+
220
+ /**
221
+ * 清空
222
+ */
223
+ handleClear() {
224
+ this.$emit('change', this.multiple ? [] : '', this.multiple ? [] : null);
225
+ this.$refs.tree.setCheckedKeys([]);
226
+ },
227
+
228
+ /**
229
+ * 部门树 格式化为 单例数组
230
+ */
231
+ turnFormatTreeData(arr, data, pId) {
232
+ data.forEach(item => {
233
+ let cItem = JSON.parse(JSON.stringify(item));
234
+ delete cItem[this.defaultOptions.children];
235
+ cItem.pId = pId;
236
+ arr.push(cItem);
237
+
238
+ if (item[this.defaultOptions.children] && item[this.defaultOptions.children].length > 0) {
239
+ this.turnFormatTreeData(arr, item[this.defaultOptions.children], item[this.defaultOptions.id]);
240
+ }
241
+ })
242
+ return arr
243
+ },
244
+ }
245
+ };
246
+ </script>
@@ -1,11 +1,11 @@
1
1
  function getError(action, option, xhr) {
2
2
  let msg;
3
3
  if (xhr.response) {
4
- msg = `${xhr.response.error || xhr.response}`;
4
+ msg = `${ xhr.response.error || xhr.response }`;
5
5
  } else if (xhr.responseText) {
6
- msg = `${xhr.responseText}`;
6
+ msg = `${ xhr.responseText }`;
7
7
  } else {
8
- msg = `fail to post ${action} ${xhr.status}`;
8
+ msg = `fail to post ${ action } ${ xhr.status }`;
9
9
  }
10
10
 
11
11
  const err = new Error(msg);
@@ -25,7 +25,7 @@
25
25
  :src="file.url" alt=""
26
26
  >
27
27
  <a class="el-upload-list__item-name" @click="handleClick(file)">
28
- <i class="el-icon-document"></i>{{file.name}}
28
+ <i class="el-icon-document"></i>{{ file.name }}
29
29
  </a>
30
30
  <label class="el-upload-list__item-status-label">
31
31
  <i :class="{
@@ -195,7 +195,7 @@ export default {
195
195
  keydown: handleKeydown
196
196
  }
197
197
  };
198
- data.class[`el-upload--${listType}`] = true;
198
+ data.class[`el-upload--${ listType }`] = true;
199
199
  return (
200
200
  <div {...data} tabindex="0" >
201
201
  {
package/src/index.js CHANGED
@@ -89,7 +89,10 @@ import Empty from '../packages/empty/index.js';
89
89
  import Descriptions from '../packages/descriptions/index.js';
90
90
  import DescriptionsItem from '../packages/descriptions-item/index.js';
91
91
  import Result from '../packages/result/index.js';
92
- import Treeselect from '../packages/treeselect/index.js';
92
+ import TreeSelect from '../packages/treeSelect/index.js';
93
+ import SubTitle from '../packages/subTitle/index.js';
94
+ import TabDialog from '../packages/tabDialog/index.js';
95
+ import FileUpload from '../packages/fileUpload/index.js';
93
96
  import locale from 'element-ui/src/locale';
94
97
  import CollapseTransition from 'element-ui/src/transitions/collapse-transition';
95
98
 
@@ -178,7 +181,9 @@ const components = [
178
181
  Descriptions,
179
182
  DescriptionsItem,
180
183
  Result,
181
- Treeselect,
184
+ TreeSelect,
185
+ SubTitle,
186
+ FileUpload,
182
187
  CollapseTransition
183
188
  ];
184
189
 
@@ -192,6 +197,7 @@ const install = function(Vue, opts = {}) {
192
197
 
193
198
  Vue.use(InfiniteScroll);
194
199
  Vue.use(Loading.directive);
200
+ Vue.use(TabDialog);
195
201
 
196
202
  Vue.prototype.$ELEMENT = {
197
203
  size: opts.size || '',
@@ -205,7 +211,6 @@ const install = function(Vue, opts = {}) {
205
211
  Vue.prototype.$prompt = MessageBox.prompt;
206
212
  Vue.prototype.$notify = Notification;
207
213
  Vue.prototype.$message = Message;
208
-
209
214
  };
210
215
 
211
216
  /* istanbul ignore if */
@@ -214,7 +219,7 @@ if (typeof window !== 'undefined' && window.Vue) {
214
219
  }
215
220
 
216
221
  export default {
217
- version: '1.0.28',
222
+ version: '1.0.29',
218
223
  locale: locale.use,
219
224
  i18n: locale.i18n,
220
225
  install,
@@ -308,5 +313,8 @@ export default {
308
313
  Descriptions,
309
314
  DescriptionsItem,
310
315
  Result,
311
- Treeselect
316
+ TreeSelect,
317
+ SubTitle,
318
+ TabDialog,
319
+ FileUpload
312
320
  };
@@ -6,8 +6,7 @@ const RE_NARGS = /(%|)\{([0-9a-zA-Z_]+)\}/g;
6
6
  * - Inspired:
7
7
  * https://github.com/Matt-Esch/string-template/index.js
8
8
  */
9
- export default function(Vue) {
10
-
9
+ export default function(Vue) {
11
10
  /**
12
11
  * template
13
12
  *
@@ -32,14 +32,14 @@ export default {
32
32
  for (let propName in definedProps) {
33
33
  propName = kebabCase(propName); // compatible with camel case
34
34
  if (props[propName]) {
35
- console.warn(`[Element Migrating][${this.$options.name}][Attribute]: ${props[propName]}`);
35
+ console.warn(`[Element Migrating][${ this.$options.name }][Attribute]: ${ props[propName] }`);
36
36
  }
37
37
  }
38
38
 
39
39
  for (let eventName in definedEvents) {
40
40
  eventName = kebabCase(eventName); // compatible with camel case
41
41
  if (events[eventName]) {
42
- console.warn(`[Element Migrating][${this.$options.name}][Event]: ${events[eventName]}`);
42
+ console.warn(`[Element Migrating][${ this.$options.name }][Event]: ${ events[eventName] }`);
43
43
  }
44
44
  }
45
45
  },
@@ -31,7 +31,7 @@ export {
31
31
  isFunction
32
32
  };
33
33
 
34
- export const isUndefined = (val)=> {
34
+ export const isUndefined = (val) => {
35
35
  return val === void 0;
36
36
  };
37
37
 
@@ -89,8 +89,12 @@ import { ElDescriptions } from './descriptions'
89
89
  import { ElDescriptionsItem } from './descriptions-item'
90
90
  import { ElResult } from './result'
91
91
  import { ElStatistic } from './statistic'
92
-
93
-
92
+
93
+ import { CyTreeSelect } from './treeSelect'
94
+ import { CySubTitle } from './subTitle'
95
+ import { CyTabDialog } from './tabDialog'
96
+ import { CyFileUpload } from './fileUpload'
97
+
94
98
  export interface InstallationOptions {
95
99
  locale: any,
96
100
  i18n: any,
@@ -381,6 +385,15 @@ export class Result extends ElResult {}
381
385
 
382
386
  /** Statistic Component */
383
387
  export class Statistic extends ElStatistic {}
384
-
385
- /** Treeselect Component */
386
- export class Treeselect extends CyTreeselect {}
388
+
389
+ /** TreeSelect Component */
390
+ export class TreeSelect extends CyTreeSelect {}
391
+
392
+ /** SubTitle Component */
393
+ export class SubTitle extends CySubTitle {}
394
+
395
+ /** TabDialog Component */
396
+ export class TabDialog extends CyTabDialog {}
397
+
398
+ /** FileUpload Component */
399
+ export class FileUpload extends CyFileUpload {}
@@ -0,0 +1,5 @@
1
+ import { CyUIComponent } from './component'
2
+
3
+ /** FileUpload Component */
4
+ export declare class CyFileUpload extends CyUIComponent {
5
+ }