vxe-table 4.2.8 → 4.3.0-beta.0

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 (204) hide show
  1. package/es/button/src/button.js +14 -14
  2. package/es/button/style.css +1 -58
  3. package/es/checkbox/src/checkbox.js +1 -1
  4. package/es/edit/src/hook.js +29 -13
  5. package/es/export/src/export-panel.js +1 -1
  6. package/es/export/src/hook.js +45 -45
  7. package/es/export/src/import-panel.js +2 -2
  8. package/es/export/src/util.js +7 -7
  9. package/es/filter/src/hook.js +5 -5
  10. package/es/filter/src/panel.js +1 -1
  11. package/es/footer/src/footer.js +15 -15
  12. package/es/form/src/form-config-item.js +8 -7
  13. package/es/form/src/form-item.js +8 -7
  14. package/es/form/src/form.js +8 -6
  15. package/es/form/style.css +0 -3
  16. package/es/grid/src/grid.js +18 -13
  17. package/es/grid/style.css +1 -1
  18. package/es/header/src/header.js +18 -18
  19. package/es/header/style.css +0 -95
  20. package/es/icon/style.css +371 -495
  21. package/es/input/src/input.js +26 -26
  22. package/es/input/style.css +13 -4
  23. package/es/keyboard/src/hook.js +7 -7
  24. package/es/list/src/list.js +5 -5
  25. package/es/loading/src/loading.js +1 -1
  26. package/es/menu/src/hooks.js +9 -9
  27. package/es/menu/src/panel.js +2 -2
  28. package/es/modal/src/modal.js +52 -51
  29. package/es/modal/style.css +2 -3
  30. package/es/pager/src/pager.js +3 -3
  31. package/es/pager/style.css +4 -2
  32. package/es/pulldown/src/pulldown.js +7 -7
  33. package/es/radio/src/button.js +1 -1
  34. package/es/radio/src/radio.js +1 -1
  35. package/es/select/src/select.js +13 -12
  36. package/es/select/style.css +1 -0
  37. package/es/style.css +1 -1
  38. package/es/style.min.css +1 -1
  39. package/es/switch/src/switch.js +1 -1
  40. package/es/table/src/body.js +38 -34
  41. package/es/table/src/cell.js +12 -8
  42. package/es/table/src/columnInfo.js +4 -4
  43. package/es/table/src/table.js +63 -58
  44. package/es/table/src/util.js +2 -2
  45. package/es/table/style.css +98 -0
  46. package/es/textarea/src/textarea.js +5 -5
  47. package/es/toolbar/src/toolbar.js +7 -6
  48. package/es/toolbar/style.css +1 -1
  49. package/es/tools/dom.js +2 -2
  50. package/es/tools/log.js +1 -1
  51. package/es/tools/vn.js +7 -0
  52. package/es/tooltip/src/tooltip.js +22 -10
  53. package/es/v-x-e-table/index.js +1 -1
  54. package/es/v-x-e-table/src/conf.js +38 -38
  55. package/es/v-x-e-table/src/interceptor.js +1 -1
  56. package/es/v-x-e-table/src/renderer.js +19 -15
  57. package/es/v-x-e-table/style.css +359 -459
  58. package/lib/button/src/button.js +10 -10
  59. package/lib/button/src/button.min.js +1 -1
  60. package/lib/button/style/style.css +1 -58
  61. package/lib/button/style/style.min.css +1 -1
  62. package/lib/checkbox/src/checkbox.js +1 -1
  63. package/lib/checkbox/src/checkbox.min.js +1 -1
  64. package/lib/edit/src/hook.js +14 -13
  65. package/lib/edit/src/hook.min.js +1 -1
  66. package/lib/export/src/export-panel.js +1 -1
  67. package/lib/export/src/export-panel.min.js +1 -1
  68. package/lib/export/src/hook.js +50 -50
  69. package/lib/export/src/hook.min.js +1 -1
  70. package/lib/export/src/import-panel.js +3 -3
  71. package/lib/export/src/import-panel.min.js +1 -1
  72. package/lib/export/src/util.js +4 -4
  73. package/lib/export/src/util.min.js +1 -1
  74. package/lib/filter/src/hook.js +5 -5
  75. package/lib/filter/src/hook.min.js +1 -1
  76. package/lib/filter/src/panel.js +1 -1
  77. package/lib/filter/src/panel.min.js +1 -1
  78. package/lib/footer/src/footer.js +14 -14
  79. package/lib/footer/src/footer.min.js +1 -1
  80. package/lib/form/src/form-config-item.js +9 -7
  81. package/lib/form/src/form-config-item.min.js +1 -1
  82. package/lib/form/src/form-item.js +9 -7
  83. package/lib/form/src/form-item.min.js +1 -1
  84. package/lib/form/src/form.js +9 -6
  85. package/lib/form/src/form.min.js +1 -1
  86. package/lib/form/style/style.css +0 -3
  87. package/lib/form/style/style.min.css +1 -1
  88. package/lib/grid/src/grid.js +17 -13
  89. package/lib/grid/src/grid.min.js +1 -1
  90. package/lib/grid/style/style.css +1 -1
  91. package/lib/grid/style/style.min.css +1 -1
  92. package/lib/header/src/header.js +17 -17
  93. package/lib/header/src/header.min.js +1 -1
  94. package/lib/header/style/style.css +0 -95
  95. package/lib/header/style/style.min.css +0 -1
  96. package/lib/icon/style/style.css +371 -495
  97. package/lib/icon/style/style.min.css +1 -1
  98. package/lib/index.umd.js +113 -88
  99. package/lib/index.umd.min.js +1 -1
  100. package/lib/input/src/input.js +23 -23
  101. package/lib/input/src/input.min.js +1 -1
  102. package/lib/input/style/style.css +13 -4
  103. package/lib/input/style/style.min.css +1 -1
  104. package/lib/keyboard/src/hook.js +7 -7
  105. package/lib/keyboard/src/hook.min.js +1 -1
  106. package/lib/list/src/list.js +5 -5
  107. package/lib/list/src/list.min.js +1 -1
  108. package/lib/loading/src/loading.js +1 -1
  109. package/lib/loading/src/loading.min.js +1 -1
  110. package/lib/menu/src/hooks.js +9 -9
  111. package/lib/menu/src/hooks.min.js +1 -1
  112. package/lib/menu/src/panel.js +2 -2
  113. package/lib/menu/src/panel.min.js +1 -1
  114. package/lib/modal/src/modal.js +55 -53
  115. package/lib/modal/src/modal.min.js +1 -1
  116. package/lib/modal/style/style.css +2 -3
  117. package/lib/modal/style/style.min.css +1 -1
  118. package/lib/pager/src/pager.js +2 -2
  119. package/lib/pager/src/pager.min.js +1 -1
  120. package/lib/pager/style/style.css +4 -2
  121. package/lib/pager/style/style.min.css +1 -1
  122. package/lib/pulldown/src/pulldown.js +7 -7
  123. package/lib/pulldown/src/pulldown.min.js +1 -1
  124. package/lib/radio/src/button.js +1 -1
  125. package/lib/radio/src/button.min.js +1 -1
  126. package/lib/radio/src/radio.js +1 -1
  127. package/lib/radio/src/radio.min.js +1 -1
  128. package/lib/select/src/select.js +14 -12
  129. package/lib/select/src/select.min.js +1 -1
  130. package/lib/select/style/style.css +1 -0
  131. package/lib/select/style/style.min.css +1 -1
  132. package/lib/style.css +1 -1
  133. package/lib/style.min.css +1 -1
  134. package/lib/switch/src/switch.js +1 -1
  135. package/lib/switch/src/switch.min.js +1 -1
  136. package/lib/table/src/body.js +36 -34
  137. package/lib/table/src/body.min.js +1 -1
  138. package/lib/table/src/cell.js +17 -11
  139. package/lib/table/src/cell.min.js +1 -1
  140. package/lib/table/src/columnInfo.js +4 -4
  141. package/lib/table/src/columnInfo.min.js +1 -1
  142. package/lib/table/src/table.js +63 -59
  143. package/lib/table/src/table.min.js +1 -1
  144. package/lib/table/src/util.js +2 -2
  145. package/lib/table/src/util.min.js +1 -1
  146. package/lib/table/style/style.css +98 -0
  147. package/lib/table/style/style.min.css +1 -1
  148. package/lib/textarea/src/textarea.js +6 -6
  149. package/lib/textarea/src/textarea.min.js +1 -1
  150. package/lib/toolbar/src/toolbar.js +10 -8
  151. package/lib/toolbar/src/toolbar.min.js +1 -1
  152. package/lib/toolbar/style/style.css +1 -1
  153. package/lib/toolbar/style/style.min.css +1 -1
  154. package/lib/tools/dom.js +2 -2
  155. package/lib/tools/dom.min.js +1 -1
  156. package/lib/tools/log.js +1 -1
  157. package/lib/tools/log.min.js +1 -1
  158. package/lib/tools/vn.js +13 -0
  159. package/lib/tools/vn.min.js +1 -1
  160. package/lib/tooltip/src/tooltip.js +22 -8
  161. package/lib/tooltip/src/tooltip.min.js +1 -1
  162. package/lib/v-x-e-table/index.js +1 -1
  163. package/lib/v-x-e-table/index.min.js +1 -1
  164. package/lib/v-x-e-table/src/conf.js +38 -38
  165. package/lib/v-x-e-table/src/conf.min.js +1 -1
  166. package/lib/v-x-e-table/src/interceptor.js +1 -1
  167. package/lib/v-x-e-table/src/interceptor.min.js +1 -1
  168. package/lib/v-x-e-table/src/renderer.js +18 -16
  169. package/lib/v-x-e-table/src/renderer.min.js +1 -1
  170. package/lib/v-x-e-table/style/style.css +359 -459
  171. package/lib/v-x-e-table/style/style.min.css +1 -1
  172. package/package.json +5 -5
  173. package/packages/edit/src/hook.ts +18 -6
  174. package/packages/form/src/form-config-item.ts +4 -3
  175. package/packages/form/src/form-item.ts +4 -3
  176. package/packages/form/src/form.ts +6 -4
  177. package/packages/grid/src/grid.ts +2 -1
  178. package/packages/input/src/input.ts +3 -3
  179. package/packages/modal/src/modal.ts +5 -4
  180. package/packages/select/src/select.ts +2 -1
  181. package/packages/table/src/cell.ts +14 -10
  182. package/packages/table/src/table.ts +9 -8
  183. package/packages/toolbar/src/toolbar.ts +4 -3
  184. package/packages/tools/vn.ts +10 -0
  185. package/packages/tooltip/src/tooltip.ts +8 -4
  186. package/packages/v-x-e-table/src/conf.ts +38 -38
  187. package/styles/button.scss +1 -43
  188. package/styles/form.scss +0 -3
  189. package/styles/header.scss +0 -134
  190. package/styles/icon.scss +507 -713
  191. package/styles/input.scss +8 -0
  192. package/styles/modal.scss +0 -1
  193. package/styles/pager.scss +2 -0
  194. package/styles/select.scss +1 -0
  195. package/styles/table.scss +136 -0
  196. package/styles/variable.scss +1 -1
  197. package/types/all.d.ts +6 -0
  198. package/types/column.d.ts +11 -11
  199. package/types/component.d.ts +3 -1
  200. package/types/form-item.d.ts +1 -0
  201. package/types/form.d.ts +6 -2
  202. package/types/grid.d.ts +4 -4
  203. package/types/table.d.ts +2 -2
  204. package/types/v-x-e-table/renderer.d.ts +3 -2
@@ -1 +1 @@
1
- @charset "UTF-8";[class*=vxe-icon--]{display:inline-block;vertical-align:middle;position:relative;direction:ltr;font-family:Verdana,Arial,Tahoma;font-weight:400;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}[class*=vxe-icon--].rotate45{transform:rotate(45deg)}[class*=vxe-icon--].rotate90{transform:rotate(90deg)}[class*=vxe-icon--].rotate180{transform:rotate(180deg)}.vxe-icon--arrow-bottom,.vxe-icon--arrow-left,.vxe-icon--arrow-right,.vxe-icon--arrow-top,.vxe-icon--calendar,.vxe-icon--caret-bottom,.vxe-icon--caret-left,.vxe-icon--caret-right,.vxe-icon--caret-top,.vxe-icon--check,.vxe-icon--circle-plus,.vxe-icon--close,.vxe-icon--d-arrow-left,.vxe-icon--d-arrow-right,.vxe-icon--dot,.vxe-icon--download,.vxe-icon--edit-outline,.vxe-icon--error,.vxe-icon--eye,.vxe-icon--eye-slash,.vxe-icon--funnel,.vxe-icon--info,.vxe-icon--menu,.vxe-icon--minus,.vxe-icon--more,.vxe-icon--plus,.vxe-icon--print,.vxe-icon--question,.vxe-icon--refresh,.vxe-icon--remove,.vxe-icon--search,.vxe-icon--square,.vxe-icon--success,.vxe-icon--upload,.vxe-icon--warning,.vxe-icon--zoomin,.vxe-icon--zoomout{width:1em;height:1em;line-height:1em}.vxe-icon--arrow-bottom:before,.vxe-icon--arrow-left:before,.vxe-icon--arrow-right:before,.vxe-icon--arrow-top:before,.vxe-icon--calendar:after,.vxe-icon--calendar:before,.vxe-icon--caret-bottom:before,.vxe-icon--caret-left:before,.vxe-icon--caret-right:before,.vxe-icon--caret-top:before,.vxe-icon--check:before,.vxe-icon--circle-plus:after,.vxe-icon--close:before,.vxe-icon--d-arrow-left:after,.vxe-icon--d-arrow-left:before,.vxe-icon--d-arrow-right:after,.vxe-icon--d-arrow-right:before,.vxe-icon--dot:before,.vxe-icon--download:after,.vxe-icon--download:before,.vxe-icon--edit-outline:after,.vxe-icon--edit-outline:before,.vxe-icon--error:after,.vxe-icon--eye-slash:after,.vxe-icon--eye-slash:before,.vxe-icon--eye:before,.vxe-icon--funnel:after,.vxe-icon--funnel:before,.vxe-icon--info:after,.vxe-icon--minus:before,.vxe-icon--more:before,.vxe-icon--plus:before,.vxe-icon--print:after,.vxe-icon--print:before,.vxe-icon--question:after,.vxe-icon--refresh:after,.vxe-icon--refresh:before,.vxe-icon--remove:after,.vxe-icon--search:after,.vxe-icon--search:before,.vxe-icon--square:before,.vxe-icon--success:after,.vxe-icon--upload:after,.vxe-icon--upload:before,.vxe-icon--warning:after,.vxe-icon--zoomin:after,.vxe-icon--zoomin:before,.vxe-icon--zoomout:after,.vxe-icon--zoomout:before{content:"";position:absolute}.vxe-icon--square:before{left:.05em;top:.05em;width:.9em;height:.9em;border-width:.1em;border-style:solid;border-color:inherit}.vxe-icon--zoomin{border-width:.1em;border-style:solid;border-color:inherit;background-color:#fff}.vxe-icon--zoomin:after,.vxe-icon--zoomin:before{background-color:inherit}.vxe-icon--zoomin:before{left:-.1em;top:.2em;width:1.1em;height:.4em}.vxe-icon--zoomin:after{top:-.1em;left:.2em;width:.4em;height:1.1em}.vxe-icon--zoomout{position:relative}.vxe-icon--zoomout:before{right:0;top:0;width:.7em;height:.7em;border-width:.1em;border-style:solid;border-color:inherit}.vxe-icon--zoomout:after{left:.1em;bottom:.1em;width:.7em;height:.7em;border-width:.1em;border-style:solid;border-color:inherit;background-color:#fff}.vxe-icon--menu:before{content:"";display:inline-block;width:.22em;height:.22em;box-shadow:0 -.36em 0,-.36em -.36em 0,.36em -.36em 0,0 0 0 1em inset,-.36em 0 0,.36em 0 0,0 .36em 0,-.36em .36em 0,.36em .36em 0;margin:.26em}.vxe-icon--caret-bottom:before,.vxe-icon--caret-left:before,.vxe-icon--caret-right:before,.vxe-icon--caret-top:before{border-width:.4em;border-style:solid;border-color:transparent}.vxe-icon--caret-top:before{left:.1em;bottom:.3em;border-bottom-color:inherit}.vxe-icon--caret-bottom:before{left:.1em;top:.3em;border-top-color:inherit}.vxe-icon--caret-left:before{right:.3em;bottom:.1em;border-right-color:inherit}.vxe-icon--caret-right:before{left:.3em;bottom:.1em;border-left-color:inherit}.vxe-icon--arrow-bottom:before,.vxe-icon--arrow-left:before,.vxe-icon--arrow-right:before,.vxe-icon--arrow-top:before{top:.4em;left:.14em;width:.7em;height:.7em;border-width:.15em;border-style:solid;border-top-color:inherit;border-right-color:inherit;border-bottom-color:transparent;border-left-color:transparent;border-radius:.15em;transform:rotate(-45deg)}.vxe-icon--arrow-bottom:before{top:0;left:.14em;transform:rotate(135deg)}.vxe-icon--arrow-left:before{top:.18em;left:.35em;transform:rotate(-135deg)}.vxe-icon--arrow-right:before{top:.18em;left:0;transform:rotate(45deg)}.vxe-icon--d-arrow-left:before,.vxe-icon--d-arrow-right:before{left:.15em}.vxe-icon--d-arrow-left:after,.vxe-icon--d-arrow-right:after{left:.58em}.vxe-icon--d-arrow-left:after,.vxe-icon--d-arrow-left:before,.vxe-icon--d-arrow-right:after,.vxe-icon--d-arrow-right:before{top:.18em;width:.7em;height:.7em;border-width:.15em;border-style:solid;border-top-color:inherit;border-right-color:transparent;border-bottom-color:transparent;border-left-color:inherit;border-radius:.15em;transform:rotate(-45deg)}.vxe-icon--d-arrow-right:after,.vxe-icon--d-arrow-right:before{transform:rotate(135deg)}.vxe-icon--d-arrow-right:before{left:-.25em}.vxe-icon--d-arrow-right:after{left:.18em}.vxe-icon--funnel:before{top:.05em;left:0;border-width:.5em;border-style:solid;border-top-color:inherit;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.vxe-icon--funnel:after{left:.41em;top:.4em;width:0;height:.5em;border-width:0 .2em 0 0;border-style:solid;border-right-color:inherit}.vxe-icon--edit-outline:before{height:.84em;width:.86em;top:.1em;left:.02em;border-radius:.2em;border-width:.1em;border-style:solid;border-color:inherit}.vxe-icon--edit-outline:after{left:.6em;bottom:.2em;width:0;height:.8em;border-radius:0 0 80% 80%;border-width:0 0 0 .22em;border-style:solid;border-color:inherit;transform:rotate(45deg)}.vxe-icon--more:before{content:"...";top:0;left:.1em;line-height:.5em;font-weight:700}.vxe-icon--plus:before{content:"+";left:-.12em;bottom:-.1em;line-height:1em;font-size:1.6em}.vxe-icon--check:before{left:.25em;bottom:.2em;width:.5em;height:.9em;border-width:.15em;border-style:solid;border-top-color:transparent;border-right-color:inherit;border-bottom-color:inherit;border-radius:.15em;border-left-color:transparent;transform:rotate(45deg)}.vxe-icon--close:before{content:"+";left:-.1em;bottom:-.16em;line-height:1em;font-size:1.8em;transform:rotate(45deg)}.vxe-icon--minus:before{content:"\2500";left:0;bottom:0;width:100%;text-align:center;line-height:.9em;font-size:1.2em}.vxe-icon--refresh{border-width:.1em;border-style:solid;border-radius:50%;border-right-color:transparent!important;border-left-color:transparent!important}.vxe-icon--refresh:before{left:50%;top:0;transform:translateX(50%) rotate(-45deg)}.vxe-icon--refresh:after{right:50%;bottom:0;transform:translateX(-50%) rotate(135deg)}.vxe-icon--refresh:after,.vxe-icon--refresh:before{width:0;height:0;border-width:.25em;border-style:solid;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.vxe-icon--refresh.roll{-webkit-animation:rollCircle 1s infinite linear;animation:rollCircle 1s infinite linear}@-webkit-keyframes rollCircle{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes rollCircle{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.vxe-icon--circle-plus:before,.vxe-icon--error:before,.vxe-icon--info:before,.vxe-icon--question:before,.vxe-icon--remove:before,.vxe-icon--success:before,.vxe-icon--warning:before{content:"";border-radius:50%;border-width:.5em;border-style:solid;border-color:inherit;position:absolute;top:0;left:0;transform:scale(.95)}.vxe-icon--info:after,.vxe-icon--question:after,.vxe-icon--warning:after{left:0;bottom:0;width:100%;text-align:center;color:#fff;transform:rotate(-10deg) scale(.75)}.vxe-icon--question:after{content:"\3F"}.vxe-icon--info:after{content:"\A1"}.vxe-icon--warning:after{content:"\21"}.vxe-icon--success:after{content:"\2713";left:.25em;bottom:0;color:#fff;font-size:.65em}.vxe-icon--circle-plus:after{content:"+";left:0;bottom:0;width:100%;text-align:center;color:#fff;line-height:1.4em;font-size:.8em}.vxe-icon--remove:after{content:"\2500";left:0;bottom:0;width:100%;text-align:center;line-height:1.5em;color:#fff;font-size:.7em}.vxe-icon--error:after{content:"\D7";left:0;bottom:0;width:100%;line-height:1.4em;text-align:center;color:#fff;font-size:.8em}.vxe-icon--download,.vxe-icon--upload{overflow:hidden}.vxe-icon--download:before,.vxe-icon--upload:before{left:0;width:1em;border-width:0;border-style:solid;border-color:inherit}.vxe-icon--download:after,.vxe-icon--upload:after{width:100%;text-align:center;font-size:2em}.vxe-icon--upload:before{top:.1em;border-top-width:.1em}.vxe-icon--upload:after{content:"\2191";left:0;top:.15em}.vxe-icon--download:before{bottom:.05em;border-bottom-width:.1em}.vxe-icon--download:after{content:"\2191";left:0;bottom:.15em;transform:rotate(180deg)}.vxe-icon--eye-slash:before,.vxe-icon--eye:before{content:"\25CF";top:.16em;left:0;width:1em;height:.68em;line-height:.25em;border-radius:50%;border-width:.1em;border-style:solid;border-color:inherit;text-align:center}.vxe-icon--eye-slash:after{top:-.1em;left:.45em;width:0;height:1.2em;border-width:0;border-style:solid;border-color:inherit;border-left-width:.1em;transform:rotate(45deg)}.vxe-icon--calendar:before{top:.15em;left:0;width:1em;height:.8em;border-width:.2em .1em .1em .1em;border-radius:.1em .1em 0 0;border-style:solid;border-color:inherit}.vxe-icon--calendar:after{left:.2em;top:0;width:.6em;height:.3em;border-width:0 .1em;border-style:solid;border-color:inherit}.vxe-icon--dot:before{top:.25em;left:.25em;border-radius:50%;border-width:.25em;border-style:solid;border-color:inherit}.vxe-icon--print{box-shadow:inset 0 0 0 .1em;border-width:.2em 0;border-style:solid;border-color:transparent!important;border-radius:.3em .3em 0 0}.vxe-icon--print:before{width:.6em;height:.3em;top:-.2em;left:.2em;box-shadow:inset 0 0 0 .1em}.vxe-icon--print:after{width:.6em;height:.6em;left:.2em;bottom:-.2em;box-shadow:inset 0 0 0 .1em;background-color:#fff}.vxe-icon--search:before{top:0;left:0;width:.8em;height:.8em;border-width:.15em;border-style:solid;border-color:inherit;border-radius:50%}.vxe-icon--search:after{top:.75em;left:.6em;width:.35em;height:0;border-width:.15em 0 0 0;border-style:solid;border-color:inherit;transform:rotate(45deg)}.vxe-loading{display:none;position:absolute;width:100%;height:100%;top:0;left:0;z-index:99;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:rgba(0,0,0,.2)}.vxe-loading.is--visible{display:block}.vxe-loading>.vxe-loading--chunk{width:100%;position:absolute;top:50%;left:0;transform:translateY(-50%);text-align:center;color:#409eff}.vxe-loading .vxe-loading--default-icon{font-size:1.2em}.vxe-loading .vxe-loading--text{padding:.4em 0}.vxe-loading .vxe-loading--spinner{display:inline-block;position:relative;width:56px;height:56px}.vxe-loading .vxe-loading--spinner:after,.vxe-loading .vxe-loading--spinner:before{content:"";width:100%;height:100%;border-radius:50%;background-color:#409eff;opacity:.6;position:absolute;top:0;left:0;-webkit-animation:bounce 2s infinite ease-in-out;animation:bounce 2s infinite ease-in-out}.vxe-loading .vxe-loading--spinner:after{-webkit-animation-delay:-1s;animation-delay:-1s}@-webkit-keyframes bounce{0%,100%{transform:scale(0)}50%{transform:scale(1)}}@keyframes bounce{0%,100%{transform:scale(0)}50%{transform:scale(1)}}.size--mini .vxe-loading .vxe-loading--spinner{width:38px;height:38px}.size--small .vxe-loading .vxe-loading--spinner{width:44px;height:44px}.size--medium .vxe-loading .vxe-loading--spinner{width:50px;height:50px}
1
+ @charset "UTF-8";@font-face{font-family:vxeiconfont;src:url("data:application/x-font-woff2;charset=utf-8;base64,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") format("woff2")}@-webkit-keyframes rollCircle{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes rollCircle{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}[class*=vxe-icon-]{font-family:vxeiconfont!important;font-style:normal;font-weight:400;font-size:1.2em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[class*=vxe-icon-].animat,[class*=vxe-icon-].roll{display:inline-block}[class*=vxe-icon-].animat{transition:transform .25s ease-in-out}[class*=vxe-icon-].rotate45{transform:rotate(45deg)}[class*=vxe-icon-].rotate90{transform:rotate(90deg)}[class*=vxe-icon-].rotate180{transform:rotate(180deg)}[class*=vxe-icon-].roll{-webkit-animation:rollCircle 1s infinite linear;animation:rollCircle 1s infinite linear}.vxe-icon-fullscreen:before{content:"\e70e"}.vxe-icon-minimize:before{content:"\e749"}.vxe-icon-print:before{content:"\eba0"}.vxe-icon-upload:before{content:"\e683"}.vxe-icon-download:before{content:"\e61a"}.vxe-icon-cloud-upload:before{content:"\e603"}.vxe-icon-cloud-download:before{content:"\e63a"}.vxe-icon-spinner:before{content:"\e601"}.vxe-icon-close:before{content:"\e6e9"}.vxe-icon-custom-column:before{content:"\e62d"}.vxe-icon-edit:before{content:"\e66e"}.vxe-icon-refresh:before{content:"\e619"}.vxe-icon-zoom-in:before{content:"\e826"}.vxe-icon-caret-down:before{content:"\e8ed"}.vxe-icon-caret-up:before{content:"\e8ee"}.vxe-icon-caret-right:before{content:"\e8ef"}.vxe-icon-caret-left:before{content:"\e8f0"}.vxe-icon-square-checked-fill:before{content:"\e6d4"}.vxe-icon-square-close:before{content:"\e793"}.vxe-icon-square-down:before{content:"\e794"}.vxe-icon-square-left:before{content:"\e796"}.vxe-icon-square-caret-right:before{content:"\e797"}.vxe-icon-square-minus:before{content:"\e798"}.vxe-icon-square-plus:before{content:"\e799"}.vxe-icon-square-right:before{content:"\e79a"}.vxe-icon-square-up:before{content:"\e79b"}.vxe-icon-square-checked:before{content:"\e7a8"}.vxe-icon-square-down-fill:before{content:"\e84b"}.vxe-icon-square-minus-fill:before{content:"\e84c"}.vxe-icon-square-close-fill:before{content:"\e84d"}.vxe-icon-square-left-fill:before{content:"\e84f"}.vxe-icon-square-caret-right-fill:before{content:"\e850"}.vxe-icon-square-up-fill:before{content:"\e851"}.vxe-icon-square-right-fill:before{content:"\e853"}.vxe-icon-square-plus-fill:before{content:"\e854"}.vxe-icon-square-plus-square:before{content:"\e87e"}.vxe-icon-square-fill:before{content:"\e8d9"}.vxe-icon-square-square:before{content:"\e6a1"}.vxe-icon-sort-alpha-desc:before{content:"\e852"}.vxe-icon-sort-alpha-asc:before{content:"\e7d5"}.vxe-icon-sort-numeric-asc:before{content:"\e800"}.vxe-icon-sort-numeric-desc:before{content:"\e801"}.vxe-icon-star-fill:before{content:"\e69e"}.vxe-icon-star:before{content:"\e69f"}.vxe-icon-star-half:before{content:"\e6b6"}.vxe-icon-lock-fill:before{content:"\e6d1"}.vxe-icon-unlock-fill:before{content:"\e92c"}.vxe-icon-question:before{content:"\e72e"}.vxe-icon-exclamation:before{content:"\e617"}.vxe-icon-information:before{content:"\e7f7"}.vxe-icon-ellipsis-h:before{content:"\e636"}.vxe-icon-ellipsis-v:before{content:"\e637"}.vxe-icon-save:before{content:"\e67c"}.vxe-icon-setting:before{content:"\e8b8"}.vxe-icon-setting-fill:before{content:"\e795"}.vxe-icon-user-fill:before{content:"\e652"}.vxe-icon-link:before{content:"\e6c8"}.vxe-icon-user:before{content:"\e61b"}.vxe-icon-sort:before{content:"\e6a0"}.vxe-icon-chart-pie:before{content:"\e902"}.vxe-icon-chart-line:before{content:"\e904"}.vxe-icon-swap:before{content:"\e7f3"}.vxe-icon-num-list:before{content:"\e7f4"}.vxe-icon-copy:before{content:"\ec7a"}.vxe-icon-company:before{content:"\e602"}.vxe-icon-swap-right:before{content:"\e8f1"}.vxe-icon-swap-left:before{content:"\e8f2"}.vxe-icon-table:before{content:"\e920"}.vxe-icon-merge-cells:before{content:"\e901"}.vxe-icon-paste:before{content:"\e70b"}.vxe-icon-cut:before{content:"\e70d"}.vxe-icon-lock:before{content:"\e676"}.vxe-icon-unlock:before{content:"\e682"}.vxe-icon-chart-bar:before{content:"\e84e"}.vxe-icon-fixed-fill:before{content:"\e9b9"}.vxe-icon-fixed:before{content:"\e9ba"}.vxe-icon-square:before{content:"\e6d5"}.vxe-icon-check:before{content:"\e645"}.vxe-icon-question-circle-fill:before{content:"\e690"}.vxe-icon-info-circle-fill:before{content:"\e6e4"}.vxe-icon-error-circle-fill:before{content:"\e62b"}.vxe-icon-delete:before{content:"\e69d"}.vxe-icon-dot:before{content:"\e63f"}.vxe-icon-success-circle:before{content:"\e6d9"}.vxe-icon-delete-fill:before{content:"\e634"}.vxe-icon-minus:before{content:"\e6ba"}.vxe-icon-maximize:before{content:"\e600"}.vxe-icon-info-circle:before{content:"\e77e"}.vxe-icon-question-circle:before{content:"\e782"}.vxe-icon-warning-circle:before{content:"\e785"}.vxe-icon-warnion-circle-fill:before{content:"\e848"}.vxe-icon-eye-fill:before{content:"\e869"}.vxe-icon-search:before{content:"\e741"}.vxe-icon-funnel:before{content:"\e8ec"}.vxe-icon-eye-fill-close:before{content:"\e8ff"}.vxe-icon-search-zoom-in:before{content:"\e6a5"}.vxe-icon-arrow-right:before{content:"\e743"}.vxe-icon-arrow-left:before{content:"\e744"}.vxe-icon-arrow-up:before{content:"\e745"}.vxe-icon-calendar:before{content:"\e746"}.vxe-icon-arrow-down:before{content:"\e7b2"}.vxe-icon-warning-triangle:before{content:"\e67f"}.vxe-icon-add:before{content:"\e664"}.vxe-icon-arrow-double-left:before{content:"\e665"}.vxe-icon-arrow-double-right:before{content:"\e666"}.vxe-icon-menu:before{content:"\e677"}.vxe-icon-repeat:before{content:"\e67b"}.vxe-icon-warning-triangle-fill:before{content:"\e68b"}.vxe-icon-error-circle:before{content:"\e613"}.vxe-icon-zoom-out:before{content:"\e65d"}.vxe-icon-success-circle-fill:before{content:"\e67e"}.vxe-icon-radio-checked:before{content:"\e763"}.vxe-icon-checkbox-unchecked:before{content:"\e8b5"}.vxe-icon-checkbox-checked:before{content:"\e8b6"}.vxe-icon-checkbox-indeterminate:before{content:"\e8b7"}.vxe-icon-radio-unchecked:before{content:"\e7c9"}.vxe-loading{display:none;position:absolute;width:100%;height:100%;top:0;left:0;z-index:99;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:rgba(0,0,0,.3)}.vxe-loading.is--visible{display:block}.vxe-loading>.vxe-loading--chunk{width:100%;position:absolute;top:50%;left:0;transform:translateY(-50%);text-align:center;color:#409eff}.vxe-loading .vxe-loading--default-icon{font-size:1.2em}.vxe-loading .vxe-loading--text{padding:.4em 0}.vxe-loading .vxe-loading--spinner{display:inline-block;position:relative;width:56px;height:56px}.vxe-loading .vxe-loading--spinner:after,.vxe-loading .vxe-loading--spinner:before{content:"";width:100%;height:100%;border-radius:50%;background-color:#409eff;opacity:.6;position:absolute;top:0;left:0;-webkit-animation:bounce 2s infinite ease-in-out;animation:bounce 2s infinite ease-in-out}.vxe-loading .vxe-loading--spinner:after{-webkit-animation-delay:-1s;animation-delay:-1s}@-webkit-keyframes bounce{0%,100%{transform:scale(0)}50%{transform:scale(1)}}@keyframes bounce{0%,100%{transform:scale(0)}50%{transform:scale(1)}}.size--mini .vxe-loading .vxe-loading--spinner{width:38px;height:38px}.size--small .vxe-loading .vxe-loading--spinner{width:44px;height:44px}.size--medium .vxe-loading .vxe-loading--spinner{width:50px;height:50px}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vxe-table",
3
- "version": "4.2.8",
3
+ "version": "4.3.0-beta.0",
4
4
  "description": "一个基于 vue 的 PC 端表格组件,支持增删改查、虚拟列表、虚拟树、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、弹窗、自定义模板、渲染器、贼灵活的配置项、扩展接口等...",
5
5
  "scripts": {
6
6
  "serve": "vue-cli-service serve",
@@ -27,7 +27,7 @@
27
27
  "style": "lib/style.css",
28
28
  "typings": "types/index.d.ts",
29
29
  "devDependencies": {
30
- "@types/resize-observer-browser": "^0.1.6",
30
+ "@types/resize-observer-browser": "^0.1.7",
31
31
  "@typescript-eslint/eslint-plugin": "^4.18.0",
32
32
  "@typescript-eslint/parser": "^4.18.0",
33
33
  "@vue/cli-plugin-babel": "~4.5.0",
@@ -36,7 +36,7 @@
36
36
  "@vue/cli-plugin-typescript": "~4.5.0",
37
37
  "@vue/cli-plugin-vuex": "~4.5.0",
38
38
  "@vue/cli-service": "~4.5.0",
39
- "@vue/compiler-sfc": "^3.2.31",
39
+ "@vue/compiler-sfc": "^3.2.37",
40
40
  "@vue/eslint-config-standard": "^5.1.2",
41
41
  "@vue/eslint-config-typescript": "^7.0.0",
42
42
  "core-js": "^3.6.5",
@@ -60,8 +60,8 @@
60
60
  "gulp-uglify": "^3.0.2",
61
61
  "sass": "^1.52.1",
62
62
  "sass-loader": "^10.0.5",
63
- "typescript": "~4.3.5",
64
- "vue": "^3.2.31",
63
+ "typescript": "^4.6.4",
64
+ "vue": "^3.2.37",
65
65
  "vue-i18n": "^9.1.7",
66
66
  "vue-router": "^4.0.11",
67
67
  "vuex": "^4.0.2",
@@ -319,7 +319,7 @@ const editHook: VxeGlobalHooksHandles.HookOptions = {
319
319
  }
320
320
  // 如果当前行被激活编辑,则清除激活状态
321
321
  if (actived.row && $xetable.findRowIndexOf(rows, actived.row) > -1) {
322
- editMethods.clearActived()
322
+ editMethods.clearEdit()
323
323
  }
324
324
  // 从新增中移除已删除的数据
325
325
  rows.forEach((row: any) => {
@@ -551,7 +551,14 @@ const editHook: VxeGlobalHooksHandles.HookOptions = {
551
551
  return $xetable.scrollToRow(row, column).then(() => {
552
552
  const cell = $xetable.getCell(row, column)
553
553
  if (cell) {
554
- editPrivateMethods.handleActived({ row, rowIndex: $xetable.getRowIndex(row), column, columnIndex: $xetable.getColumnIndex(column), cell, $table: $xetable })
554
+ editPrivateMethods.handleActived({
555
+ row,
556
+ rowIndex: $xetable.getRowIndex(row),
557
+ column,
558
+ columnIndex: $xetable.getColumnIndex(column),
559
+ cell,
560
+ $table: $xetable
561
+ })
555
562
  internalData._lastCallTime = Date.now()
556
563
  }
557
564
  return nextTick()
@@ -564,14 +571,19 @@ const editHook: VxeGlobalHooksHandles.HookOptions = {
564
571
  */
565
572
  setSelectCell (row, fieldOrColumn) {
566
573
  const { tableData } = reactData
567
- const { visibleColumn } = internalData
568
574
  const editOpts = computeEditOpts.value
569
575
  const column = XEUtils.isString(fieldOrColumn) ? $xetable.getColumnByField(fieldOrColumn) : fieldOrColumn
570
576
  if (row && column && editOpts.trigger !== 'manual') {
571
577
  const rowIndex = $xetable.findRowIndexOf(tableData, row)
572
578
  if (rowIndex > -1 && column) {
573
579
  const cell = $xetable.getCell(row, column)
574
- const params = { row, rowIndex, column, columnIndex: visibleColumn.indexOf(column), cell }
580
+ const params = {
581
+ row,
582
+ rowIndex,
583
+ column,
584
+ columnIndex: $xetable.getColumnIndex(column),
585
+ cell
586
+ }
575
587
  $xetable.handleSelected(params, {})
576
588
  }
577
589
  }
@@ -608,7 +620,7 @@ const editHook: VxeGlobalHooksHandles.HookOptions = {
608
620
  }
609
621
  $xetable.closeTooltip()
610
622
  if (actived.column) {
611
- editMethods.clearActived(evnt)
623
+ editMethods.clearEdit(evnt)
612
624
  }
613
625
  type = 'edit-actived'
614
626
  column.renderHeight = cell.offsetHeight
@@ -714,7 +726,7 @@ const editHook: VxeGlobalHooksHandles.HookOptions = {
714
726
  const selectMethod = () => {
715
727
  if (isMouseSelected && (selected.row !== row || selected.column !== column)) {
716
728
  if (actived.row !== row || (editOpts.mode === 'cell' ? actived.column !== column : false)) {
717
- editMethods.clearActived(evnt)
729
+ editMethods.clearEdit(evnt)
718
730
  editMethods.clearSelected()
719
731
  if ($xetable.clearCellAreas) {
720
732
  $xetable.clearCellAreas()
@@ -3,10 +3,11 @@ import XEUtils from 'xe-utils'
3
3
  import GlobalConfig from '../../v-x-e-table/src/conf'
4
4
  import { VXETable } from '../../v-x-e-table'
5
5
  import { getFuncText, isEnableConf } from '../../tools/utils'
6
+ import { getSlotVNs } from '../../tools/vn'
6
7
  import { renderTitle } from './render'
7
8
  import { isActivetem } from './util'
8
9
 
9
- import { VxeFormConstructor, VxeFormDefines, VxeFormPrivateMethods } from '../../../types/all'
10
+ import { VxeFormConstructor, VxeFormDefines, VxeFormPrivateMethods, SlotVNodeType } from '../../../types/all'
10
11
 
11
12
  const VxeFormConfigItem = defineComponent({
12
13
  name: 'VxeFormConfigItem',
@@ -68,11 +69,11 @@ const VxeFormConfigItem = defineComponent({
68
69
  class: ['vxe-form--gather vxe-row', item.id, span ? `vxe-col--${span} is--span` : '', className ? (XEUtils.isFunction(className) ? className(params) : className) : '']
69
70
  }, childVNs) : createCommentVNode()
70
71
  }
71
- let contentVNs: any[] = []
72
+ let contentVNs: SlotVNodeType[] = []
72
73
  if (defaultSlot) {
73
74
  contentVNs = $xeform.callSlot(defaultSlot, params)
74
75
  } else if (compConf && compConf.renderItemContent) {
75
- contentVNs = compConf.renderItemContent(itemRender, params)
76
+ contentVNs = getSlotVNs(compConf.renderItemContent(itemRender, params))
76
77
  } else if (field) {
77
78
  contentVNs = [XEUtils.toValueString(XEUtils.get(data, field))]
78
79
  }
@@ -3,10 +3,11 @@ import XEUtils from 'xe-utils'
3
3
  import GlobalConfig from '../../v-x-e-table/src/conf'
4
4
  import { VXETable } from '../../v-x-e-table'
5
5
  import { getFuncText, isEnableConf } from '../../tools/utils'
6
+ import { getSlotVNs } from '../../tools/vn'
6
7
  import { createItem, watchItem, destroyItem, assemItem, XEFormItemProvide, isActivetem } from './util'
7
8
  import { renderTitle } from './render'
8
9
 
9
- import { VxeFormConstructor, VxeFormDefines, VxeFormItemPropTypes, VxeFormPrivateMethods } from '../../../types/all'
10
+ import { SlotVNodeType, VxeFormConstructor, VxeFormDefines, VxeFormItemPropTypes, VxeFormPrivateMethods } from '../../../types/all'
10
11
 
11
12
  export const formItemProps = {
12
13
  title: String as PropType<VxeFormItemPropTypes.Title>,
@@ -92,11 +93,11 @@ export default defineComponent({
92
93
  isRequired = itemRules.some((rule) => rule.required)
93
94
  }
94
95
  }
95
- let contentVNs: any[] = []
96
+ let contentVNs: SlotVNodeType[] = []
96
97
  if (defaultSlot) {
97
98
  contentVNs = $xeform.callSlot(defaultSlot, params)
98
99
  } else if (compConf && compConf.renderItemContent) {
99
- contentVNs = compConf.renderItemContent(itemRender, params)
100
+ contentVNs = getSlotVNs(compConf.renderItemContent(itemRender, params))
100
101
  } else if (field) {
101
102
  contentVNs = [`${XEUtils.get(data, field)}`]
102
103
  }
@@ -1,4 +1,4 @@
1
- import { defineComponent, h, ref, Ref, resolveComponent, ComponentOptions, createCommentVNode, provide, computed, reactive, watch, nextTick, PropType, VNode, onMounted } from 'vue'
1
+ import { defineComponent, h, ref, Ref, resolveComponent, ComponentOptions, createCommentVNode, provide, computed, reactive, watch, nextTick, PropType, onMounted } from 'vue'
2
2
  import XEUtils from 'xe-utils'
3
3
  import GlobalConfig from '../../v-x-e-table/src/conf'
4
4
  import { VXETable } from '../../v-x-e-table'
@@ -9,6 +9,7 @@ import { createItem, handleFieldOrItem, isHiddenItem, isActivetem } from './util
9
9
  import { useSize } from '../../hooks/size'
10
10
  import VxeFormConfigItem from './form-config-item'
11
11
  import VxeLoading from '../../loading/index'
12
+ import { getSlotVNs } from '../../tools/vn'
12
13
 
13
14
  import { VxeFormConstructor, VxeFormPropTypes, VxeFormEmits, FormReactData, FormMethods, FormPrivateRef, VxeFormPrivateMethods, VxeFormDefines, VxeFormItemPropTypes, VxeTooltipInstance, FormInternalData, VxeFormPrivateComputed } from '../../../types/all'
14
15
 
@@ -83,6 +84,7 @@ export default defineComponent({
83
84
  titleAsterisk: { type: Boolean as PropType<VxeFormPropTypes.TitleAsterisk>, default: () => GlobalConfig.form.titleAsterisk },
84
85
  titleOverflow: { type: [Boolean, String] as PropType<VxeFormPropTypes.TitleOverflow>, default: null },
85
86
  className: [String, Function] as PropType<VxeFormPropTypes.ClassName>,
87
+ readonly: Boolean as PropType<VxeFormPropTypes.Readonly>,
86
88
  items: Array as PropType<VxeFormPropTypes.Items>,
87
89
  rules: Object as PropType<VxeFormPropTypes.Rules>,
88
90
  preventSubmit: { type: Boolean as PropType<VxeFormPropTypes.PreventSubmit>, default: () => GlobalConfig.form.preventSubmit },
@@ -153,13 +155,13 @@ export default defineComponent({
153
155
  getComputeMaps: () => computeMaps
154
156
  } as unknown as VxeFormConstructor & VxeFormPrivateMethods
155
157
 
156
- const callSlot = (slotFunc: ((params: any) => any) | string | null, params: any): VNode[] => {
158
+ const callSlot = (slotFunc: ((params: any) => any) | string | null, params: any) => {
157
159
  if (slotFunc) {
158
160
  if (XEUtils.isString(slotFunc)) {
159
161
  slotFunc = slots[slotFunc] || null
160
162
  }
161
163
  if (XEUtils.isFunction(slotFunc)) {
162
- return slotFunc(params)
164
+ return getSlotVNs(slotFunc(params))
163
165
  }
164
166
  }
165
167
  return []
@@ -241,7 +243,7 @@ export default defineComponent({
241
243
  if (compConf && compConf.itemResetMethod) {
242
244
  compConf.itemResetMethod({ data, field, property: field, item, $form: $xeform })
243
245
  } else if (field) {
244
- XEUtils.set(data, field, resetValue === null ? getResetValue(XEUtils.get(data, field), undefined) : resetValue)
246
+ XEUtils.set(data, field, resetValue === null ? getResetValue(XEUtils.get(data, field), undefined) : XEUtils.clone(resetValue, true))
245
247
  }
246
248
  }
247
249
  })
@@ -9,6 +9,7 @@ import tableComponentProps from '../../table/src/props'
9
9
  import tableComponentEmits from '../../table/src/emits'
10
10
  import { useSize } from '../../hooks/size'
11
11
  import { GlobalEvent, hasEventKey, EVENT_KEYS } from '../../tools/event'
12
+ import { getSlotVNs } from '../../tools/vn'
12
13
 
13
14
  import { TableMethods, VxeGridConstructor, VxeGridEmits, GridReactData, VxeGridPropTypes, VxeToolbarPropTypes, GridMethods, GridPrivateMethods, VxeGridPrivateComputed, VxeGridPrivateMethods, VxePagerInstance, VxeToolbarInstance, GridPrivateRef, VxeFormInstance, VxeTableProps, VxeTableConstructor, VxeTableMethods, VxeTablePrivateMethods, VxeTableEvents, VxePagerEvents, VxeFormEvents, VxeTableDefines, VxeTableEventProps, VxeFormItemProps, VxeGridProps } from '../../../types/all'
14
15
 
@@ -1024,7 +1025,7 @@ export default defineComponent({
1024
1025
  slotFunc = slots[slotFunc] || null
1025
1026
  }
1026
1027
  if (XEUtils.isFunction(slotFunc)) {
1027
- return slotFunc(params)
1028
+ return getSlotVNs(slotFunc(params))
1028
1029
  }
1029
1030
  }
1030
1031
  return []
@@ -1952,7 +1952,7 @@ export default defineComponent({
1952
1952
  onClick: datePrevEvent
1953
1953
  }, [
1954
1954
  h('i', {
1955
- class: 'vxe-icon--caret-left'
1955
+ class: 'vxe-icon-caret-left'
1956
1956
  })
1957
1957
  ]),
1958
1958
  h('span', {
@@ -1960,7 +1960,7 @@ export default defineComponent({
1960
1960
  onClick: dateTodayMonthEvent
1961
1961
  }, [
1962
1962
  h('i', {
1963
- class: 'vxe-icon--dot'
1963
+ class: 'vxe-icon-dot'
1964
1964
  })
1965
1965
  ]),
1966
1966
  h('span', {
@@ -1970,7 +1970,7 @@ export default defineComponent({
1970
1970
  onClick: dateNextEvent
1971
1971
  }, [
1972
1972
  h('i', {
1973
- class: 'vxe-icon--caret-right'
1973
+ class: 'vxe-icon-caret-right'
1974
1974
  })
1975
1975
  ]),
1976
1976
  multiple && computeSupportMultiples.value ? h('span', {
@@ -8,6 +8,7 @@ import { GlobalEvent, hasEventKey, EVENT_KEYS } from '../../tools/event'
8
8
  import GlobalConfig from '../../v-x-e-table/src/conf'
9
9
  import VxeButtonConstructor from '../../button/src/button'
10
10
  import VxeLoading from '../../loading/index'
11
+ import { getSlotVNs } from '../../tools/vn'
11
12
 
12
13
  import { VxeModalConstructor, VxeModalPropTypes, ModalReactData, VxeModalEmits, ModalEventTypes, VxeButtonInstance, ModalMethods, ModalPrivateRef, VxeModalMethods } from '../../../types/all'
13
14
 
@@ -687,7 +688,7 @@ export default defineComponent({
687
688
  const { slots: propSlots = {}, showClose, showZoom, title } = props
688
689
  const { zoomLocat } = reactData
689
690
  const titleSlot = slots.title || propSlots.title
690
- const titVNs: VNode[] = titleSlot ? titleSlot({ $modal: $xemodal }) as VNode[] : [
691
+ const titVNs = titleSlot ? getSlotVNs(titleSlot({ $modal: $xemodal })) : [
691
692
  h('span', {
692
693
  class: 'vxe-modal--title'
693
694
  }, title ? getFuncText(title) : GlobalConfig.i18n('vxe.alert.title'))
@@ -736,7 +737,7 @@ export default defineComponent({
736
737
  'is--ellipsis': !isMsg && props.showTitleOverflow
737
738
  }],
738
739
  ...headerOns
739
- }, headerSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : headerSlot({ $modal: $xemodal })) as VNode[] : renderTitles())
740
+ }, headerSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : getSlotVNs(headerSlot({ $modal: $xemodal }))) : renderTitles())
740
741
  )
741
742
  }
742
743
  return headVNs
@@ -762,7 +763,7 @@ export default defineComponent({
762
763
  contVNs.push(
763
764
  h('div', {
764
765
  class: 'vxe-modal--content'
765
- }, defaultSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : defaultSlot({ $modal: $xemodal })) as VNode[] : getFuncText(content))
766
+ }, defaultSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : getSlotVNs(defaultSlot({ $modal: $xemodal }))) as VNode[] : getFuncText(content))
766
767
  )
767
768
  if (!isMsg) {
768
769
  /**
@@ -814,7 +815,7 @@ export default defineComponent({
814
815
  footVNs.push(
815
816
  h('div', {
816
817
  class: 'vxe-modal--footer'
817
- }, footerSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : footerSlot({ $modal: $xemodal })) as VNode[] : renderBtns())
818
+ }, footerSlot ? (!reactData.inited || (props.destroyOnClose && !reactData.visible) ? [] : getSlotVNs(footerSlot({ $modal: $xemodal }))) as VNode[] : renderBtns())
818
819
  )
819
820
  }
820
821
  if (!isMsg && props.resize) {
@@ -6,6 +6,7 @@ import { getEventTargetNode, getAbsolutePos } from '../../tools/dom'
6
6
  import { getLastZIndex, nextZIndex, getFuncText, formatText } from '../../tools/utils'
7
7
  import { GlobalEvent, hasEventKey, EVENT_KEYS } from '../../tools/event'
8
8
  import VxeInputComponent from '../../input/src/input'
9
+ import { getSlotVNs } from '../../tools/vn'
9
10
 
10
11
  import { VxeSelectPropTypes, VxeSelectConstructor, SelectReactData, VxeSelectEmits, VxeInputConstructor, SelectMethods, SelectPrivateRef, VxeSelectMethods, VxeOptgroupProps, VxeOptionProps, VxeFormDefines, VxeFormConstructor, VxeFormPrivateMethods, VxeInputDefines } from '../../../types/all'
11
12
 
@@ -147,7 +148,7 @@ export default defineComponent({
147
148
  slotFunc = slots[slotFunc] || null
148
149
  }
149
150
  if (XEUtils.isFunction(slotFunc)) {
150
- return slotFunc(params)
151
+ return getSlotVNs(slotFunc(params))
151
152
  }
152
153
  }
153
154
  return []
@@ -5,8 +5,9 @@ import { VXETable } from '../../v-x-e-table'
5
5
  import { getFuncText, isEnableConf, formatText, eqEmptyValue } from '../../tools/utils'
6
6
  import { updateCellTitle } from '../../tools/dom'
7
7
  import { createColumn } from './util'
8
+ import { getSlotVNs } from '../../tools/vn'
8
9
 
9
- import { VxeTableConstructor, VxeTableDefines, VxeTablePrivateMethods } from '../../../types/all'
10
+ import { SlotVNodeType, VxeTableConstructor, VxeTableDefines, VxeTablePrivateMethods } from '../../../types/all'
10
11
 
11
12
  function renderHelpIcon (params: VxeTableDefines.CellRenderHeaderParams) {
12
13
  const { $table, column } = params
@@ -24,7 +25,7 @@ function renderHelpIcon (params: VxeTableDefines.CellRenderHeaderParams) {
24
25
  ] : []
25
26
  }
26
27
 
27
- function renderTitleContent (params: VxeTableDefines.CellRenderHeaderParams, content: VNode[] | string[] | string) {
28
+ function renderTitleContent (params: VxeTableDefines.CellRenderHeaderParams, content: SlotVNodeType[]) {
28
29
  const { $table, column } = params
29
30
  const { props, internalData } = $table
30
31
  const { computeTooltipOpts } = $table.getComputeMaps()
@@ -81,7 +82,7 @@ function getFooterContent (params: VxeTableDefines.CellRenderFooterParams) {
81
82
  if (renderOpts) {
82
83
  const compConf = VXETable.renderer.get(renderOpts.name)
83
84
  if (compConf && compConf.renderFooter) {
84
- return compConf.renderFooter(renderOpts, params)
85
+ return getSlotVNs(compConf.renderFooter(renderOpts, params))
85
86
  }
86
87
  }
87
88
  return [formatText(items[_columnIndex], 1)]
@@ -160,10 +161,10 @@ export const Cell = {
160
161
  if (renderOpts) {
161
162
  const compConf = VXETable.renderer.get(renderOpts.name)
162
163
  if (compConf && compConf.renderHeader) {
163
- return renderTitleContent(params, compConf.renderHeader(renderOpts, params))
164
+ return renderTitleContent(params, getSlotVNs(compConf.renderHeader(renderOpts, params)))
164
165
  }
165
166
  }
166
- return renderTitleContent(params, formatText(column.getTitle(), 1))
167
+ return renderTitleContent(params, [formatText(column.getTitle(), 1)])
167
168
  },
168
169
  renderDefaultHeader (params: VxeTableDefines.CellRenderHeaderParams) {
169
170
  return renderHelpIcon(params).concat(Cell.renderHeaderTitle(params))
@@ -181,7 +182,7 @@ export const Cell = {
181
182
  const compConf = VXETable.renderer.get(renderOpts.name)
182
183
  const compFn = compConf ? compConf[funName] : null
183
184
  if (compFn) {
184
- return compFn(renderOpts, Object.assign({ $type: editRender ? 'edit' : 'cell' }, params))
185
+ return getSlotVNs(compFn(renderOpts, Object.assign({ $type: editRender ? 'edit' : 'cell' }, params)))
185
186
  }
186
187
  }
187
188
  const cellValue = $table.getCellLabel(row, column)
@@ -211,7 +212,7 @@ export const Cell = {
211
212
  /**
212
213
  * 树节点
213
214
  */
214
- renderTreeIcon (params: VxeTableDefines.CellRenderBodyParams, cellVNodes: VNode[]) {
215
+ renderTreeIcon (params: VxeTableDefines.CellRenderBodyParams, cellVNodes: SlotVNodeType[]) {
215
216
  const { $table, isHidden } = params
216
217
  const { reactData } = $table
217
218
  const { computeTreeOpts } = $table.getComputeMaps()
@@ -272,7 +273,7 @@ export const Cell = {
272
273
  const { $table, column } = params
273
274
  const { slots } = column
274
275
  const headerSlot = slots ? slots.header : null
275
- return renderTitleContent(params, headerSlot ? $table.callSlot(headerSlot, params) : formatText(column.getTitle(), 1))
276
+ return renderTitleContent(params, headerSlot ? $table.callSlot(headerSlot, params) : [formatText(column.getTitle(), 1)])
276
277
  },
277
278
  renderSeqCell (params: VxeTableDefines.CellRenderBodyParams) {
278
279
  const { $table, column } = params
@@ -626,7 +627,7 @@ export const Cell = {
626
627
  if (contentRender) {
627
628
  const compConf = VXETable.renderer.get(contentRender.name)
628
629
  if (compConf && compConf.renderExpand) {
629
- return compConf.renderExpand(contentRender, params)
630
+ return getSlotVNs(compConf.renderExpand(contentRender, params))
630
631
  }
631
632
  }
632
633
  return []
@@ -792,7 +793,10 @@ export const Cell = {
792
793
  if (editSlot) {
793
794
  return $table.callSlot(editSlot, params)
794
795
  }
795
- return compConf && compConf.renderEdit ? compConf.renderEdit(editRender, Object.assign({ $type: 'edit' }, params)) : []
796
+ if (compConf && compConf.renderEdit) {
797
+ return getSlotVNs(compConf.renderEdit(editRender, Object.assign({ $type: 'edit' }, params)))
798
+ }
799
+ return []
796
800
  }
797
801
  if (defaultSlot) {
798
802
  return $table.callSlot(defaultSlot, params)
@@ -15,6 +15,7 @@ import tableProps from './props'
15
15
  import tableEmits from './emits'
16
16
  import VxeLoading from '../../loading/index'
17
17
  import { getRowUniqueId, clearTableAllStatus, getRowkey, getRowid, rowToVisible, colToVisible, getCellValue, setCellValue, handleFieldOrColumn, toTreePathSeq, restoreScrollLocation, restoreScrollListener, XEBodyScrollElement } from './util'
18
+ import { getSlotVNs } from '../../tools/vn'
18
19
 
19
20
  import { VxeGridConstructor, VxeGridPrivateMethods, VxeTableConstructor, TableReactData, TableInternalData, VxeTablePropTypes, VxeToolbarConstructor, VxeTooltipInstance, TablePrivateMethods, VxeTablePrivateRef, VxeTablePrivateComputed, VxeTablePrivateMethods, VxeTableMethods, TableMethods, VxeMenuPanelInstance, VxeTableDefines, VxeTableProps } from '../../../types/all'
20
21
 
@@ -4088,7 +4089,7 @@ export default defineComponent({
4088
4089
  // 如果点击了当前表格之外
4089
4090
  !getEventTargetNode(evnt, el).flag
4090
4091
  ) {
4091
- setTimeout(() => $xetable.clearActived(evnt))
4092
+ setTimeout(() => $xetable.clearEdit(evnt))
4092
4093
  }
4093
4094
  })
4094
4095
  }
@@ -4164,7 +4165,7 @@ export default defineComponent({
4164
4165
  // 如果是激活编辑状态,则取消编辑
4165
4166
  if (actived.row) {
4166
4167
  const params = actived.args
4167
- $xetable.clearActived(evnt)
4168
+ $xetable.clearEdit(evnt)
4168
4169
  // 如果配置了选中功能,则为选中状态
4169
4170
  if (mouseOpts.selected) {
4170
4171
  nextTick(() => $xetable.handleSelected(params, evnt))
@@ -4237,7 +4238,7 @@ export default defineComponent({
4237
4238
  // 如果是激活编辑状态,则取消编辑
4238
4239
  if (actived.row) {
4239
4240
  const params = actived.args
4240
- $xetable.clearActived(evnt)
4241
+ $xetable.clearEdit(evnt)
4241
4242
  // 如果配置了选中功能,则为选中状态
4242
4243
  if (mouseOpts.selected) {
4243
4244
  nextTick(() => $xetable.handleSelected(params, evnt))
@@ -4273,7 +4274,7 @@ export default defineComponent({
4273
4274
  // 如果是激活编辑状态,则取消编辑
4274
4275
  if (actived.row) {
4275
4276
  params = actived.args
4276
- $xetable.clearActived(evnt)
4277
+ $xetable.clearEdit(evnt)
4277
4278
  // 如果配置了选中功能,则为选中状态
4278
4279
  if (mouseOpts.selected) {
4279
4280
  nextTick(() => $xetable.handleSelected(params, evnt))
@@ -4529,7 +4530,7 @@ export default defineComponent({
4529
4530
  return $xegrid.callSlot(slotFunc, params)
4530
4531
  }
4531
4532
  if (XEUtils.isFunction(slotFunc)) {
4532
- return slotFunc(params)
4533
+ return getSlotVNs(slotFunc(params))
4533
4534
  }
4534
4535
  }
4535
4536
  return []
@@ -4875,7 +4876,7 @@ export default defineComponent({
4875
4876
  XEUtils.eachTree([row], (item) => {
4876
4877
  if ($xetable.eqRow(item, row) || (!checkMethod || checkMethod({ row: item }))) {
4877
4878
  XEUtils.set(item, checkField, value)
4878
- XEUtils.remove(treeIndeterminates, half => half === item)
4879
+ XEUtils.remove(treeIndeterminates, half => $xetable.eqRow(half, item))
4879
4880
  handleCheckboxReserveRow(row, value)
4880
4881
  }
4881
4882
  }, treeOpts)
@@ -4914,9 +4915,9 @@ export default defineComponent({
4914
4915
  if (value) {
4915
4916
  selection.push(item)
4916
4917
  } else {
4917
- XEUtils.remove(selection, select => select === item)
4918
+ XEUtils.remove(selection, select => $xetable.eqRow(select, item))
4918
4919
  }
4919
- XEUtils.remove(treeIndeterminates, half => half === item)
4920
+ XEUtils.remove(treeIndeterminates, half => $xetable.eqRow(half, item))
4920
4921
  handleCheckboxReserveRow(row, value)
4921
4922
  }
4922
4923
  }, treeOpts)
@@ -7,6 +7,7 @@ import { getEventTargetNode } from '../../tools/dom'
7
7
  import { formatText } from '../../tools/utils'
8
8
  import { warnLog, errLog } from '../../tools/log'
9
9
  import { GlobalEvent } from '../../tools/event'
10
+ import { getSlotVNs } from '../../tools/vn'
10
11
 
11
12
  import { VxeGridConstructor, GridPrivateMethods, ToolbarMethods, VxeToolbarConstructor, VxeToolbarEmits, VxeToolbarPropTypes, VxeTableConstructor, ToolbarPrivateRef, VxeTableMethods, VxeTablePrivateMethods, ToolbarReactData, VxeTableDefines } from '../../../types/all'
12
13
 
@@ -374,7 +375,7 @@ export default defineComponent({
374
375
  const { buttons } = props
375
376
  const buttonsSlot = slots.buttons
376
377
  if (buttonsSlot) {
377
- return buttonsSlot({ $grid: $xegrid, $table: $xetable })
378
+ return getSlotVNs(buttonsSlot({ $grid: $xegrid, $table: $xetable }))
378
379
  }
379
380
  const btnVNs: VNode[] = []
380
381
  if (buttons) {
@@ -421,7 +422,7 @@ export default defineComponent({
421
422
  const { tools } = props
422
423
  const toolsSlot = slots.tools
423
424
  if (toolsSlot) {
424
- return toolsSlot({ $grid: $xegrid, $table: $xetable })
425
+ return getSlotVNs(toolsSlot({ $grid: $xegrid, $table: $xetable }))
425
426
  }
426
427
  const btnVNs: VNode[] = []
427
428
  if (tools) {
@@ -671,7 +672,7 @@ export default defineComponent({
671
672
  }) : createCommentVNode(),
672
673
  zoom && $xegrid ? h(resolveComponent('vxe-button') as ComponentOptions, {
673
674
  circle: true,
674
- icon: $xegrid.isMaximized() ? (zoomOpts.iconOut || GlobalConfig.icon.TOOLBAR_TOOLS_ZOOM_OUT) : (zoomOpts.iconIn || GlobalConfig.icon.TOOLBAR_TOOLS_ZOOM_IN),
675
+ icon: $xegrid.isMaximized() ? (zoomOpts.iconOut || GlobalConfig.icon.TOOLBAR_TOOLS_MINIMIZE) : (zoomOpts.iconIn || GlobalConfig.icon.TOOLBAR_TOOLS_FULLSCREEN),
675
676
  title: GlobalConfig.i18n(`vxe.toolbar.zoom${$xegrid.isMaximized() ? 'Out' : 'In'}`),
676
677
  onClick: zoomEvent
677
678
  }) : createCommentVNode(),
@@ -1,3 +1,13 @@
1
+ import XEUtils from 'xe-utils'
2
+ import { SlotVNodeType } from '../../types/all'
3
+
1
4
  export function getOnName (type: string) {
2
5
  return 'on' + type.substring(0, 1).toLocaleUpperCase() + type.substring(1)
3
6
  }
7
+
8
+ export function getSlotVNs (vns: SlotVNodeType | SlotVNodeType[]) {
9
+ if (XEUtils.isArray(vns)) {
10
+ return vns
11
+ }
12
+ return [vns]
13
+ }