@opentiny/vue-docs 2.2.6 → 2.2.7

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 (612) hide show
  1. package/demos/mobile/app/alert/basic-usage.vue +26 -0
  2. package/demos/mobile/app/alert/center.vue +13 -0
  3. package/demos/mobile/app/alert/custom-close.vue +25 -7
  4. package/demos/mobile/app/alert/target.vue +30 -0
  5. package/demos/mobile/app/alert/webdoc/alert.js +50 -0
  6. package/demos/mobile/app/checkbox/basic-usage.vue +33 -0
  7. package/demos/mobile/app/checkbox/{default.vue → checkbox-group.vue} +5 -10
  8. package/demos/mobile/app/checkbox/{label.vue → disabled.vue} +4 -3
  9. package/demos/mobile/app/checkbox/event-change.vue +2 -2
  10. package/demos/mobile/app/checkbox/icon-position.vue +49 -0
  11. package/demos/mobile/app/checkbox/indeterminate.vue +2 -2
  12. package/demos/mobile/app/checkbox/true-false-label.vue +2 -2
  13. package/demos/mobile/app/checkbox/webdoc/checkbox.js +88 -46
  14. package/demos/mobile/app/input/basic-usage.vue +32 -0
  15. package/demos/mobile/app/input/clearable.vue +7 -7
  16. package/demos/mobile/app/input/counter.vue +15 -8
  17. package/demos/mobile/app/input/disabled.vue +31 -0
  18. package/demos/mobile/app/input/events.vue +32 -13
  19. package/demos/mobile/app/input/max-min-length.vue +5 -5
  20. package/demos/mobile/app/input/methods.vue +53 -0
  21. package/demos/mobile/app/input/native-attributes.vue +62 -0
  22. package/demos/mobile/app/input/prefix-suffix-icon.vue +35 -0
  23. package/demos/mobile/app/input/show-password.vue +5 -5
  24. package/demos/mobile/app/input/slots.vue +65 -0
  25. package/demos/mobile/app/input/textarea-rows-cols.vue +31 -0
  26. package/demos/mobile/app/input/textarea-scalable.vue +41 -0
  27. package/demos/mobile/app/input/{type-be-form-select.vue → type-select.vue} +10 -10
  28. package/demos/mobile/app/input/type.vue +60 -0
  29. package/demos/mobile/app/input/validate-event.vue +5 -30
  30. package/demos/mobile/app/input/webdoc/input.js +281 -312
  31. package/demos/mobile/app/label/base.vue +24 -0
  32. package/demos/mobile/app/label/bold.vue +23 -0
  33. package/demos/mobile/app/label/color.vue +34 -0
  34. package/demos/mobile/app/label/decimal.vue +28 -0
  35. package/demos/mobile/app/label/ellipsis.vue +31 -0
  36. package/demos/mobile/app/label/limit.vue +24 -0
  37. package/demos/mobile/app/label/position.vue +30 -0
  38. package/demos/mobile/app/label/required.vue +24 -0
  39. package/demos/mobile/app/label/size.vue +31 -0
  40. package/demos/mobile/app/label/type.vue +30 -0
  41. package/demos/mobile/app/label/webdoc/label.cn.md +11 -0
  42. package/demos/mobile/app/label/webdoc/label.en.md +11 -0
  43. package/demos/mobile/app/label/webdoc/label.js +247 -0
  44. package/demos/mobile/app/label/wholeline.vue +24 -0
  45. package/demos/mobile/app/mask/basic-usage.vue +38 -0
  46. package/demos/mobile/app/mask/click-no-hide.vue +32 -0
  47. package/demos/mobile/app/mask/slot-default.vue +37 -0
  48. package/demos/mobile/app/mask/webdoc/mask.cn.md +11 -0
  49. package/demos/mobile/app/mask/webdoc/mask.en.md +11 -0
  50. package/demos/mobile/app/mask/webdoc/mask.js +114 -0
  51. package/demos/mobile/app/mask/z-index.vue +30 -0
  52. package/demos/mobile/app/tag/basic-usage.vue +27 -0
  53. package/demos/mobile/app/tag/different-color.vue +30 -0
  54. package/demos/mobile/app/tag/max-width.vue +26 -0
  55. package/demos/mobile/app/tag/mini.vue +27 -0
  56. package/demos/mobile/app/tag/webdoc/tag.cn.md +7 -0
  57. package/demos/mobile/app/tag/webdoc/tag.en.md +7 -0
  58. package/demos/mobile/app/tag/webdoc/tag.js +96 -0
  59. package/demos/mobile/menus.js +5 -2
  60. package/demos/mobile-first/app/alert/webdoc/alert.js +77 -36
  61. package/demos/mobile-first/app/cascader-view/webdoc/cascader-view.js +249 -10
  62. package/demos/mobile-first/app/exception/webdoc/exception.js +94 -22
  63. package/demos/mobile-first/app/flowchart/webdoc/flowchart.js +24 -25
  64. package/demos/mobile-first/app/image/webdoc/image.js +126 -57
  65. package/demos/mobile-first/app/pull-refresh/webdoc/pull-refresh.js +223 -9
  66. package/demos/mobile-first/app/tooltip/webdoc/tooltip.js +47 -53
  67. package/demos/pc/app/action-menu/icon.spec.ts +38 -0
  68. package/demos/pc/app/action-menu/webdoc/action-menu.cn.md +1 -1
  69. package/demos/pc/app/action-menu/webdoc/action-menu.en.md +1 -1
  70. package/demos/pc/app/action-menu/webdoc/action-menu.js +16 -66
  71. package/demos/pc/app/alert/custom-close-composition-api.vue +2 -2
  72. package/demos/pc/app/alert/custom-close.vue +3 -4
  73. package/demos/pc/app/amount/webdoc/amount.js +1 -1
  74. package/demos/pc/app/anchor/basic-usage-composition-api.vue +11 -2
  75. package/demos/pc/app/anchor/basic-usage.vue +11 -2
  76. package/demos/pc/app/anchor/is-affix-composition-api.vue +8 -2
  77. package/demos/pc/app/anchor/is-affix.vue +8 -2
  78. package/demos/pc/app/anchor/webdoc/anchor.js +3 -3
  79. package/demos/pc/app/area/webdoc/area.js +1 -1
  80. package/demos/pc/app/bulletin-board/active-name.spec.ts +1 -2
  81. package/demos/pc/app/bulletin-board/base.spec.ts +2 -3
  82. package/demos/pc/app/bulletin-board/icon.spec.ts +1 -1
  83. package/demos/pc/app/bulletin-board/more-link.spec.ts +8 -2
  84. package/demos/pc/app/bulletin-board/route.spec.ts +3 -3
  85. package/demos/pc/app/bulletin-board/tab-title.spec.ts +1 -1
  86. package/demos/pc/app/bulletin-board/title.spec.ts +1 -1
  87. package/demos/pc/app/bulletin-board/url.spec.ts +3 -3
  88. package/demos/pc/app/bulletin-board/webdoc/bulletin-board.js +12 -11
  89. package/demos/pc/app/calendar/webdoc/calendar.js +1 -1
  90. package/demos/pc/app/calendar-view/webdoc/calendar-view.js +3 -2
  91. package/demos/pc/app/carousel/autoplay.spec.ts +1 -1
  92. package/demos/pc/app/carousel/basic-usage.spec.ts +12 -21
  93. package/demos/pc/app/carousel/card-mode.spec.ts +16 -37
  94. package/demos/pc/app/carousel/carousel-arrow-always.spec.ts +1 -1
  95. package/demos/pc/app/carousel/carousel-arrow-hover.spec.ts +1 -1
  96. package/demos/pc/app/carousel/carousel-arrow-never.spec.ts +1 -1
  97. package/demos/pc/app/carousel/carousel-events.spec.ts +5 -3
  98. package/demos/pc/app/carousel/close-loop.spec.ts +1 -1
  99. package/demos/pc/app/carousel/indicator-trigger.spec.ts +1 -1
  100. package/demos/pc/app/carousel/manual-play.spec.ts +1 -1
  101. package/demos/pc/app/carousel/play-interval.spec.ts +7 -11
  102. package/demos/pc/app/carousel/show-title.spec.ts +1 -1
  103. package/demos/pc/app/carousel/up-down-carousel.spec.ts +1 -1
  104. package/demos/pc/app/carousel/webdoc/carousel.js +1 -1
  105. package/demos/pc/app/cascader/webdoc/cascader.js +1 -1
  106. package/demos/pc/app/chart/webdoc/chart-attributes-demo.js +1 -1
  107. package/demos/pc/app/chart/webdoc/chart-autonavi-map.js +1 -1
  108. package/demos/pc/app/chart/webdoc/chart-baidu-map.js +1 -1
  109. package/demos/pc/app/chart/webdoc/chart-bar.js +1 -1
  110. package/demos/pc/app/chart/webdoc/chart-boxplot.js +1 -1
  111. package/demos/pc/app/chart/webdoc/chart-candle.js +1 -1
  112. package/demos/pc/app/chart/webdoc/chart-events.js +1 -1
  113. package/demos/pc/app/chart/webdoc/chart-funnel.js +1 -1
  114. package/demos/pc/app/chart/webdoc/chart-gauge.js +1 -1
  115. package/demos/pc/app/chart/webdoc/chart-graph.js +1 -1
  116. package/demos/pc/app/chart/webdoc/chart-heatmap.js +1 -1
  117. package/demos/pc/app/chart/webdoc/chart-histogram.js +1 -1
  118. package/demos/pc/app/chart/webdoc/chart-line.js +1 -1
  119. package/demos/pc/app/chart/webdoc/chart-liquidfill.js +1 -1
  120. package/demos/pc/app/chart/webdoc/chart-map.js +1 -1
  121. package/demos/pc/app/chart/webdoc/chart-pie.js +1 -1
  122. package/demos/pc/app/chart/webdoc/chart-question.js +1 -1
  123. package/demos/pc/app/chart/webdoc/chart-radar.js +1 -1
  124. package/demos/pc/app/chart/webdoc/chart-ring.js +1 -1
  125. package/demos/pc/app/chart/webdoc/chart-sankey.js +1 -1
  126. package/demos/pc/app/chart/webdoc/chart-scatter.js +1 -1
  127. package/demos/pc/app/chart/webdoc/chart-sunburst.js +1 -1
  128. package/demos/pc/app/chart/webdoc/chart-tree.js +1 -1
  129. package/demos/pc/app/chart/webdoc/chart-waterfall.js +1 -1
  130. package/demos/pc/app/chart/webdoc/chart-wordcloud.js +1 -1
  131. package/demos/pc/app/chart/webdoc/chart.js +1 -1
  132. package/demos/pc/app/color/webdoc/color.js +1 -1
  133. package/demos/pc/app/color-picker/alpha.spec.ts +14 -0
  134. package/demos/pc/app/color-picker/base.spec.ts +12 -0
  135. package/demos/pc/app/color-picker/default-visible.spec.ts +8 -0
  136. package/demos/pc/app/color-picker/dynamic-color-change.spec.ts +9 -0
  137. package/demos/pc/app/color-picker/event.spec.ts +10 -0
  138. package/demos/pc/app/color-picker/history.spec.ts +3 -3
  139. package/demos/pc/app/color-picker/predefine.spec.ts +2 -2
  140. package/demos/pc/app/color-picker/webdoc/color-picker.js +0 -10
  141. package/demos/pc/app/color-select-panel/alpha.spec.ts +9 -0
  142. package/demos/pc/app/color-select-panel/base.spec.ts +9 -0
  143. package/demos/pc/app/color-select-panel/event.spec.ts +12 -0
  144. package/demos/pc/app/color-select-panel/history.spec.ts +15 -0
  145. package/demos/pc/app/color-select-panel/predefine.spec.ts +25 -0
  146. package/demos/pc/app/color-select-panel/webdoc/color-select-panel.js +0 -10
  147. package/demos/pc/app/company/webdoc/company.js +1 -1
  148. package/demos/pc/app/config-provider/webdoc/config-provider.cn.md +2 -2
  149. package/demos/pc/app/config-provider/webdoc/config-provider.js +2 -9
  150. package/demos/pc/app/container/webdoc/container.js +1 -1
  151. package/demos/pc/app/count-api.js +34 -0
  152. package/demos/pc/app/country/webdoc/country.js +1 -1
  153. package/demos/pc/app/credit-card-form/webdoc/credit-card-form.js +1 -1
  154. package/demos/pc/app/crop/aspect-ratio-composition-api.vue +8 -0
  155. package/demos/pc/app/crop/aspect-ratio.spec.ts +14 -0
  156. package/demos/pc/app/crop/aspect-ratio.vue +9 -0
  157. package/demos/pc/app/crop/auto-crop-area.spec.ts +15 -0
  158. package/demos/pc/app/crop/basic-usage.spec.ts +14 -0
  159. package/demos/pc/app/crop/crop-meth.spec.ts +19 -0
  160. package/demos/pc/app/crop/drag-mode-composition-api.vue +1 -1
  161. package/demos/pc/app/crop/drag-mode.spec.ts +16 -0
  162. package/demos/pc/app/crop/drag-mode.vue +1 -1
  163. package/demos/pc/app/crop/event-about-crop-composition-api.vue +9 -0
  164. package/demos/pc/app/crop/event-about-crop.spec.ts +15 -0
  165. package/demos/pc/app/crop/event-about-crop.vue +8 -0
  166. package/demos/pc/app/crop/event-ready.spec.ts +14 -0
  167. package/demos/pc/app/crop/get-container-data.spec.ts +18 -0
  168. package/demos/pc/app/crop/get-crop-box-data.spec.ts +13 -0
  169. package/demos/pc/app/crop/get-cropped-canvas-composition-api.vue +7 -1
  170. package/demos/pc/app/crop/get-cropped-canvas.spec.ts +14 -0
  171. package/demos/pc/app/crop/get-cropped-canvas.vue +7 -1
  172. package/demos/pc/app/crop/get-data.spec.ts +17 -0
  173. package/demos/pc/app/crop/get-image-data-composition-api.vue +7 -0
  174. package/demos/pc/app/crop/get-image-data.spec.ts +14 -0
  175. package/demos/pc/app/crop/get-image-data.vue +7 -0
  176. package/demos/pc/app/crop/min-crop-box-width-height.spec.ts +11 -0
  177. package/demos/pc/app/crop/no-background.spec.ts +14 -0
  178. package/demos/pc/app/crop/no-guides.spec.ts +8 -0
  179. package/demos/pc/app/crop/no-modal.spec.ts +10 -0
  180. package/demos/pc/app/crop/replace-image.spec.ts +17 -0
  181. package/demos/pc/app/crop/view-mode-composition-api.vue +8 -2
  182. package/demos/pc/app/crop/view-mode.spec.ts +31 -0
  183. package/demos/pc/app/crop/view-mode.vue +10 -2
  184. package/demos/pc/app/crop/wheel-zoom-ratio.spec.ts +15 -0
  185. package/demos/pc/app/crop/zoom-on-wheel.spec.ts +10 -0
  186. package/demos/pc/app/currency/webdoc/currency.js +1 -1
  187. package/demos/pc/app/date-picker/webdoc/date-picker.js +85 -54
  188. package/demos/pc/app/dept/webdoc/dept.js +1 -1
  189. package/demos/pc/app/detail-page/basic-usage-composition-api.vue +1 -1
  190. package/demos/pc/app/detail-page/basic-usage.vue +1 -1
  191. package/demos/pc/app/detail-page/custom-show-text-composition-api.vue +11 -12
  192. package/demos/pc/app/detail-page/custom-show-text.spec.ts +5 -7
  193. package/demos/pc/app/detail-page/custom-show-text.vue +11 -12
  194. package/demos/pc/app/detail-page/webdoc/detail-page.js +46 -22
  195. package/demos/pc/app/dialog-box/basic-usage.spec.ts +11 -38
  196. package/demos/pc/app/dialog-box/center.spec.ts +4 -14
  197. package/demos/pc/app/dialog-box/close-on-click-modal.spec.ts +3 -7
  198. package/demos/pc/app/dialog-box/close-on-press-escape.spec.ts +2 -5
  199. package/demos/pc/app/dialog-box/custom-dialog-content.spec.ts +6 -8
  200. package/demos/pc/app/dialog-box/custom-dialog-footer.spec.ts +3 -14
  201. package/demos/pc/app/dialog-box/custom-dialog-title.spec.ts +3 -12
  202. package/demos/pc/app/dialog-box/destroy-on-close.spec.ts +9 -7
  203. package/demos/pc/app/dialog-box/dialog-top-height.spec.ts +6 -12
  204. package/demos/pc/app/dialog-box/dialog-width.spec.ts +5 -16
  205. package/demos/pc/app/dialog-box/draggable.spec.ts +4 -5
  206. package/demos/pc/app/dialog-box/form-in-dialog.spec.ts +5 -4
  207. package/demos/pc/app/dialog-box/lock-scroll.spec.ts +7 -10
  208. package/demos/pc/app/dialog-box/open-close-events.spec.ts +0 -1
  209. package/demos/pc/app/dialog-box/right-dialog-composition-api.vue +1 -1
  210. package/demos/pc/app/dialog-box/right-dialog.vue +1 -1
  211. package/demos/pc/app/dialog-select/{grid-multi-composition-api.vue → nest-grid-multi-composition-api.vue} +7 -4
  212. package/demos/pc/app/dialog-select/{grid-multi.vue → nest-grid-multi.vue} +4 -2
  213. package/demos/pc/app/dialog-select/{grid-radio-composition-api.vue → nest-grid-single-composition-api.vue} +6 -3
  214. package/demos/pc/app/dialog-select/{grid-radio.vue → nest-grid-single.vue} +4 -2
  215. package/demos/pc/app/dialog-select/{tree-multi-composition-api.vue → nest-tree-multi-composition-api.vue} +22 -9
  216. package/demos/pc/app/dialog-select/{tree-multi.vue → nest-tree-multi.vue} +19 -8
  217. package/demos/pc/app/dialog-select/{tree-radio-composition-api.vue → nest-tree-single-composition-api.vue} +19 -7
  218. package/demos/pc/app/dialog-select/{tree-radio.vue → nest-tree-single.vue} +18 -6
  219. package/demos/pc/app/dialog-select/webdoc/dialog-select.js +282 -183
  220. package/demos/pc/app/divider/basic-usage.spec.ts +7 -0
  221. package/demos/pc/app/divider/content-position.spec.ts +12 -0
  222. package/demos/pc/app/divider/custom-style.spec.ts +19 -0
  223. package/demos/pc/app/divider/direction.spec.ts +12 -0
  224. package/demos/pc/app/drawer/basic-usage.vue +7 -0
  225. package/demos/pc/app/drawer/webdoc/drawer.js +1 -1
  226. package/demos/pc/app/drop-roles/webdoc/drop-roles.js +1 -1
  227. package/demos/pc/app/drop-times/webdoc/drop-times.js +1 -1
  228. package/demos/pc/app/dropdown/hide-on-click-composition-api.vue +1 -1
  229. package/demos/pc/app/dropdown/hide-on-click.vue +1 -1
  230. package/demos/pc/app/dropdown/inherit-width-composition-api.vue +2 -2
  231. package/demos/pc/app/dropdown/inherit-width.spec.ts +43 -0
  232. package/demos/pc/app/dropdown/inherit-width.vue +2 -2
  233. package/demos/pc/app/dropdown/options.spec.ts +1 -1
  234. package/demos/pc/app/dropdown/show-icon.spec.ts +34 -0
  235. package/demos/pc/app/dropdown/slots-composition-api.vue +1 -1
  236. package/demos/pc/app/dropdown/tip.spec.ts +49 -0
  237. package/demos/pc/app/dropdown/trigger-composition-api.vue +10 -10
  238. package/demos/pc/app/dropdown/visible-arrow.spec.ts +21 -0
  239. package/demos/pc/app/dropdown/webdoc/dropdown.cn.md +1 -1
  240. package/demos/pc/app/dropdown/webdoc/dropdown.en.md +1 -1
  241. package/demos/pc/app/dropdown/webdoc/dropdown.js +53 -36
  242. package/demos/pc/app/espace/webdoc/espace.js +1 -1
  243. package/demos/pc/app/file-upload/drag-upload.spec.ts +1 -1
  244. package/demos/pc/app/file-upload/picture-card.spec.ts +2 -2
  245. package/demos/pc/app/filter-panel/basic-usage-composition-api.vue +13 -2
  246. package/demos/pc/app/filter-panel/basic-usage.spec.ts +15 -6
  247. package/demos/pc/app/filter-panel/basic-usage.vue +15 -4
  248. package/demos/pc/app/filter-panel/event.spec.ts +12 -2
  249. package/demos/pc/app/filter-panel/manual-hide.spec.ts +2 -2
  250. package/demos/pc/app/filter-panel/popper-class-composition-api.vue +1 -0
  251. package/demos/pc/app/filter-panel/popper-class.spec.ts +2 -2
  252. package/demos/pc/app/filter-panel/popper-class.vue +1 -0
  253. package/demos/pc/app/filter-panel/tip.spec.ts +2 -2
  254. package/demos/pc/app/filter-panel/webdoc/filter-panel.cn.md +1 -1
  255. package/demos/pc/app/filter-panel/webdoc/filter-panel.en.md +3 -3
  256. package/demos/pc/app/filter-panel/webdoc/filter-panel.js +50 -56
  257. package/demos/pc/app/floatbar/webdoc/floatbar.js +1 -1
  258. package/demos/pc/app/flowchart/webdoc/flowchart.js +1 -1
  259. package/demos/pc/app/font/webdoc/font.js +1 -1
  260. package/demos/pc/app/form/events-composition-api.vue +46 -0
  261. package/demos/pc/app/form/events.spec.ts +12 -0
  262. package/demos/pc/app/form/events.vue +52 -0
  263. package/demos/pc/app/form/form-validate-field-composition-api.vue +13 -14
  264. package/demos/pc/app/form/form-validate-field.spec.ts +9 -2
  265. package/demos/pc/app/form/form-validate-field.vue +9 -12
  266. package/demos/pc/app/form/form-validation-composition-api.vue +6 -1
  267. package/demos/pc/app/form/form-validation.vue +5 -1
  268. package/demos/pc/app/form/label-position-composition-api.vue +1 -1
  269. package/demos/pc/app/form/label-position.vue +1 -1
  270. package/demos/pc/app/form/webdoc/form.js +18 -8
  271. package/demos/pc/app/fullscreen/example-api.spec.ts +14 -29
  272. package/demos/pc/app/fullscreen/example-component.spec.ts +12 -29
  273. package/demos/pc/app/fullscreen/webdoc/fullscreen.js +4 -4
  274. package/demos/pc/app/grid/custom/column-width-composition-api.vue +1 -1
  275. package/demos/pc/app/grid/custom/column-width.vue +1 -1
  276. package/demos/pc/app/grid/custom/prsonalized-drag.vue +11 -1
  277. package/demos/pc/app/grid/custom-style/footer-style-composition-api.vue +19 -16
  278. package/demos/pc/app/grid/custom-style/footer-style.spec.js +1 -0
  279. package/demos/pc/app/grid/custom-style/footer-style.vue +18 -16
  280. package/demos/pc/app/grid/custom-style/header-style-composition-api.vue +18 -13
  281. package/demos/pc/app/grid/custom-style/header-style.spec.js +1 -0
  282. package/demos/pc/app/grid/custom-style/header-style.vue +18 -14
  283. package/demos/pc/app/grid/edit/trigger-mode-hm-editing-composition-api.vue +12 -4
  284. package/demos/pc/app/grid/edit/trigger-mode-hm-editing.spec.js +6 -1
  285. package/demos/pc/app/grid/edit/trigger-mode-hm-editing.vue +12 -4
  286. package/demos/pc/app/grid/highlight/highlight-hover-row-composition-api.vue +1 -1
  287. package/demos/pc/app/grid/highlight/highlight-hover-row.vue +1 -1
  288. package/demos/pc/app/grid/validation/before-submit-validation-composition-api.vue +17 -0
  289. package/demos/pc/app/grid/validation/before-submit-validation.vue +17 -0
  290. package/demos/pc/app/grid/webdoc/grid-align.js +1 -1
  291. package/demos/pc/app/grid/webdoc/grid-appearance-settings.js +1 -1
  292. package/demos/pc/app/grid/webdoc/grid-context-menu.js +1 -1
  293. package/demos/pc/app/grid/webdoc/grid-custom-style.js +3 -3
  294. package/demos/pc/app/grid/webdoc/grid-custom.js +2 -2
  295. package/demos/pc/app/grid/webdoc/grid-data-source.js +1 -1
  296. package/demos/pc/app/grid/webdoc/grid-drag.js +1 -1
  297. package/demos/pc/app/grid/webdoc/grid-dynamically-columns.js +1 -1
  298. package/demos/pc/app/grid/webdoc/grid-edit.js +1 -1
  299. package/demos/pc/app/grid/webdoc/grid-editor.js +1 -1
  300. package/demos/pc/app/grid/webdoc/grid-empty.js +1 -1
  301. package/demos/pc/app/grid/webdoc/grid-event.js +1 -1
  302. package/demos/pc/app/grid/webdoc/grid-expand.js +1 -1
  303. package/demos/pc/app/grid/webdoc/grid-faq.js +1 -1
  304. package/demos/pc/app/grid/webdoc/grid-filter.js +1 -1
  305. package/demos/pc/app/grid/webdoc/grid-fixed.js +1 -1
  306. package/demos/pc/app/grid/webdoc/grid-footer.js +1 -1
  307. package/demos/pc/app/grid/webdoc/grid-header.js +1 -1
  308. package/demos/pc/app/grid/webdoc/grid-highlight.js +1 -1
  309. package/demos/pc/app/grid/webdoc/grid-import-export.js +1 -1
  310. package/demos/pc/app/grid/webdoc/grid-large-data.js +3 -2
  311. package/demos/pc/app/grid/webdoc/grid-loading.js +1 -1
  312. package/demos/pc/app/grid/webdoc/grid-mouse-keyboard.js +1 -1
  313. package/demos/pc/app/grid/webdoc/grid-operation-column.js +1 -1
  314. package/demos/pc/app/grid/webdoc/grid-pager.js +1 -1
  315. package/demos/pc/app/grid/webdoc/grid-renderer.js +1 -1
  316. package/demos/pc/app/grid/webdoc/grid-row-grouping.js +1 -1
  317. package/demos/pc/app/grid/webdoc/grid-serial-column.js +1 -1
  318. package/demos/pc/app/grid/webdoc/grid-size.js +1 -1
  319. package/demos/pc/app/grid/webdoc/grid-slot.js +1 -1
  320. package/demos/pc/app/grid/webdoc/grid-sort.js +1 -1
  321. package/demos/pc/app/grid/webdoc/grid-span.js +1 -1
  322. package/demos/pc/app/grid/webdoc/grid-tip.js +1 -1
  323. package/demos/pc/app/grid/webdoc/grid-toolbar.js +1 -1
  324. package/demos/pc/app/grid/webdoc/grid-tree-table.js +1 -1
  325. package/demos/pc/app/grid/webdoc/grid-validation.js +1 -1
  326. package/demos/pc/app/grid/webdoc/grid.js +27 -37
  327. package/demos/pc/app/hrapprover/webdoc/hrapprover.js +1 -1
  328. package/demos/pc/app/image/webdoc/image.js +2 -2
  329. package/demos/pc/app/infinite-scroll/basic-usage.spec.ts +11 -0
  330. package/demos/pc/app/infinite-scroll/disabled.spec.ts +10 -0
  331. package/demos/pc/app/infinite-scroll/webdoc/infinite-scroll.cn.md +1 -1
  332. package/demos/pc/app/infinite-scroll/webdoc/infinite-scroll.js +18 -18
  333. package/demos/pc/app/layout/webdoc/layout.js +1 -1
  334. package/demos/pc/app/link/webdoc/link.js +1 -1
  335. package/demos/pc/app/link-menu/custom-foot.spec.ts +1 -1
  336. package/demos/pc/app/link-menu/custom-icon.spec.ts +2 -17
  337. package/demos/pc/app/link-menu/data-resource.spec.ts +9 -18
  338. package/demos/pc/app/link-menu/get-menu-data-sync.spec.ts +1 -1
  339. package/demos/pc/app/link-menu/menu-items.spec.ts +1 -1
  340. package/demos/pc/app/link-menu/webdoc/link-menu.js +8 -28
  341. package/demos/pc/app/loading/webdoc/loading.js +6 -9
  342. package/demos/pc/app/locales/webdoc/locales.js +1 -1
  343. package/demos/pc/app/logon-user/webdoc/logon-user.js +1 -1
  344. package/demos/pc/app/logout/webdoc/logout.js +1 -1
  345. package/demos/pc/app/modal/footer-btn-props-composition-api.vue +1 -1
  346. package/demos/pc/app/modal/min-height.spec.ts +2 -3
  347. package/demos/pc/app/modal/min-width.spec.ts +2 -2
  348. package/demos/pc/app/modal/resize.spec.ts +1 -1
  349. package/demos/pc/app/modal/webdoc/modal.js +3 -3
  350. package/demos/pc/app/numeric/about-step.spec.ts +2 -2
  351. package/demos/pc/app/numeric/allow-empty.spec.ts +5 -7
  352. package/demos/pc/app/numeric/basic-usage.spec.ts +2 -2
  353. package/demos/pc/app/numeric/blur-event.spec.ts +1 -1
  354. package/demos/pc/app/numeric/controls.spec.ts +5 -21
  355. package/demos/pc/app/numeric/dynamic-disabled.spec.ts +1 -1
  356. package/demos/pc/app/numeric/max-min.spec.ts +3 -3
  357. package/demos/pc/app/numeric/mouse-wheel.spec.ts +1 -1
  358. package/demos/pc/app/numeric/numeric-size.spec.ts +3 -3
  359. package/demos/pc/app/numeric/unit.spec.ts +3 -5
  360. package/demos/pc/app/pager/webdoc/pager.js +2 -2
  361. package/demos/pc/app/pop-upload/basic-usage-composition-api.vue +4 -1
  362. package/demos/pc/app/pop-upload/basic-usage.spec.ts +25 -14
  363. package/demos/pc/app/pop-upload/basic-usage.vue +5 -2
  364. package/demos/pc/app/pop-upload/before-upload.spec.ts +6 -4
  365. package/demos/pc/app/pop-upload/custom-request-headers-composition-api.vue +1 -1
  366. package/demos/pc/app/pop-upload/custom-request-headers.spec.ts +2 -2
  367. package/demos/pc/app/pop-upload/custom-request-headers.vue +1 -1
  368. package/demos/pc/app/pop-upload/file-limit-composition-api.vue +1 -1
  369. package/demos/pc/app/pop-upload/file-limit.spec.ts +9 -11
  370. package/demos/pc/app/pop-upload/file-limit.vue +1 -1
  371. package/demos/pc/app/pop-upload/file-type-composition-api.vue +6 -1
  372. package/demos/pc/app/pop-upload/file-type.spec.ts +6 -3
  373. package/demos/pc/app/pop-upload/file-type.vue +6 -1
  374. package/demos/pc/app/pop-upload/fill-button-text.spec.ts +16 -36
  375. package/demos/pc/app/pop-upload/http-request.spec.ts +3 -5
  376. package/demos/pc/app/pop-upload/prevent-delete-file.spec.ts +2 -2
  377. package/demos/pc/app/pop-upload/size.spec.ts +1 -1
  378. package/demos/pc/app/pop-upload/upload-events-composition-api.vue +39 -0
  379. package/demos/pc/app/pop-upload/upload-events.spec.ts +39 -0
  380. package/demos/pc/app/pop-upload/upload-events.vue +44 -0
  381. package/demos/pc/app/pop-upload/webdoc/pop-upload.cn.md +1 -1
  382. package/demos/pc/app/pop-upload/webdoc/pop-upload.en.md +3 -3
  383. package/demos/pc/app/pop-upload/webdoc/pop-upload.js +192 -153
  384. package/demos/pc/app/popover/basic-usage-composition-api.vue +1 -1
  385. package/demos/pc/app/popover/basic-usage.spec.js +4 -1
  386. package/demos/pc/app/popover/basic-usage.vue +1 -1
  387. package/demos/pc/app/popover/content.spec.js +7 -3
  388. package/demos/pc/app/popover/custom-popper.spec.js +25 -4
  389. package/demos/pc/app/popover/disabled-composition-api.vue +2 -1
  390. package/demos/pc/app/popover/events-composition-api.vue +2 -2
  391. package/demos/pc/app/popover/events.spec.js +4 -0
  392. package/demos/pc/app/popover/offset-composition-api.vue +6 -6
  393. package/demos/pc/app/popover/offset.spec.js +31 -3
  394. package/demos/pc/app/popover/offset.vue +6 -6
  395. package/demos/pc/app/popover/trigger.spec.js +3 -3
  396. package/demos/pc/app/popover/webdoc/popover.js +11 -3
  397. package/demos/pc/app/qr-code/basic-usage.spec.ts +9 -0
  398. package/demos/pc/app/qr-code/icon.spec.ts +11 -0
  399. package/demos/pc/app/qr-code/level.spec.ts +15 -0
  400. package/demos/pc/app/qr-code/style.spec.ts +9 -0
  401. package/demos/pc/app/qr-code/webdoc/qr-code.js +13 -11
  402. package/demos/pc/app/rich-text-editor/webdoc/rich-text-editor.js +1 -1
  403. package/demos/pc/app/roles/webdoc/roles.js +1 -1
  404. package/demos/pc/app/scroll-text/basic-usage-composition-api.vue +1 -1
  405. package/demos/pc/app/scroll-text/basic-usage.spec.ts +1 -1
  406. package/demos/pc/app/scroll-text/basic-usage.vue +1 -1
  407. package/demos/pc/app/scroll-text/custom-text-style-composition-api.vue +1 -1
  408. package/demos/pc/app/scroll-text/custom-text-style.vue +1 -1
  409. package/demos/pc/app/scroll-text/hover-stop-composition-api.vue +1 -1
  410. package/demos/pc/app/scroll-text/hover-stop.spec.ts +1 -1
  411. package/demos/pc/app/scroll-text/hover-stop.vue +1 -1
  412. package/demos/pc/app/scroll-text/scroll-direction-composition-api.vue +1 -1
  413. package/demos/pc/app/scroll-text/scroll-direction.spec.ts +4 -4
  414. package/demos/pc/app/scroll-text/scroll-direction.vue +1 -1
  415. package/demos/pc/app/scroll-text/scroll-time-composition-api.vue +1 -1
  416. package/demos/pc/app/scroll-text/scroll-time.spec.ts +1 -1
  417. package/demos/pc/app/scroll-text/scroll-time.vue +1 -1
  418. package/demos/pc/app/scroll-text/slots-composition-api.vue +1 -1
  419. package/demos/pc/app/scroll-text/slots.vue +1 -1
  420. package/demos/pc/app/scroll-text/webdoc/scroll-text.js +27 -33
  421. package/demos/pc/app/select/clear-no-match-value-composition-api.vue +6 -2
  422. package/demos/pc/app/select/clear-no-match-value.spec.ts +22 -0
  423. package/demos/pc/app/select/clear-no-match-value.vue +6 -2
  424. package/demos/pc/app/select/copy-multi-composition-api.vue +3 -3
  425. package/demos/pc/app/select/copy-multi.spec.ts +3 -1
  426. package/demos/pc/app/select/copy-single-composition-api.vue +3 -3
  427. package/demos/pc/app/select/copy-single.spec.ts +16 -17
  428. package/demos/pc/app/select/copy-single.vue +1 -1
  429. package/demos/pc/app/select/events-composition-api.vue +1 -1
  430. package/demos/pc/app/select/filter-method-composition-api.vue +9 -2
  431. package/demos/pc/app/select/filter-method.spec.ts +3 -3
  432. package/demos/pc/app/select/is-drop-inherit-width.spec.ts +3 -4
  433. package/demos/pc/app/select/manual-focus-blur-composition-api.vue +1 -1
  434. package/demos/pc/app/select/manual-focus-blur.spec.ts +5 -4
  435. package/demos/pc/app/select/nest-grid-composition-api.vue +3 -3
  436. package/demos/pc/app/select/nest-tree-composition-api.vue +32 -2
  437. package/demos/pc/app/select/optimization.spec.ts +7 -8
  438. package/demos/pc/app/select/tag-type.spec.ts +12 -0
  439. package/demos/pc/app/select/webdoc/select.cn.md +1 -1
  440. package/demos/pc/app/select/webdoc/select.en.md +1 -1
  441. package/demos/pc/app/select/webdoc/select.js +19 -19
  442. package/demos/pc/app/slide-bar/basic-usage.spec.ts +3 -3
  443. package/demos/pc/app/slide-bar/custom-content.spec.ts +1 -2
  444. package/demos/pc/app/slide-bar/custom-tag.spec.ts +1 -2
  445. package/demos/pc/app/slide-bar/slide-bar-events.spec.ts +1 -2
  446. package/demos/pc/app/slide-bar/wheel-blocks.spec.ts +7 -8
  447. package/demos/pc/app/split/webdoc/split.js +1 -1
  448. package/demos/pc/app/steps/size.spec.ts +2 -1
  449. package/demos/pc/app/steps/slot-item.spec.ts +8 -2
  450. package/demos/pc/app/steps/slot-item.vue +4 -4
  451. package/demos/pc/app/steps/text-position.spec.ts +2 -1
  452. package/demos/pc/app/tabs/basic-usage-composition-api.vue +1 -1
  453. package/demos/pc/app/tabs/basic-usage.spec.ts +6 -0
  454. package/demos/pc/app/tabs/basic-usage.vue +1 -1
  455. package/demos/pc/app/tabs/tabs-events-close-composition-api.vue +9 -2
  456. package/demos/pc/app/tabs/tabs-events-close.vue +9 -2
  457. package/demos/pc/app/tabs/webdoc/tabs.js +79 -4
  458. package/demos/pc/app/text-popup/basic-usage.spec.ts +1 -1
  459. package/demos/pc/app/text-popup/clear-value.spec.ts +1 -1
  460. package/demos/pc/app/text-popup/placeholder.spec.ts +1 -1
  461. package/demos/pc/app/text-popup/readonly.spec.ts +1 -1
  462. package/demos/pc/app/text-popup/separtor.spec.ts +1 -1
  463. package/demos/pc/app/text-popup/value.spec.ts +1 -1
  464. package/demos/pc/app/text-popup/webdoc/text-popup.js +11 -11
  465. package/demos/pc/app/text-popup/width.spec.ts +1 -1
  466. package/demos/pc/app/time-line/basic-usage.spec.ts +1 -1
  467. package/demos/pc/app/time-line/custom-field.spec.ts +3 -3
  468. package/demos/pc/app/time-line/custom-horizontal-timeline.spec.ts +3 -3
  469. package/demos/pc/app/time-line/custom-vertical-timeline.spec.ts +6 -6
  470. package/demos/pc/app/time-line/set-node-width.spec.ts +6 -8
  471. package/demos/pc/app/time-line/set-start-value.spec.ts +4 -4
  472. package/demos/pc/app/time-line/shape.spec.ts +3 -3
  473. package/demos/pc/app/time-line/status.spec.ts +1 -1
  474. package/demos/pc/app/time-line/timeline-item.spec.ts +1 -1
  475. package/demos/pc/app/time-line/vertical-timeline.spec.ts +9 -5
  476. package/demos/pc/app/time-line/webdoc/time-line.js +2 -2
  477. package/demos/pc/app/time-picker/basic-usage.spec.ts +12 -33
  478. package/demos/pc/app/time-picker/clearable.spec.ts +23 -8
  479. package/demos/pc/app/time-picker/default-value.spec.ts +24 -9
  480. package/demos/pc/app/time-picker/disabled.spec.ts +10 -4
  481. package/demos/pc/app/time-picker/editable.spec.ts +3 -4
  482. package/demos/pc/app/time-picker/event-composition-api.vue +1 -1
  483. package/demos/pc/app/time-picker/event.spec.ts +6 -6
  484. package/demos/pc/app/time-picker/event.vue +1 -1
  485. package/demos/pc/app/time-picker/format.spec.ts +32 -16
  486. package/demos/pc/app/time-picker/is-range.spec.ts +8 -32
  487. package/demos/pc/app/time-picker/name.spec.ts +1 -3
  488. package/demos/pc/app/time-picker/placeholder.spec.ts +4 -0
  489. package/demos/pc/app/time-picker/popper-class.spec.ts +4 -4
  490. package/demos/pc/app/time-picker/size.spec.ts +22 -3
  491. package/demos/pc/app/time-picker/step.spec.ts +5 -0
  492. package/demos/pc/app/time-picker/suffix-icon.spec.ts +2 -8
  493. package/demos/pc/app/time-picker/webdoc/time-picker.js +52 -31
  494. package/demos/pc/app/time-select/webdoc/time-select.js +1 -1
  495. package/demos/pc/app/toggle-menu/automatic-filtering.spec.ts +4 -13
  496. package/demos/pc/app/toggle-menu/basic-usage.spec.ts +9 -40
  497. package/demos/pc/app/toggle-menu/custom-icon.spec.ts +2 -3
  498. package/demos/pc/app/toggle-menu/default-expand-all.spec.ts +5 -7
  499. package/demos/pc/app/toggle-menu/drag-events.spec.ts +9 -21
  500. package/demos/pc/app/toggle-menu/draggable.spec.ts +17 -13
  501. package/demos/pc/app/toggle-menu/node-click.spec.ts +2 -3
  502. package/demos/pc/app/toggle-menu/node-collapse.spec.ts +2 -3
  503. package/demos/pc/app/toggle-menu/node-drop.spec.ts +3 -4
  504. package/demos/pc/app/toggle-menu/node-expand.spec.ts +2 -3
  505. package/demos/pc/app/toggle-menu/show-filter.spec.ts +1 -2
  506. package/demos/pc/app/toggle-menu/slot-node.spec.ts +2 -3
  507. package/demos/pc/app/toggle-menu/toggle-props.spec.ts +2 -9
  508. package/demos/pc/app/tooltip/basic-usage.spec.js +6 -4
  509. package/demos/pc/app/tooltip/content.spec.js +16 -2
  510. package/demos/pc/app/tooltip/control.spec.js +19 -1
  511. package/demos/pc/app/tooltip/custom-popper.spec.js +30 -1
  512. package/demos/pc/app/tooltip/delay.spec.js +23 -1
  513. package/demos/pc/app/tooltip/offset.spec.js +23 -0
  514. package/demos/pc/app/tooltip/popper-options.spec.js +4 -1
  515. package/demos/pc/app/tooltip/theme.spec.js +1 -2
  516. package/demos/pc/app/tooltip/transition.spec.js +1 -0
  517. package/demos/pc/app/transfer/basic-usage.spec.ts +43 -48
  518. package/demos/pc/app/transfer/before-transfer.spec.ts +28 -0
  519. package/demos/pc/app/transfer/custom-btns.spec.ts +1 -1
  520. package/demos/pc/app/transfer/custom-filter-composition-api.vue +17 -8
  521. package/demos/pc/app/transfer/custom-filter.vue +18 -9
  522. package/demos/pc/app/transfer/custom-render-composition-api.vue +1 -1
  523. package/demos/pc/app/transfer/custom-render.spec.ts +2 -1
  524. package/demos/pc/app/transfer/custom-render.vue +1 -1
  525. package/demos/pc/app/transfer/custom-titles.spec.ts +7 -0
  526. package/demos/pc/app/transfer/drop-config.spec.ts +1 -1
  527. package/demos/pc/app/transfer/nested-table.spec.ts +1 -1
  528. package/demos/pc/app/transfer/webdoc/transfer.js +8 -15
  529. package/demos/pc/app/tree/filter-view-composition-api.vue +4 -2
  530. package/demos/pc/app/tree/filter-view.vue +2 -1
  531. package/demos/pc/app/tree/icons-composition-api.vue +4 -4
  532. package/demos/pc/app/tree/icons.vue +4 -4
  533. package/demos/pc/app/tree/lazy-composition-api.vue +5 -3
  534. package/demos/pc/app/tree/lazy.vue +5 -2
  535. package/demos/pc/app/tree/radio-composition-api.vue +7 -5
  536. package/demos/pc/app/tree/radio.vue +3 -3
  537. package/demos/pc/app/tree/webdoc/tree.js +13 -13
  538. package/demos/pc/app/user/webdoc/user.js +1 -1
  539. package/demos/pc/app/user-account/webdoc/user-account.js +1 -1
  540. package/demos/pc/app/user-contact/data-source.spec.ts +2 -5
  541. package/demos/pc/app/user-link/webdoc/user-link.js +1 -1
  542. package/demos/pc/app/watermark/basic-usage.spec.ts +9 -0
  543. package/demos/pc/app/watermark/image.spec.ts +9 -0
  544. package/demos/pc/app/watermark/webdoc/watermark.js +11 -11
  545. package/demos/pc/menus.js +9 -1
  546. package/demos/pc/webdoc/installation-en.md +6 -1
  547. package/demos/pc/webdoc/installation.md +4 -0
  548. package/package.json +6 -6
  549. package/playground.html +1 -1
  550. package/src/views/components/components.vue +2 -2
  551. package/demos/mobile/app/input/autofocus.vue +0 -37
  552. package/demos/mobile/app/input/autosize.vue +0 -41
  553. package/demos/mobile/app/input/blur-focus.vue +0 -40
  554. package/demos/mobile/app/input/cols-rows.vue +0 -28
  555. package/demos/mobile/app/input/form.vue +0 -45
  556. package/demos/mobile/app/input/input-event.vue +0 -39
  557. package/demos/mobile/app/input/method-select.vue +0 -36
  558. package/demos/mobile/app/input/prefix-suffix.vue +0 -39
  559. package/demos/mobile/app/input/props-step.vue +0 -28
  560. package/demos/mobile/app/input/props.vue +0 -28
  561. package/demos/mobile/app/input/slot-content.vue +0 -30
  562. package/demos/mobile/app/input/slots-append-prepend.vue +0 -34
  563. package/demos/mobile/app/input/suffix-icon.vue +0 -30
  564. package/demos/mobile/app/input/type-be-form-tips.vue +0 -55
  565. package/demos/mobile/app/input/type-be-form.vue +0 -47
  566. package/demos/pc/app/file-upload/accept-file-composition-api.vue +0 -14
  567. package/demos/pc/app/file-upload/accept-file.vue +0 -23
  568. package/demos/pc/app/file-upload/dynamic-disable-composition-api.vue +0 -20
  569. package/demos/pc/app/file-upload/dynamic-disable.vue +0 -29
  570. package/demos/pc/app/file-upload/jalor-request-composition-api.vue +0 -21
  571. package/demos/pc/app/file-upload/jalor-request.vue +0 -31
  572. package/demos/pc/app/file-upload/upload-file-filters-composition-api.vue +0 -34
  573. package/demos/pc/app/file-upload/upload-file-filters.vue +0 -43
  574. package/demos/pc/app/filter-panel/clearable-composition-api.vue +0 -33
  575. package/demos/pc/app/filter-panel/clearable.spec.ts +0 -18
  576. package/demos/pc/app/filter-panel/clearable.vue +0 -42
  577. package/demos/pc/app/filter-panel/disabled-composition-api.vue +0 -28
  578. package/demos/pc/app/filter-panel/disabled.spec.ts +0 -12
  579. package/demos/pc/app/filter-panel/disabled.vue +0 -37
  580. package/demos/pc/app/grid/validation/valid-config-composition-api.vue +0 -141
  581. package/demos/pc/app/grid/validation/valid-config.vue +0 -150
  582. package/demos/pc/app/pop-upload/data-composition-api.vue +0 -13
  583. package/demos/pc/app/pop-upload/data.spec.ts +0 -24
  584. package/demos/pc/app/pop-upload/data.vue +0 -21
  585. package/demos/pc/app/pop-upload/max-upload-file-size-composition-api.vue +0 -10
  586. package/demos/pc/app/pop-upload/max-upload-file-size.spec.ts +0 -24
  587. package/demos/pc/app/pop-upload/max-upload-file-size.vue +0 -18
  588. package/demos/pc/app/pop-upload/upload-name-composition-api.vue +0 -10
  589. package/demos/pc/app/pop-upload/upload-name.spec.ts +0 -46
  590. package/demos/pc/app/pop-upload/upload-name.vue +0 -18
  591. package/demos/pc/app/popover/dynamic-reference-composition-api.vue +0 -36
  592. package/demos/pc/app/popover/dynamic-reference.spec.js +0 -16
  593. package/demos/pc/app/popover/dynamic-reference.vue +0 -45
  594. package/demos/pc/app/scroll-text/custom-scroll-text-composition-api.vue +0 -7
  595. package/demos/pc/app/scroll-text/custom-scroll-text.spec.ts +0 -7
  596. package/demos/pc/app/scroll-text/custom-scroll-text.vue +0 -13
  597. package/demos/pc/app/tabs/custom-tab-content-composition-api.vue +0 -17
  598. package/demos/pc/app/tabs/custom-tab-content.vue +0 -26
  599. package/demos/pc/app/tabs/prevent-tab-switching-composition-api.vue +0 -25
  600. package/demos/pc/app/tabs/prevent-tab-switching.vue +0 -33
  601. package/demos/pc/app/tabs/show-echarts-composition-api.vue +0 -46
  602. package/demos/pc/app/tabs/show-echarts.vue +0 -52
  603. package/demos/pc/app/tabs/tabs-size-composition-api.vue +0 -17
  604. package/demos/pc/app/tabs/tabs-size.vue +0 -26
  605. package/demos/pc/app/transfer/manual-clear-query-composition-api.vue +0 -34
  606. package/demos/pc/app/transfer/manual-clear-query.spec.ts +0 -12
  607. package/demos/pc/app/transfer/manual-clear-query.vue +0 -43
  608. package/demos/pc/app/wizard/status-icon-composition-api.vue +0 -33
  609. package/demos/pc/app/wizard/status-icon.vue +0 -41
  610. /package/demos/pc/app/pager/{page-append-to-body-composition-api.vue → popper-append-to-body-composition-api.vue} +0 -0
  611. /package/demos/pc/app/pager/{page-append-to-body.spec.ts → popper-append-to-body.spec.ts} +0 -0
  612. /package/demos/pc/app/pager/{page-append-to-body.vue → popper-append-to-body.vue} +0 -0
@@ -6,11 +6,18 @@ test('特定表单项校验', async ({ page }) => {
6
6
 
7
7
  const demo = page.locator('#form-validate-field')
8
8
  const getTooltipByText = (text: string) => page.locator('.tiny-tooltip').getByText(text)
9
+ const validBtn = demo.getByRole('button', { name: '校验' }).first()
9
10
 
10
- await demo.getByRole('button', { name: '校验特定字段' }).click()
11
+ await validBtn.click()
11
12
  await expect(getTooltipByText('不符合规则的日期格式')).toBeVisible()
12
13
  await expect(getTooltipByText('必填')).toBeVisible()
13
- await demo.getByRole('button', { name: '移除特定字段校验' }).click()
14
+ await demo.getByRole('button', { name: '移除校验' }).click()
14
15
  await expect(getTooltipByText('不符合规则的日期格式')).not.toBeVisible()
15
16
  await expect(getTooltipByText('必填')).not.toBeVisible()
17
+ await validBtn.click()
18
+ await expect(getTooltipByText('不符合规则的日期格式')).toBeVisible()
19
+ await expect(getTooltipByText('必填')).toBeVisible()
20
+ await demo.getByRole('button', { name: '重置日期' }).click()
21
+ await expect(getTooltipByText('不符合规则的日期格式')).not.toBeVisible()
22
+ await expect(getTooltipByText('必填')).toBeVisible()
16
23
  })
@@ -1,25 +1,19 @@
1
1
  <template>
2
2
  <div class="demo-form">
3
- <tiny-form
4
- ref="ruleFormRef"
5
- hide-required-asterisk
6
- :model="createData"
7
- :rules="rules"
8
- label-width="100px"
9
- show-message
10
- >
11
- <tiny-form-item label="姓名" prop="users" required>
3
+ <tiny-form ref="ruleFormRef" :model="createData" :rules="rules">
4
+ <tiny-form-item label="姓名" prop="users">
12
5
  <tiny-input v-model="createData.users"></tiny-input>
13
6
  </tiny-form-item>
14
- <tiny-form-item label="日期" prop="datepicker">
7
+ <tiny-form-item label="日期" prop="datepicker" ref="dateRef">
15
8
  <tiny-date-picker v-model="createData.datepicker"></tiny-date-picker>
16
9
  </tiny-form-item>
17
10
  <tiny-form-item label="URL" prop="url">
18
11
  <tiny-input v-model="createData.url"></tiny-input>
19
12
  </tiny-form-item>
20
13
  <tiny-form-item>
21
- <tiny-button type="primary" @click="validateField"> 校验特定字段 </tiny-button>
22
- <tiny-button type="primary" @click="clearValidate"> 移除特定字段校验 </tiny-button>
14
+ <tiny-button type="primary" @click="validateField"> 校验 </tiny-button>
15
+ <tiny-button type="primary" @click="clearValidate"> 移除校验 </tiny-button>
16
+ <tiny-button type="primary" @click="resetField"> 重置日期 </tiny-button>
23
17
  </tiny-form-item>
24
18
  </tiny-form>
25
19
  </div>
@@ -69,6 +63,9 @@ export default {
69
63
  },
70
64
  clearValidate() {
71
65
  this.$refs.ruleFormRef.clearValidate(['url', 'datepicker'])
66
+ },
67
+ resetField() {
68
+ this.$refs.dateRef.resetField()
72
69
  }
73
70
  }
74
71
  }
@@ -29,7 +29,8 @@
29
29
  <tiny-button type="primary" @click="validType === 'callback' ? handleSubmit() : handleSubmitPromise()">
30
30
  提交
31
31
  </tiny-button>
32
- <tiny-button type="success" @click="clearFormValid"> 移除校验 </tiny-button>
32
+ <tiny-button type="primary" @click="clearFormValid"> 移除校验 </tiny-button>
33
+ <tiny-button type="primary" @click="resetForm"> 重置表单 </tiny-button>
33
34
  </tiny-form-item>
34
35
  </tiny-form>
35
36
  </div>
@@ -132,6 +133,10 @@ function handleSubmitPromise() {
132
133
  function clearFormValid() {
133
134
  ruleFormRef.value.clearValidate()
134
135
  }
136
+
137
+ function resetForm() {
138
+ ruleFormRef.value.resetFields()
139
+ }
135
140
  </script>
136
141
 
137
142
  <style scoped>
@@ -29,7 +29,8 @@
29
29
  <tiny-button type="primary" @click="validType === 'callback' ? handleSubmit() : handleSubmitPromise()">
30
30
  提交
31
31
  </tiny-button>
32
- <tiny-button type="success" @click="clearFormValid"> 移除校验 </tiny-button>
32
+ <tiny-button type="primary" @click="clearFormValid"> 移除校验 </tiny-button>
33
+ <tiny-button type="primary" @click="resetForm"> 重置表单 </tiny-button>
33
34
  </tiny-form-item>
34
35
  </tiny-form>
35
36
  </div>
@@ -140,6 +141,9 @@ export default {
140
141
  },
141
142
  clearFormValid() {
142
143
  this.$refs.ruleFormRef.clearValidate()
144
+ },
145
+ resetForm() {
146
+ this.$refs.ruleFormRef.resetFields()
143
147
  }
144
148
  }
145
149
  }
@@ -3,7 +3,7 @@
3
3
  <div class="title">
4
4
  标签位置: <tiny-button-group :data="labelPositionList" v-model="labelPositionValue"></tiny-button-group>
5
5
  </div>
6
- <tiny-form ref="ruleFormRef" :model="createData" :label-position="labelPositionValue">
6
+ <tiny-form ref="ruleFormRef" :model="createData" :label-position="labelPositionValue" label-width="60px">
7
7
  <tiny-form-item label="用户名" prop="username">
8
8
  <tiny-input v-model="createData.username"></tiny-input>
9
9
  </tiny-form-item>
@@ -3,7 +3,7 @@
3
3
  <div class="title">
4
4
  标签位置: <tiny-button-group :data="labelPositionList" v-model="labelPositionValue"></tiny-button-group>
5
5
  </div>
6
- <tiny-form ref="ruleFormRef" :model="createData" :label-position="labelPositionValue">
6
+ <tiny-form ref="ruleFormRef" :model="createData" :label-position="labelPositionValue" label-width="60px">
7
7
  <tiny-form-item label="用户名" prop="username">
8
8
  <tiny-input v-model="createData.username"></tiny-input>
9
9
  </tiny-form-item>
@@ -60,9 +60,10 @@ export default {
60
60
  demoId: 'form-validation',
61
61
  name: { 'zh-CN': '表单校验、移除校验', 'en-US': 'Form Validation/Clear Validation' },
62
62
  desc: {
63
- 'zh-CN': `<p>通过 <code>rules</code> 设置校验规则, <code>rules</code> 的详情见 <a href="#IFormRules">IFormRules</a>
64
- <br />
65
- 调用 <code>clearValidate</code> 方法移除表单项的校验结果。传入待移除的表单项的 <code>prop</code> 属性或者 <code>prop</code> 组成的数组,如不传则移除整个表单的校验结果。</p>`,
63
+ 'zh-CN': `<p>通过 <code>rules</code> 设置校验规则,
64
+ 调用 <code>clearValidate</code> 方法移除表单项的校验结果。传入待移除的表单项的 <code>prop</code> 属性或者 <code>prop</code> 组成的数组,如不传则移除整个表单的校验结果,
65
+ 调用 <code>resetFields</code> 方法重置表单并移除校验结果。
66
+ </p>`,
66
67
  'en-US': `<p>Includes common verification rules such as mandatory fields, date, time, URL, and email. Use <code>trigger</code> to configure the mode of triggering the validation rule. If <code>change</code> is used, the validation is triggered when the value in the text box changes. If <code>blur</code> is used, the validation is triggered after the focus is lost.
67
68
  <br />
68
69
  Use <code>clearValidate</code> method to clear the validation result.
@@ -76,7 +77,7 @@ export default {
76
77
  'name': { 'zh-CN': '特定表单项校验', 'en-US': 'Form field Validation' },
77
78
  'desc': {
78
79
  'zh-CN':
79
- '<p>通过 <code>validateField</code> 方法对特定表单项进行校验, <code>clearValidate</code> 方法移除特定表单项校验。</p>',
80
+ '<p>通过 <code>validateField</code> 方法对特定表单项进行校验, <code>clearValidate</code> 方法移除特定表单项校验, <code>resetField</code> 重置表单项并移除校验。</p>',
80
81
  'en-US':
81
82
  '<p>Verify specific form items using the <code>validateField</code> method, and remove specific form item validation using the <code>clearValidate</code> method.</p>'
82
83
  },
@@ -221,6 +222,15 @@ export default {
221
222
  'Set the <code>tip</code> type error prompt through <code>popper-options</code>. For example, when the parent element of the form is a scrolling element and the page scrolls, the prompt will be misaligned. Change the <code>bubbling</code> attribute Set to <code>true</code> to resolve this issue.'
222
223
  },
223
224
  codeFiles: ['popper-options.vue']
225
+ },
226
+ {
227
+ demoId: 'events',
228
+ name: { 'zh-CN': '表单事件', 'en-US': 'Form events' },
229
+ desc: {
230
+ 'zh-CN': '<p>任一表单项被校验后触发 <code>validate</code>事件</p>',
231
+ 'en-US': 'The <code>validate</code> event is triggered after any form item is verified.'
232
+ },
233
+ codeFiles: ['events.vue']
224
234
  }
225
235
  ],
226
236
  apis: [
@@ -498,7 +508,7 @@ export default {
498
508
  'zh-CN': '任一表单项被校验后触发',
499
509
  'en-US': 'Triggered after any form item is verified'
500
510
  },
501
- demoId: 'form-validation'
511
+ demoId: 'events'
502
512
  }
503
513
  ]
504
514
  },
@@ -599,7 +609,7 @@ export default {
599
609
  'zh-CN': '是否显示校验错误信息',
600
610
  'en-US': 'Whether to display verification error information'
601
611
  },
602
- demoId: 'form-validation'
612
+ demoId: 'novalid-tip'
603
613
  },
604
614
  {
605
615
  name: 'size',
@@ -641,7 +651,7 @@ export default {
641
651
  'zh-CN': '指定校验提示框显示的位置',
642
652
  'en-US': 'Specify the position where the verification dialog box is displayed'
643
653
  },
644
- demoId: 'form-validation'
654
+ demoId: 'validation-position'
645
655
  },
646
656
  {
647
657
  name: 'validate-type',
@@ -695,7 +705,7 @@ export default {
695
705
  'zh-CN': '对该表单项进行重置,将其值重置为初始值并移除校验结果',
696
706
  'en-US': 'Reset the table item to the initial value and remove the verification result.'
697
707
  },
698
- demoId: 'form-validation'
708
+ demoId: 'form-validate-field'
699
709
  }
700
710
  ],
701
711
  'events': []
@@ -1,52 +1,37 @@
1
1
  import { test, expect } from '@playwright/test'
2
2
 
3
- test('Fullscreen 函数式使用', async ({ page }) => {
3
+ test('函数式使用', async ({ page }) => {
4
4
  page.on('pageerror', (exception) => expect(exception).toBeNull())
5
5
  await page.goto('fullscreen#example-api')
6
6
 
7
- const pageOnly = page.getByLabel('pageOnly')
8
- const teleport = page.getByLabel('teleport')
9
7
  const fullBtn = page.getByRole('button', { name: 'Request Fullscreen' })
10
8
  const exitFullBtn = page.getByRole('button', { name: 'Exit Fullscreen' })
11
- const smallImg = page.locator('img').first()
12
- const bigImg = page.locator('img').last()
9
+ const smallImg = page.locator('.tiny-fullscreen-wrapper img').nth(0)
10
+ const bigImg = page.locator('.tiny-fullscreen-wrapper img').nth(1)
13
11
 
14
12
  // 初始化完成,默认非全屏模式
15
13
  await expect(fullBtn).toBeVisible()
16
14
  await expect(exitFullBtn).toHaveCount(0)
17
15
  await expect(smallImg).not.toHaveCSS('display', 'none')
18
16
  await expect(bigImg).toHaveCSS('display', 'none')
19
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
17
+ const document1 = await page.evaluate('document.fullscreenElement')
18
+ await expect(document1).toBe(null)
20
19
 
21
20
  // 点击Request Fullscreen按钮,图片全屏展示
22
21
  await fullBtn.click()
23
- await expect(smallImg).toHaveCSS('display', 'none')
24
- await expect(bigImg).not.toHaveCSS('display', 'none')
25
- expect(await page.evaluate('document.fullscreenElement')).toBe('ref: <Node>')
26
-
27
- // 点击Exit Fullscreen按钮,退出全屏展示
28
- await exitFullBtn.click()
29
22
  await expect(smallImg).not.toHaveCSS('display', 'none')
30
23
  await expect(bigImg).toHaveCSS('display', 'none')
31
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
32
24
 
33
- // pageOnly为true时,为网页全屏
34
- await pageOnly.check()
35
- await fullBtn.click()
36
- await expect(smallImg).toHaveCSS('display', 'none')
37
- await expect(bigImg).not.toHaveCSS('display', 'none')
38
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
25
+ // 选取需要添加样式的元素并设置新的CSS属性
26
+ await page.$eval('.tinyui-design-header', (el) => {
27
+ el.setAttribute('style', 'display: none;')
28
+ })
39
29
 
40
- // pageOnly为false时,为浏览器全屏
41
- await exitFullBtn.click()
42
- await pageOnly.uncheck()
30
+ // // 点击Exit Fullscreen按钮,退出全屏展示
43
31
  await fullBtn.click()
44
- expect(await page.evaluate('document.fullscreenElement')).toBe('ref: <Node>')
32
+ await expect(smallImg).not.toHaveCSS('display', 'none')
33
+ await expect(bigImg).toHaveCSS('display', 'none')
45
34
 
46
- // teleport默认true,目标元素移到body下,反之false时不移动目标元素
47
- expect(await page.evaluate('document.fullscreenElement?.nodeName')).toBe('BODY') // 默认true时
48
- await exitFullBtn.click()
49
- await teleport.uncheck()
50
- await fullBtn.click()
51
- expect(await page.evaluate('document.fullscreenElement?.nodeName')).toBe('DIV')
35
+ // TINY-TODO: 全屏时,按Esc键退出全屏图片有问题
36
+ // TINY-TODO: 因全屏模式下获取不到元素 pageOnly teleport区别暂未测试
52
37
  })
@@ -5,58 +5,41 @@ test('组件式使用', async ({ page }) => {
5
5
  await page.goto('fullscreen#example-component')
6
6
 
7
7
  const pageOnly = page.getByLabel('pageOnly')
8
- const teleport = page.getByLabel('teleport')
9
8
  const fullBtn = page.getByRole('button', { name: 'Request Fullscreen' })
10
9
  const exitFullBtn = page.getByRole('button', { name: 'Exit Fullscreen' })
11
- const smallImg = page.locator('img').first()
12
- const bigImg = page.locator('img').last()
10
+ const smallImg = page.locator('.tiny-fullscreen-wrapper img').nth(0)
11
+ const bigImg = page.locator('.tiny-fullscreen-wrapper img').nth(1)
13
12
 
14
13
  // 初始化完成,默认非全屏模式
15
14
  await expect(fullBtn).toBeVisible()
16
15
  await expect(exitFullBtn).toHaveCount(0)
17
16
  await expect(smallImg).not.toHaveCSS('display', 'none')
18
17
  await expect(bigImg).toHaveCSS('display', 'none')
19
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
18
+ const document1 = await page.evaluate('document.fullscreenElement')
19
+ await expect(document1).toBe(null)
20
20
 
21
21
  // 点击Request Fullscreen按钮,图片全屏展示
22
22
  await fullBtn.click()
23
23
  await expect(smallImg).toHaveCSS('display', 'none')
24
24
  await expect(bigImg).not.toHaveCSS('display', 'none')
25
- expect(await page.evaluate('document.fullscreenElement')).toBe('ref: <Node>')
26
25
 
27
- // 点击Exit Fullscreen按钮,退出全屏展示
26
+ // 选取需要添加样式的元素并设置新的CSS属性
27
+ await page.$eval('.tinyui-design-header', (el) => {
28
+ el.setAttribute('style', 'display: none;')
29
+ })
30
+
31
+ // // 点击Exit Fullscreen按钮,退出全屏展示
28
32
  await exitFullBtn.click()
29
33
  await expect(smallImg).not.toHaveCSS('display', 'none')
30
34
  await expect(bigImg).toHaveCSS('display', 'none')
31
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
32
35
 
33
- // 全屏时,按Esc键退出全屏
34
- await fullBtn.click()
35
- await expect(smallImg).toHaveCSS('display', 'none')
36
- await expect(bigImg).not.toHaveCSS('display', 'none')
37
- expect(await page.evaluate('document.fullscreenElement')).toBe('ref: <Node>')
38
- await exitFullBtn.press('Escape')
39
- await expect(smallImg).not.toHaveCSS('display', 'none')
40
- await expect(bigImg).toHaveCSS('display', 'none')
41
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
36
+ // TINY-TODO: 全屏时,按Esc键退出全屏图片有问题
42
37
 
43
38
  // pageOnly为true时,为网页全屏
44
39
  await pageOnly.check()
45
40
  await fullBtn.click()
46
41
  await expect(smallImg).toHaveCSS('display', 'none')
47
42
  await expect(bigImg).not.toHaveCSS('display', 'none')
48
- expect(await page.evaluate('document.fullscreenElement')).toBe(null)
49
43
 
50
- // pageOnly为false时,为浏览器全屏
51
- await exitFullBtn.click()
52
- await pageOnly.uncheck()
53
- await fullBtn.click()
54
- expect(await page.evaluate('document.fullscreenElement')).toBe('ref: <Node>')
55
-
56
- // teleport默认true,目标元素移到body下,反之false时不移动目标元素
57
- expect(await page.evaluate('document.fullscreenElement?.nodeName')).toBe('BODY') // 默认true时
58
- await exitFullBtn.click()
59
- await teleport.uncheck()
60
- await fullBtn.click()
61
- expect(await page.evaluate('document.fullscreenElement?.nodeName')).toBe('DIV')
44
+ // TINY-TODO: 因全屏模式下获取不到元素 pageOnly teleport区别暂未测试
62
45
  })
@@ -19,7 +19,7 @@ export default {
19
19
  {
20
20
  'name': 'fullscreen',
21
21
  'type': 'component',
22
- 'properties': [
22
+ 'props': [
23
23
  {
24
24
  'name': 'page-only',
25
25
  'type': 'boolean',
@@ -60,7 +60,7 @@ export default {
60
60
  'zh-CN': '自定义组件 wrapper 的样式类名',
61
61
  'en-US': 'Style class name of the custom component wrapper'
62
62
  },
63
- 'demoId': 'example-component'
63
+ 'demoId': ''
64
64
  },
65
65
  {
66
66
  'name': 'fullscreen',
@@ -81,7 +81,7 @@ export default {
81
81
  'en-US':
82
82
  'When the component is used in component mode, click the component wrapper to determine whether to disable full-screen display. The default value is true.'
83
83
  },
84
- 'demoId': 'example-component'
84
+ 'demoId': ''
85
85
  }
86
86
  ],
87
87
  'events': [
@@ -117,7 +117,7 @@ export default {
117
117
  'zh-CN': '函数式使用时,切换全屏模式',
118
118
  'en-US': 'Switch the full-screen mode when the function mode is used.'
119
119
  },
120
- 'demoId': 'example-component'
120
+ 'demoId': 'example-api'
121
121
  }
122
122
  ]
123
123
  }
@@ -5,7 +5,7 @@
5
5
  </template>
6
6
  <tiny-grid-column field="name" title="名称"></tiny-grid-column>
7
7
  <tiny-grid-column field="employees" title="员工数"></tiny-grid-column>
8
- <tiny-grid-column field="address" title="地址"></tiny-grid-column>
8
+ <tiny-grid-column field="address" :resizable="false" title="地址"></tiny-grid-column>
9
9
  <tiny-grid-column field="introduction" title="公司简介" show-overflow></tiny-grid-column>
10
10
  </tiny-grid>
11
11
  </template>
@@ -5,7 +5,7 @@
5
5
  </template>
6
6
  <tiny-grid-column field="name" title="名称"></tiny-grid-column>
7
7
  <tiny-grid-column field="employees" title="员工数"></tiny-grid-column>
8
- <tiny-grid-column field="address" title="地址"></tiny-grid-column>
8
+ <tiny-grid-column field="address" :resizable="false" title="地址"></tiny-grid-column>
9
9
  <tiny-grid-column field="introduction" title="公司简介" show-overflow></tiny-grid-column>
10
10
  </tiny-grid>
11
11
  </template>
@@ -1,7 +1,12 @@
1
1
  <template>
2
2
  <tiny-grid :data="tableData" :resizable="true" border>
3
3
  <template #toolbar>
4
- <tiny-grid-toolbar id="custom-sort-columns" :resizable="{ storage: true }" :setting="setting"></tiny-grid-toolbar>
4
+ <tiny-grid-toolbar
5
+ id="custom-sort-columns"
6
+ @on-before-move="onBeforeMove"
7
+ :resizable="{ storage: true }"
8
+ :setting="setting"
9
+ ></tiny-grid-toolbar>
5
10
  </template>
6
11
  <tiny-grid-column type="index" width="40"></tiny-grid-column>
7
12
  <tiny-grid-column type="selection" width="40"></tiny-grid-column>
@@ -23,6 +28,11 @@ export default {
23
28
  TinyGridColumn: GridColumn,
24
29
  TinyGridToolbar: GridToolbar
25
30
  },
31
+ methods: {
32
+ onBeforeMove() {
33
+ alert(11)
34
+ }
35
+ },
26
36
  data() {
27
37
  return {
28
38
  Sortable,
@@ -1,8 +1,7 @@
1
1
  <template>
2
- <div>
2
+ <div class="footer-style">
3
3
  <h4 class="title">自定义表尾行样式:</h4>
4
4
  <tiny-grid
5
- class="grid-footer-row-style"
6
5
  :data="tableData"
7
6
  show-footer
8
7
  :footer-method="footerMethod"
@@ -18,7 +17,6 @@
18
17
  </tiny-grid>
19
18
  <h4 class="title">自定义表尾单元格样式:</h4>
20
19
  <tiny-grid
21
- class="grid-footer-cell-style"
22
20
  :data="tableData"
23
21
  show-footer
24
22
  :footer-method="footerMethod"
@@ -29,7 +27,7 @@
29
27
  <tiny-grid-column type="selection" width="60"></tiny-grid-column>
30
28
  <tiny-grid-column field="name" title="公司名称"></tiny-grid-column>
31
29
  <tiny-grid-column field="employees" title="员工数"></tiny-grid-column>
32
- <tiny-grid-column field="createdDate" title="创建日期"></tiny-grid-column>
30
+ <tiny-grid-column field="createdDate" title="创建日期" :footer-class-name="footerClassName"></tiny-grid-column>
33
31
  <tiny-grid-column field="city" title="城市"></tiny-grid-column>
34
32
  </tiny-grid>
35
33
  </div>
@@ -138,29 +136,34 @@ const footerRowClassName = ({ $rowIndex }) => {
138
136
  return 'footer__row--green'
139
137
  }
140
138
  }
139
+
140
+ const footerClassName = () => {
141
+ return 'footer__cell--red'
142
+ }
141
143
  </script>
142
144
 
143
- <style>
144
- .grid-footer-cell-style .tiny-grid-footer__column.footer__cell--blue {
145
+ <style scoped>
146
+ .title {
147
+ font-size: 16px;
148
+ padding: 15px;
149
+ font-weight: bolder;
150
+ color: #444;
151
+ }
152
+ .footer-style :deep(.tiny-grid-footer__column.footer__cell--blue) {
145
153
  background-color: #2db7f5;
146
154
  color: #fff;
147
155
  }
148
156
 
149
- .grid-footer-row-style .tiny-grid-footer__row.footer__row--red {
157
+ .footer-style :deep(.tiny-grid-footer__row.footer__row--red) {
150
158
  background-color: palevioletred;
151
159
  color: #fff;
152
160
  }
153
- .grid-footer-row-style .tiny-grid-footer__row.footer__row--green {
161
+ .footer-style :deep(.tiny-grid-footer__row.footer__row--green) {
154
162
  background-color: green;
155
163
  color: #fff;
156
164
  }
157
- </style>
158
-
159
- <style scoped>
160
- .title {
161
- font-size: 16px;
162
- padding: 15px;
163
- font-weight: bolder;
164
- color: #444;
165
+ .footer-style :deep(.footer__cell--red) {
166
+ background-color: palevioletred;
167
+ color: #fff;
165
168
  }
166
169
  </style>
@@ -4,6 +4,7 @@ test('自定义表尾行样式', async ({ page }) => {
4
4
  page.on('pageerror', (exception) => expect(exception).toBeNull())
5
5
  await page.goto('grid-custom-style#custom-style-footer-style')
6
6
  await expect(page.locator('.footer__row--red')).toHaveCSS('background-color', 'rgb(219, 112, 147)')
7
+ await expect(page.locator('.footer__cell--red').first()).toHaveCSS('background-color', 'rgb(219, 112, 147)')
7
8
  await expect(page.locator('.footer__row--green')).toHaveCSS('background-color', 'rgb(0, 128, 0)')
8
9
  await expect(page.locator('.footer__cell--blue')).toHaveCSS('background-color', 'rgb(45, 183, 245)')
9
10
  })
@@ -1,8 +1,7 @@
1
1
  <template>
2
- <div>
2
+ <div class="footer-style">
3
3
  <h4 class="title">自定义表尾行样式:</h4>
4
4
  <tiny-grid
5
- class="grid-footer-row-style"
6
5
  :data="tableData"
7
6
  show-footer
8
7
  :footer-method="footerMethod"
@@ -18,7 +17,6 @@
18
17
  </tiny-grid>
19
18
  <h4 class="title">自定义表尾单元格样式:</h4>
20
19
  <tiny-grid
21
- class="grid-footer-cell-style"
22
20
  :data="tableData"
23
21
  show-footer
24
22
  :footer-method="footerMethod"
@@ -29,7 +27,7 @@
29
27
  <tiny-grid-column type="selection" width="60"></tiny-grid-column>
30
28
  <tiny-grid-column field="name" title="公司名称"></tiny-grid-column>
31
29
  <tiny-grid-column field="employees" title="员工数"></tiny-grid-column>
32
- <tiny-grid-column field="createdDate" title="创建日期"></tiny-grid-column>
30
+ <tiny-grid-column field="createdDate" title="创建日期" :footer-class-name="footerClassName"></tiny-grid-column>
33
31
  <tiny-grid-column field="city" title="城市"></tiny-grid-column>
34
32
  </tiny-grid>
35
33
  </div>
@@ -145,32 +143,36 @@ export default {
145
143
  if ($rowIndex === 1) {
146
144
  return 'footer__row--green'
147
145
  }
146
+ },
147
+ footerClassName() {
148
+ return 'footer__cell--red'
148
149
  }
149
150
  }
150
151
  }
151
152
  </script>
152
153
 
153
- <style>
154
- .grid-footer-cell-style .tiny-grid-footer__column.footer__cell--blue {
154
+ <style scoped>
155
+ .title {
156
+ font-size: 16px;
157
+ padding: 15px;
158
+ font-weight: bolder;
159
+ color: #444;
160
+ }
161
+ .footer-style :deep(.tiny-grid-footer__column.footer__cell--blue) {
155
162
  background-color: #2db7f5;
156
163
  color: #fff;
157
164
  }
158
165
 
159
- .grid-footer-row-style .tiny-grid-footer__row.footer__row--red {
166
+ .footer-style :deep(.tiny-grid-footer__row.footer__row--red) {
160
167
  background-color: palevioletred;
161
168
  color: #fff;
162
169
  }
163
- .grid-footer-row-style .tiny-grid-footer__row.footer__row--green {
170
+ .footer-style :deep(.tiny-grid-footer__row.footer__row--green) {
164
171
  background-color: green;
165
172
  color: #fff;
166
173
  }
167
- </style>
168
-
169
- <style scoped>
170
- .title {
171
- font-size: 16px;
172
- padding: 15px;
173
- font-weight: bolder;
174
- color: #444;
174
+ .footer-style :deep(.footer__cell--red) {
175
+ background-color: palevioletred;
176
+ color: #fff;
175
177
  }
176
178
  </style>
@@ -1,7 +1,7 @@
1
1
  <template>
2
- <div>
2
+ <div class="header-style">
3
3
  <h4 class="title">自定义表头行样式:</h4>
4
- <tiny-grid class="grid-header-row-style" :data="tableData" :header-row-class-name="headerRowClassName">
4
+ <tiny-grid :data="tableData" :header-row-class-name="headerRowClassName">
5
5
  <tiny-grid-column type="index" width="60"></tiny-grid-column>
6
6
  <tiny-grid-column type="selection" width="60"></tiny-grid-column>
7
7
  <tiny-grid-column field="name" title="公司名称"></tiny-grid-column>
@@ -10,12 +10,12 @@
10
10
  <tiny-grid-column field="city" title="城市"></tiny-grid-column>
11
11
  </tiny-grid>
12
12
  <h4 class="title">自定义表头单元格样式:</h4>
13
- <tiny-grid class="grid-header-cell-style" :data="tableData" :header-cell-class-name="headerCellClassName">
13
+ <tiny-grid :data="tableData" :header-cell-class-name="headerCellClassName">
14
14
  <tiny-grid-column type="index" width="60"></tiny-grid-column>
15
15
  <tiny-grid-column type="selection" width="60"></tiny-grid-column>
16
16
  <tiny-grid-column field="name" title="公司名称"></tiny-grid-column>
17
17
  <tiny-grid-column field="employees" title="员工数"></tiny-grid-column>
18
- <tiny-grid-column field="createdDate" title="创建日期"></tiny-grid-column>
18
+ <tiny-grid-column field="createdDate" :header-class-name="headerClassName" title="创建日期"></tiny-grid-column>
19
19
  <tiny-grid-column field="city" title="城市"></tiny-grid-column>
20
20
  </tiny-grid>
21
21
  </div>
@@ -95,17 +95,11 @@ const headerCellClassName = ({ column }) => {
95
95
  return 'header__cell--blue'
96
96
  }
97
97
  }
98
- </script>
99
98
 
100
- <style>
101
- .grid-header-row-style .tiny-grid-header__row.header__row--red {
102
- background-color: palevioletred;
103
- }
104
- .grid-header-cell-style .tiny-grid-header__column.header__cell--blue {
105
- background-color: #2db7f5;
106
- color: #fff;
99
+ const headerClassName = () => {
100
+ return 'header-blue'
107
101
  }
108
- </style>
102
+ </script>
109
103
 
110
104
  <style scoped>
111
105
  .title {
@@ -114,4 +108,15 @@ const headerCellClassName = ({ column }) => {
114
108
  font-weight: bolder;
115
109
  color: #444;
116
110
  }
111
+ .header-style :deep(.tiny-grid-header__row.header__row--red) {
112
+ background-color: palevioletred;
113
+ }
114
+ .header-style :deep(.tiny-grid-header__column.header__cell--blue) {
115
+ background-color: #2db7f5;
116
+ color: #fff;
117
+ }
118
+ .header-style :deep(.header-blue) {
119
+ background-color: #2db7f5;
120
+ color: #fff;
121
+ }
117
122
  </style>
@@ -5,4 +5,5 @@ test('自定义表头样式', async ({ page }) => {
5
5
  await page.goto('grid-custom-style#custom-style-header-style')
6
6
  await expect(page.locator('.header__row--red')).toHaveCSS('background-color', 'rgb(219, 112, 147)')
7
7
  await expect(page.locator('.header__cell--blue')).toHaveCSS('background-color', 'rgb(45, 183, 245)')
8
+ await expect(page.locator('.header-blue')).toHaveCSS('background-color', 'rgb(45, 183, 245)')
8
9
  })