yy-vue-easytable 2.27.2

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 (205) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +187 -0
  3. package/libs/font/demo.css +539 -0
  4. package/libs/font/demo_index.html +400 -0
  5. package/libs/font/iconfont.css +57 -0
  6. package/libs/font/iconfont.eot +0 -0
  7. package/libs/font/iconfont.js +1 -0
  8. package/libs/font/iconfont.json +79 -0
  9. package/libs/font/iconfont.svg +56 -0
  10. package/libs/font/iconfont.ttf +0 -0
  11. package/libs/font/iconfont.woff +0 -0
  12. package/libs/font/iconfont.woff2 +0 -0
  13. package/libs/locale/lang/af-ZA.js +48 -0
  14. package/libs/locale/lang/en-US.js +48 -0
  15. package/libs/locale/lang/fr-FR.js +48 -0
  16. package/libs/locale/lang/ko-KR.js +48 -0
  17. package/libs/locale/lang/pt-BR.js +48 -0
  18. package/libs/locale/lang/ru-RU.js +48 -0
  19. package/libs/locale/lang/zh-CN.js +48 -0
  20. package/libs/locale/lang/zh-TW.js +48 -0
  21. package/libs/locale/lang/zu-ZA.js +48 -0
  22. package/libs/main.js +1 -0
  23. package/libs/theme-dark/base.css +1 -0
  24. package/libs/theme-dark/index.css +1253 -0
  25. package/libs/theme-dark/var.css +7 -0
  26. package/libs/theme-dark/ve-checkbox.css +150 -0
  27. package/libs/theme-dark/ve-contextmenu.css +71 -0
  28. package/libs/theme-dark/ve-dropdown.css +177 -0
  29. package/libs/theme-dark/ve-icon.css +10 -0
  30. package/libs/theme-dark/ve-loading.css +218 -0
  31. package/libs/theme-dark/ve-pagination.css +136 -0
  32. package/libs/theme-dark/ve-radio.css +111 -0
  33. package/libs/theme-dark/ve-select.css +50 -0
  34. package/libs/theme-dark/ve-table.css +385 -0
  35. package/libs/theme-default/base.css +1 -0
  36. package/libs/theme-default/index.css +1253 -0
  37. package/libs/theme-default/var.css +7 -0
  38. package/libs/theme-default/ve-checkbox.css +150 -0
  39. package/libs/theme-default/ve-contextmenu.css +71 -0
  40. package/libs/theme-default/ve-dropdown.css +177 -0
  41. package/libs/theme-default/ve-icon.css +10 -0
  42. package/libs/theme-default/ve-loading.css +218 -0
  43. package/libs/theme-default/ve-pagination.css +136 -0
  44. package/libs/theme-default/ve-radio.css +111 -0
  45. package/libs/theme-default/ve-select.css +50 -0
  46. package/libs/theme-default/ve-table.css +385 -0
  47. package/libs/umd/index.js +9 -0
  48. package/libs/ve-checkbox-group.js +1 -0
  49. package/libs/ve-checkbox.js +1 -0
  50. package/libs/ve-contextmenu.js +1 -0
  51. package/libs/ve-dropdown.js +1 -0
  52. package/libs/ve-icon.js +1 -0
  53. package/libs/ve-loading.js +1 -0
  54. package/libs/ve-locale.js +1 -0
  55. package/libs/ve-pagination.js +1 -0
  56. package/libs/ve-radio.js +1 -0
  57. package/libs/ve-select.js +1 -0
  58. package/libs/ve-table.js +1 -0
  59. package/package.json +142 -0
  60. package/packages/font/demo.css +539 -0
  61. package/packages/font/demo_index.html +400 -0
  62. package/packages/font/iconfont.css +57 -0
  63. package/packages/font/iconfont.eot +0 -0
  64. package/packages/font/iconfont.js +1 -0
  65. package/packages/font/iconfont.json +79 -0
  66. package/packages/font/iconfont.svg +56 -0
  67. package/packages/font/iconfont.ttf +0 -0
  68. package/packages/font/iconfont.woff +0 -0
  69. package/packages/font/iconfont.woff2 +0 -0
  70. package/packages/index.js +75 -0
  71. package/packages/src/comps/resize-observer/index.js +2 -0
  72. package/packages/src/comps/resize-observer/src/index.jsx +38 -0
  73. package/packages/src/directives/clickoutside.js +31 -0
  74. package/packages/src/directives/events-outside.js +79 -0
  75. package/packages/src/directives/focus.js +28 -0
  76. package/packages/src/locale/index.js +27 -0
  77. package/packages/src/locale/lang/af-ZA.js +29 -0
  78. package/packages/src/locale/lang/en-US.js +30 -0
  79. package/packages/src/locale/lang/fr-FR.js +29 -0
  80. package/packages/src/locale/lang/ko-KR.js +29 -0
  81. package/packages/src/locale/lang/pt-BR.js +29 -0
  82. package/packages/src/locale/lang/ru-RU.js +29 -0
  83. package/packages/src/locale/lang/zh-CN.js +30 -0
  84. package/packages/src/locale/lang/zh-TW.js +29 -0
  85. package/packages/src/locale/lang/zu-ZA.js +29 -0
  86. package/packages/src/mixins/emitter.js +39 -0
  87. package/packages/src/utils/animation-frame.js +39 -0
  88. package/packages/src/utils/auto-resize.js +179 -0
  89. package/packages/src/utils/constant.js +42 -0
  90. package/packages/src/utils/dom.js +239 -0
  91. package/packages/src/utils/event-key-codes.js +53 -0
  92. package/packages/src/utils/hooks-manager.js +76 -0
  93. package/packages/src/utils/index.js +161 -0
  94. package/packages/src/utils/mouse-event.js +24 -0
  95. package/packages/src/utils/random.js +6 -0
  96. package/packages/src/utils/request-animation-timeout.js +36 -0
  97. package/packages/src/utils/resize-event.js +40 -0
  98. package/packages/src/utils/scroll-bar.js +27 -0
  99. package/packages/style/ve-checkbox.less +179 -0
  100. package/packages/style/ve-contextmenu.less +76 -0
  101. package/packages/style/ve-dropdown.less +204 -0
  102. package/packages/style/ve-icon.less +3 -0
  103. package/packages/style/ve-loading.less +242 -0
  104. package/packages/style/ve-pagination.less +153 -0
  105. package/packages/style/ve-radio.less +126 -0
  106. package/packages/style/ve-select.less +48 -0
  107. package/packages/style/ve-table.less +539 -0
  108. package/packages/theme-dark/base.less +1 -0
  109. package/packages/theme-dark/index.less +12 -0
  110. package/packages/theme-dark/var.less +111 -0
  111. package/packages/theme-dark/ve-checkbox.less +2 -0
  112. package/packages/theme-dark/ve-contextmenu.less +2 -0
  113. package/packages/theme-dark/ve-dropdown.less +2 -0
  114. package/packages/theme-dark/ve-icon.less +2 -0
  115. package/packages/theme-dark/ve-loading.less +2 -0
  116. package/packages/theme-dark/ve-pagination.less +2 -0
  117. package/packages/theme-dark/ve-radio.less +2 -0
  118. package/packages/theme-dark/ve-select.less +2 -0
  119. package/packages/theme-dark/ve-table.less +2 -0
  120. package/packages/theme-default/base.less +1 -0
  121. package/packages/theme-default/index.less +12 -0
  122. package/packages/theme-default/var.less +111 -0
  123. package/packages/theme-default/ve-checkbox.less +2 -0
  124. package/packages/theme-default/ve-contextmenu.less +2 -0
  125. package/packages/theme-default/ve-dropdown.less +2 -0
  126. package/packages/theme-default/ve-icon.less +2 -0
  127. package/packages/theme-default/ve-loading.less +2 -0
  128. package/packages/theme-default/ve-pagination.less +2 -0
  129. package/packages/theme-default/ve-radio.less +2 -0
  130. package/packages/theme-default/ve-select.less +2 -0
  131. package/packages/theme-default/ve-table.less +2 -0
  132. package/packages/ve-checkbox/index.js +7 -0
  133. package/packages/ve-checkbox/src/index.jsx +175 -0
  134. package/packages/ve-checkbox/src/util/constant.js +14 -0
  135. package/packages/ve-checkbox/src/util/index.js +10 -0
  136. package/packages/ve-checkbox-group/index.js +7 -0
  137. package/packages/ve-checkbox-group/src/index.jsx +53 -0
  138. package/packages/ve-checkbox-group/src/util/constant.js +14 -0
  139. package/packages/ve-checkbox-group/src/util/index.js +10 -0
  140. package/packages/ve-contextmenu/index.js +7 -0
  141. package/packages/ve-contextmenu/src/index.jsx +731 -0
  142. package/packages/ve-contextmenu/src/util/constant.js +29 -0
  143. package/packages/ve-contextmenu/src/util/index.js +10 -0
  144. package/packages/ve-dropdown/index.js +7 -0
  145. package/packages/ve-dropdown/src/index.jsx +720 -0
  146. package/packages/ve-dropdown/src/util/constant.js +15 -0
  147. package/packages/ve-dropdown/src/util/index.js +10 -0
  148. package/packages/ve-icon/index.js +7 -0
  149. package/packages/ve-icon/src/index.jsx +52 -0
  150. package/packages/ve-icon/src/util/constant.js +10 -0
  151. package/packages/ve-icon/src/util/index.js +10 -0
  152. package/packages/ve-loading/index.js +8 -0
  153. package/packages/ve-loading/src/bounce.jsx +50 -0
  154. package/packages/ve-loading/src/flow.jsx +51 -0
  155. package/packages/ve-loading/src/grid.jsx +57 -0
  156. package/packages/ve-loading/src/index.js +106 -0
  157. package/packages/ve-loading/src/loading.jsx +63 -0
  158. package/packages/ve-loading/src/plane.jsx +38 -0
  159. package/packages/ve-loading/src/pulse.jsx +38 -0
  160. package/packages/ve-loading/src/util/constant.js +31 -0
  161. package/packages/ve-loading/src/util/index.js +10 -0
  162. package/packages/ve-loading/src/wave.jsx +53 -0
  163. package/packages/ve-locale/index.js +28 -0
  164. package/packages/ve-pagination/index.js +7 -0
  165. package/packages/ve-pagination/src/index.jsx +304 -0
  166. package/packages/ve-pagination/src/pager.jsx +166 -0
  167. package/packages/ve-pagination/src/util/constant.js +16 -0
  168. package/packages/ve-pagination/src/util/index.js +10 -0
  169. package/packages/ve-radio/index.js +7 -0
  170. package/packages/ve-radio/src/index.jsx +121 -0
  171. package/packages/ve-radio/src/util/constant.js +13 -0
  172. package/packages/ve-radio/src/util/index.js +10 -0
  173. package/packages/ve-select/index.js +7 -0
  174. package/packages/ve-select/src/index.jsx +193 -0
  175. package/packages/ve-select/src/util/constant.js +13 -0
  176. package/packages/ve-select/src/util/index.js +10 -0
  177. package/packages/ve-table/index.js +7 -0
  178. package/packages/ve-table/src/body/body-checkbox-content.jsx +126 -0
  179. package/packages/ve-table/src/body/body-radio-content.jsx +113 -0
  180. package/packages/ve-table/src/body/body-td.jsx +671 -0
  181. package/packages/ve-table/src/body/body-tr-scrolling.jsx +38 -0
  182. package/packages/ve-table/src/body/body-tr.jsx +383 -0
  183. package/packages/ve-table/src/body/expand-tr-icon.jsx +80 -0
  184. package/packages/ve-table/src/body/expand-tr.jsx +147 -0
  185. package/packages/ve-table/src/body/index.jsx +943 -0
  186. package/packages/ve-table/src/colgroup/index.jsx +48 -0
  187. package/packages/ve-table/src/column-resizer/index.jsx +318 -0
  188. package/packages/ve-table/src/editor/constant.js +5 -0
  189. package/packages/ve-table/src/editor/index.jsx +533 -0
  190. package/packages/ve-table/src/footer/footer-td.jsx +396 -0
  191. package/packages/ve-table/src/footer/footer-tr.jsx +249 -0
  192. package/packages/ve-table/src/footer/index.jsx +108 -0
  193. package/packages/ve-table/src/header/header-checkbox-content.jsx +69 -0
  194. package/packages/ve-table/src/header/header-filter-content.jsx +100 -0
  195. package/packages/ve-table/src/header/header-filter-custom-content.jsx +110 -0
  196. package/packages/ve-table/src/header/header-th.jsx +664 -0
  197. package/packages/ve-table/src/header/header-tr.jsx +255 -0
  198. package/packages/ve-table/src/header/index.jsx +195 -0
  199. package/packages/ve-table/src/index.jsx +4196 -0
  200. package/packages/ve-table/src/selection/constant.js +5 -0
  201. package/packages/ve-table/src/selection/index.jsx +1643 -0
  202. package/packages/ve-table/src/util/clipboard.js +428 -0
  203. package/packages/ve-table/src/util/constant.js +269 -0
  204. package/packages/ve-table/src/util/index.js +1585 -0
  205. package/packages/ve-table/src/util/store.js +14 -0
@@ -0,0 +1,304 @@
1
+ import Pager from "./pager.jsx";
2
+ import VeSelect from "vue-easytable/packages/ve-select";
3
+ import VeIcon from "vue-easytable/packages/ve-icon";
4
+ import { COMPS_NAME, EMIT_EVENTS, LOCALE_COMP_NAME } from "./util/constant";
5
+ import { clsName } from "./util";
6
+ import { createLocale } from "../../src/utils/index";
7
+ import { ICON_NAMES } from "../../src/utils/constant";
8
+
9
+ const t = createLocale(LOCALE_COMP_NAME);
10
+
11
+ export default {
12
+ name: COMPS_NAME.VE_PAGINATION,
13
+
14
+ components: {
15
+ Total: {
16
+ render() {
17
+ return (
18
+ <span class={clsName("total")}>
19
+ {t("total", this.$parent.total)}
20
+ </span>
21
+ );
22
+ },
23
+ },
24
+
25
+ Prev: {
26
+ render() {
27
+ return (
28
+ <li
29
+ on-click={this.$parent.prevPage}
30
+ class={[
31
+ this.$parent.newPageIndex === 1
32
+ ? clsName("disabled")
33
+ : "",
34
+ clsName("li"),
35
+ clsName("prev"),
36
+ ]}
37
+ >
38
+ <a>
39
+ <VeIcon name={ICON_NAMES.LEFT_ARROW} />
40
+ </a>
41
+ </li>
42
+ );
43
+ },
44
+ },
45
+
46
+ Pager,
47
+
48
+ Next: {
49
+ render() {
50
+ return (
51
+ <li
52
+ on-click={this.$parent.nextPage}
53
+ class={[
54
+ this.$parent.newPageIndex === this.$parent.pageCount
55
+ ? clsName("disabled")
56
+ : "",
57
+ clsName("li"),
58
+ clsName("next"),
59
+ ]}
60
+ >
61
+ <a>
62
+ <VeIcon name={ICON_NAMES.RIGHT_ARROW} />
63
+ </a>
64
+ </li>
65
+ );
66
+ },
67
+ },
68
+
69
+ Sizer: {
70
+ render() {
71
+ return (
72
+ <VeSelect
73
+ class={clsName("select")}
74
+ value={this.$parent.newPageSizeOption}
75
+ popperAppendTo={this.$parent.popperAppendTo}
76
+ on-input={this.handleChange}
77
+ //v-model={this.$parent.newPageSizeOption}
78
+ />
79
+ );
80
+ },
81
+
82
+ methods: {
83
+ handleChange(items) {
84
+ if (Array.isArray(items) && items.length > 0) {
85
+ let item = items.find((x) => x.selected);
86
+ if (item) {
87
+ this.$parent.pageSizeChangeHandler(item.value);
88
+ }
89
+ }
90
+ },
91
+ },
92
+ },
93
+
94
+ Jumper: {
95
+ methods: {
96
+ jumperEnter(event) {
97
+ if (event.keyCode !== 13) return;
98
+
99
+ var val = this.$parent.getValidNum(event.target.value);
100
+ // bug fixed #483
101
+ event.target.value = val;
102
+ this.$parent.jumpPageHandler(val);
103
+ },
104
+ },
105
+ render() {
106
+ return (
107
+ <span class={clsName("goto")}>
108
+ &nbsp;{t("goto")}&nbsp;
109
+ <input
110
+ class={clsName("goto-input")}
111
+ domProps-value={this.$parent.newPageIndex}
112
+ on-keyup={this.jumperEnter}
113
+ type="input"
114
+ />
115
+ &nbsp;{t("page")}&nbsp;
116
+ </span>
117
+ );
118
+ },
119
+ },
120
+ },
121
+ props: {
122
+ layout: {
123
+ type: Array,
124
+ default() {
125
+ return ["total", "prev", "pager", "next", "sizer", "jumper"];
126
+ },
127
+ },
128
+
129
+ // 总条数
130
+ total: {
131
+ type: Number,
132
+ required: true,
133
+ },
134
+
135
+ // 当前页
136
+ pageIndex: {
137
+ type: Number,
138
+ default: 1,
139
+ },
140
+
141
+ // 最多显示几个数字按钮
142
+ pagingCount: {
143
+ type: Number,
144
+ default: 5,
145
+ },
146
+
147
+ // 每页大小
148
+ pageSize: {
149
+ type: Number,
150
+ default: 10,
151
+ },
152
+
153
+ // 每页大小下拉配置
154
+ pageSizeOption: {
155
+ type: Array,
156
+ default: function () {
157
+ return [10, 20, 30];
158
+ },
159
+ },
160
+ // popper append to element
161
+ popperAppendTo: {
162
+ type: [String, HTMLElement],
163
+ default: function () {
164
+ return document.body;
165
+ },
166
+ },
167
+ },
168
+ data() {
169
+ return {
170
+ newPageIndex:
171
+ this.pageIndex && this.pageIndex > 0
172
+ ? parseInt(this.pageIndex)
173
+ : 1,
174
+
175
+ newPageSize: this.pageSize,
176
+ };
177
+ },
178
+
179
+ computed: {
180
+ pageCount() {
181
+ return Math.ceil(this.total / this.newPageSize);
182
+ },
183
+ newPageSizeOption() {
184
+ return this.pageSizeOption.map((x) => {
185
+ var temp = {};
186
+
187
+ temp.value = x;
188
+ temp.label = x + t("itemsPerPage");
189
+ if (this.newPageSize == x) {
190
+ temp.selected = true;
191
+ }
192
+
193
+ return temp;
194
+ });
195
+ },
196
+ },
197
+ watch: {
198
+ pageIndex: function (newVal) {
199
+ this.newPageIndex = newVal;
200
+ },
201
+
202
+ pageSize: function (newVal) {
203
+ this.newPageSize = newVal;
204
+ },
205
+ },
206
+
207
+ methods: {
208
+ getValidNum(value) {
209
+ let result = 1;
210
+
211
+ value = parseInt(value, 10);
212
+
213
+ if (isNaN(value) || value < 1) {
214
+ result = 1;
215
+ } else {
216
+ if (value < 1) {
217
+ result = 1;
218
+ } else if (value > this.pageCount) {
219
+ result = this.pageCount;
220
+ } else {
221
+ result = value;
222
+ }
223
+ }
224
+ return result;
225
+ },
226
+
227
+ jumpPageHandler(newPageIndex) {
228
+ this.newPageIndex = newPageIndex;
229
+ this.$emit(EMIT_EVENTS.PAGE_NUMBER_CHANGE, this.newPageIndex);
230
+ },
231
+
232
+ // 上一页
233
+ prevPage() {
234
+ if (this.newPageIndex > 1) {
235
+ this.newPageIndex = this.newPageIndex - 1;
236
+ this.$emit(EMIT_EVENTS.PAGE_NUMBER_CHANGE, this.newPageIndex);
237
+ }
238
+ },
239
+
240
+ // 下一页
241
+ nextPage() {
242
+ if (this.newPageIndex < this.pageCount) {
243
+ this.newPageIndex = this.newPageIndex + 1;
244
+ this.$emit(EMIT_EVENTS.PAGE_NUMBER_CHANGE, this.newPageIndex);
245
+ }
246
+ },
247
+
248
+ // 改变页面大小
249
+ pageSizeChangeHandler() {
250
+ let item = this.newPageSizeOption.find((x) => x.selected);
251
+
252
+ if (item) {
253
+ this.newPageSize = item.value;
254
+ this.newPageIndex = 1;
255
+ this.$emit(EMIT_EVENTS.PAGE_SIZE_CHANGE, this.newPageSize);
256
+ }
257
+ },
258
+
259
+ // 回到初始页码
260
+ goBackPageIndex() {
261
+ this.newPageIndex =
262
+ this.pageIndex && this.pageIndex > 0
263
+ ? parseInt(this.pageIndex)
264
+ : 1;
265
+ },
266
+
267
+ // 还原每页大小
268
+ goBackPageSize() {
269
+ if (this.pageSize > 0) {
270
+ this.newPageSize = this.pageSize;
271
+ }
272
+ },
273
+ },
274
+ render() {
275
+ let template = <ul class="ve-pagination"></ul>;
276
+
277
+ var comps = {
278
+ //'total','prev','pager','next','sizer','jumper'
279
+ total: <total></total>,
280
+ prev: <prev></prev>,
281
+ pager: (
282
+ <pager
283
+ pageCount={this.pageCount}
284
+ pageIndex={this.newPageIndex}
285
+ pagingCount={this.pagingCount}
286
+ onJumpPageHandler={this.jumpPageHandler}
287
+ ></pager>
288
+ ),
289
+ next: <next></next>,
290
+ sizer: <sizer></sizer>,
291
+ jumper: <jumper onJumpPageHandler={this.jumpPageHandler}></jumper>,
292
+ };
293
+
294
+ // https://github.com/ElemeFE/element/issues/10033
295
+ // https://github.com/ElemeFE/element/issues/9587
296
+ template.children = template.children || [];
297
+
298
+ this.layout.forEach((item) => {
299
+ template.children.push(comps[item]);
300
+ });
301
+
302
+ return template;
303
+ },
304
+ };
@@ -0,0 +1,166 @@
1
+ import VeIcon from "vue-easytable/packages/ve-icon";
2
+ import { clsName } from "./util";
3
+ import { LOCALE_COMP_NAME } from "./util/constant";
4
+ import { createLocale } from "../../src/utils/index";
5
+ import { ICON_NAMES } from "../../src/utils/constant";
6
+ const t = createLocale(LOCALE_COMP_NAME);
7
+
8
+ export default {
9
+ props: {
10
+ pageCount: {
11
+ type: Number,
12
+ required: true,
13
+ },
14
+ pageIndex: {
15
+ type: Number,
16
+ required: true,
17
+ },
18
+ pagingCount: {
19
+ type: Number,
20
+ required: true,
21
+ },
22
+ },
23
+ computed: {
24
+ numOffset() {
25
+ return Math.floor((this.pagingCount + 2) / 2) - 1;
26
+ },
27
+
28
+ showJumpPrev() {
29
+ if (this.pageCount > this.pagingCount + 2) {
30
+ if (this.pageIndex > this.pagingCount) {
31
+ return true;
32
+ }
33
+ }
34
+ return false;
35
+ },
36
+
37
+ showJumpNext() {
38
+ if (this.pageCount > this.pagingCount + 2) {
39
+ //if (this.pageIndex < this.pageCount - this.numOffset) {
40
+ if (this.pageIndex <= this.pageCount - this.pagingCount) {
41
+ return true;
42
+ }
43
+ }
44
+ return false;
45
+ },
46
+
47
+ // 当前要显示的数字按钮集合
48
+ pagingCounts() {
49
+ let startNum,
50
+ result = [],
51
+ showJumpPrev = this.showJumpPrev,
52
+ showJumpNext = this.showJumpNext;
53
+
54
+ if (showJumpPrev && !showJumpNext) {
55
+ startNum = this.pageCount - this.pagingCount;
56
+ for (let i = startNum; i < this.pageCount; i++) {
57
+ result.push(i);
58
+ }
59
+ } else if (!showJumpPrev && showJumpNext) {
60
+ for (let i = 2; i < this.pagingCount + 2; i++) {
61
+ result.push(i);
62
+ }
63
+ } else if (showJumpPrev && showJumpNext) {
64
+ for (
65
+ let i = this.pageIndex - this.numOffset;
66
+ i <= this.pageIndex + this.numOffset;
67
+ i++
68
+ ) {
69
+ result.push(i);
70
+ }
71
+ } else {
72
+ for (let i = 2; i < this.pageCount; i++) {
73
+ result.push(i);
74
+ }
75
+ }
76
+
77
+ return result;
78
+ },
79
+ },
80
+ methods: {
81
+ jumpPage(pageIndex) {
82
+ this.$emit("jumpPageHandler", pageIndex);
83
+ },
84
+ },
85
+ render() {
86
+ const {
87
+ pageIndex,
88
+ jumpPage,
89
+ showJumpPrev,
90
+ pagingCount,
91
+ pagingCounts,
92
+ showJumpNext,
93
+ pageCount,
94
+ } = this;
95
+
96
+ return (
97
+ <span class={clsName("pager")}>
98
+ <li
99
+ class={[
100
+ pageIndex === 1 ? clsName("li-active") : "",
101
+ clsName("li"),
102
+ ]}
103
+ on-click={() => jumpPage(1)}
104
+ >
105
+ <a>1</a>
106
+ </li>
107
+
108
+ {showJumpPrev && (
109
+ <li
110
+ class={[
111
+ pageIndex === 1 ? "disabled" : "",
112
+ clsName("li"),
113
+ clsName("jump-prev"),
114
+ ]}
115
+ title={t("prev5", pagingCount)}
116
+ on-click={() => jumpPage(pageIndex - pagingCount)}
117
+ >
118
+ <a>
119
+ <VeIcon name={ICON_NAMES.DOUBLE_LEFT_ARROW} />
120
+ </a>
121
+ </li>
122
+ )}
123
+ {pagingCounts.map((number, index) => {
124
+ return (
125
+ <li
126
+ key={index}
127
+ class={[
128
+ number === pageIndex
129
+ ? clsName("li-active")
130
+ : "",
131
+ clsName("li"),
132
+ ]}
133
+ on-click={() => jumpPage(number)}
134
+ >
135
+ <a>{number}</a>
136
+ </li>
137
+ );
138
+ })}
139
+
140
+ {showJumpNext && (
141
+ <li
142
+ class={[clsName("li"), clsName("jump-next")]}
143
+ title={t("next5", pagingCount)}
144
+ on-click={() => jumpPage(pageIndex + pagingCount)}
145
+ >
146
+ <a>
147
+ <VeIcon name={ICON_NAMES.DOUBLE_RIGHT_ARROW} />
148
+ </a>
149
+ </li>
150
+ )}
151
+
152
+ {pageCount > 1 && (
153
+ <li
154
+ class={[
155
+ pageIndex === pageCount ? clsName("li-active") : "",
156
+ clsName("li"),
157
+ ]}
158
+ on-click={() => jumpPage(pageCount)}
159
+ >
160
+ <a>{pageCount}</a>
161
+ </li>
162
+ )}
163
+ </span>
164
+ );
165
+ },
166
+ };
@@ -0,0 +1,16 @@
1
+ // prefix
2
+ export const PREFIX_CLS = "ve-pagination-";
3
+
4
+ // locale comp name
5
+ export const LOCALE_COMP_NAME = "pagination";
6
+
7
+ // emit events
8
+ export const EMIT_EVENTS = {
9
+ PAGE_NUMBER_CHANGE: "on-page-number-change",
10
+ PAGE_SIZE_CHANGE: "on-page-size-change",
11
+ };
12
+
13
+ // comps name
14
+ export const COMPS_NAME = {
15
+ VE_PAGINATION: "VePagination",
16
+ };
@@ -0,0 +1,10 @@
1
+ import { PREFIX_CLS } from "./constant";
2
+
3
+ /*
4
+ * @clsName
5
+ * @desc get class name
6
+ * @param {string} cls - class
7
+ */
8
+ export function clsName(cls) {
9
+ return PREFIX_CLS + cls;
10
+ }
@@ -0,0 +1,7 @@
1
+ import VeRadio from "./src/index";
2
+
3
+ VeRadio.install = function (Vue) {
4
+ Vue.component(VeRadio.name, VeRadio);
5
+ };
6
+
7
+ export default VeRadio;
@@ -0,0 +1,121 @@
1
+ import { clsName } from "./util";
2
+ import { COMPS_NAME, EMIT_EVENTS } from "./util/constant";
3
+
4
+ export default {
5
+ name: COMPS_NAME.VE_RADIO,
6
+ props: {
7
+ // 当前checkbox 选中状态,实现 v-model
8
+ value: {
9
+ type: [String, Number, Boolean],
10
+ default: null,
11
+ },
12
+ label: {
13
+ type: String,
14
+ default: null,
15
+ },
16
+ // is disabled checked
17
+ disabled: Boolean,
18
+ // 是否是可控组件
19
+ isControlled: {
20
+ type: Boolean,
21
+ default: false,
22
+ },
23
+ // isControlled 为true 时生效
24
+ isSelected: {
25
+ type: Boolean,
26
+ default: false,
27
+ },
28
+ },
29
+ data() {
30
+ return {
31
+ // 当前checkbox 选中状态
32
+ model: this.value,
33
+ };
34
+ },
35
+
36
+ computed: {
37
+ radioClass() {
38
+ return [
39
+ clsName("container"),
40
+ {
41
+ [clsName("checked")]: this.internalIsSelected,
42
+ [clsName("disabled")]: this.disabled,
43
+ },
44
+ ];
45
+ },
46
+
47
+ // 是否选中
48
+ internalIsSelected() {
49
+ return this.isControlled ? this.isSelected : this.model;
50
+ },
51
+ },
52
+
53
+ watch: {
54
+ value() {
55
+ this.updateModelBySingle();
56
+ },
57
+ },
58
+
59
+ methods: {
60
+ // checked change
61
+ checkedChange(event) {
62
+ if (this.disabled) {
63
+ return false;
64
+ }
65
+ const isChecked = event.target.checked;
66
+
67
+ if (!this.isControlled) {
68
+ this.$emit("input", isChecked);
69
+ }
70
+ this.$emit(EMIT_EVENTS.ON_RADIO_CHANGE, isChecked);
71
+ },
72
+
73
+ // get label content
74
+ getLabelContent() {
75
+ const { label, $slots } = this;
76
+
77
+ return label ? label : $slots.default;
78
+ },
79
+
80
+ initModel() {
81
+ this.model = this.value;
82
+ },
83
+
84
+ // 通过单选更新 model
85
+ updateModelBySingle() {
86
+ if (!this.disabled) {
87
+ this.model = this.value;
88
+ }
89
+ },
90
+ },
91
+
92
+ created() {
93
+ this.initModel();
94
+ },
95
+ render() {
96
+ const {
97
+ label,
98
+ radioClass,
99
+ checkedChange,
100
+ getLabelContent,
101
+ internalIsSelected,
102
+ } = this;
103
+
104
+ return (
105
+ <label class={"ve-radio"}>
106
+ <span class={radioClass}>
107
+ <input
108
+ checked={internalIsSelected}
109
+ class={clsName("input")}
110
+ type="radio"
111
+ value={label}
112
+ on-change={checkedChange}
113
+ />
114
+
115
+ <span class={clsName("inner")}></span>
116
+ </span>
117
+ <span class={clsName("label")}>{getLabelContent()}</span>
118
+ </label>
119
+ );
120
+ },
121
+ };
@@ -0,0 +1,13 @@
1
+ // prefix
2
+ export const PREFIX_CLS = "ve-radio-";
3
+
4
+ // emit events
5
+ export const EMIT_EVENTS = {
6
+ // on radio change
7
+ ON_RADIO_CHANGE: "on-radio-change",
8
+ };
9
+
10
+ // comps name
11
+ export const COMPS_NAME = {
12
+ VE_RADIO: "VeRadio",
13
+ };
@@ -0,0 +1,10 @@
1
+ import { PREFIX_CLS } from "./constant";
2
+
3
+ /*
4
+ * @clsName
5
+ * @desc get class name
6
+ * @param {string} cls - class
7
+ */
8
+ export function clsName(cls) {
9
+ return PREFIX_CLS + cls;
10
+ }
@@ -0,0 +1,7 @@
1
+ import VeSelect from "./src/index.jsx";
2
+
3
+ VeSelect.install = function (Vue) {
4
+ Vue.component(VeSelect.name, VeSelect);
5
+ };
6
+
7
+ export default VeSelect;