@opentiny/vue-docs 3.27.1 → 3.28.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 (419) hide show
  1. package/demos/apis/base-select.js +2 -2
  2. package/demos/apis/chart-attributes-demo.js +4 -4
  3. package/demos/apis/chart-demo.js +4 -4
  4. package/demos/apis/chart-docs.js +4 -4
  5. package/demos/apis/chart-events.js +4 -4
  6. package/demos/apis/chart-question.js +4 -4
  7. package/demos/apis/chart.js +4 -4
  8. package/demos/apis/color-picker.js +1 -1
  9. package/demos/apis/color-select-panel.js +1 -1
  10. package/demos/apis/drawer.js +14 -0
  11. package/demos/apis/dropdown.js +6 -2
  12. package/demos/apis/grid-select.js +20 -21
  13. package/demos/apis/grid.js +1 -1
  14. package/demos/apis/modal.js +15 -1
  15. package/demos/apis/select-wrapper.js +1067 -0
  16. package/demos/apis/select.js +25 -13
  17. package/demos/apis/switch.js +15 -0
  18. package/demos/apis/time-line.js +14 -0
  19. package/demos/apis/tree-menu.js +7 -4
  20. package/demos/apis/tree-select.js +41 -0
  21. package/demos/mobile-first/app/base-select/all-text.vue +43 -0
  22. package/demos/mobile-first/app/base-select/allow-create.vue +51 -0
  23. package/demos/mobile-first/app/base-select/automatic-dropdown.vue +60 -0
  24. package/demos/mobile-first/app/base-select/basic-usage.vue +47 -0
  25. package/demos/mobile-first/app/base-select/binding-obj.vue +44 -0
  26. package/demos/mobile-first/app/base-select/cache-usage.vue +55 -0
  27. package/demos/mobile-first/app/base-select/clear-no-match-value.vue +52 -0
  28. package/demos/mobile-first/app/base-select/clearable.vue +34 -0
  29. package/demos/mobile-first/app/base-select/collapse-tags.vue +49 -0
  30. package/demos/mobile-first/app/base-select/copy-multi.vue +55 -0
  31. package/demos/mobile-first/app/base-select/copy-single.vue +158 -0
  32. package/demos/mobile-first/app/base-select/disabled.vue +107 -0
  33. package/demos/mobile-first/app/base-select/events.vue +112 -0
  34. package/demos/mobile-first/app/base-select/filter-method.vue +83 -0
  35. package/demos/mobile-first/app/base-select/filter-mode.vue +57 -0
  36. package/demos/mobile-first/app/base-select/hide-drop.vue +34 -0
  37. package/demos/mobile-first/app/base-select/is-drop-inherit-width.vue +49 -0
  38. package/demos/mobile-first/app/base-select/manual-focus-blur.vue +90 -0
  39. package/demos/mobile-first/app/base-select/map-field.vue +42 -0
  40. package/demos/mobile-first/app/base-select/memoize-usage.vue +66 -0
  41. package/demos/mobile-first/app/base-select/multiple-mix.vue +156 -0
  42. package/demos/mobile-first/app/base-select/multiple.vue +98 -0
  43. package/demos/mobile-first/app/base-select/native-properties.vue +34 -0
  44. package/demos/mobile-first/app/base-select/no-data-text.vue +40 -0
  45. package/demos/mobile-first/app/base-select/optimization.vue +55 -0
  46. package/demos/mobile-first/app/base-select/option-group.vue +105 -0
  47. package/demos/mobile-first/app/base-select/popup-style-position.vue +40 -0
  48. package/demos/mobile-first/app/base-select/remote-method.vue +286 -0
  49. package/demos/mobile-first/app/base-select/show-alloption.vue +34 -0
  50. package/demos/mobile-first/app/base-select/show-tip.vue +34 -0
  51. package/demos/mobile-first/app/base-select/size.vue +48 -0
  52. package/demos/mobile-first/app/base-select/slot-default.vue +95 -0
  53. package/demos/mobile-first/app/base-select/slot-empty.vue +41 -0
  54. package/demos/mobile-first/app/base-select/slot-footer.vue +45 -0
  55. package/demos/mobile-first/app/base-select/slot-label.vue +85 -0
  56. package/demos/mobile-first/app/base-select/slot-panel.vue +155 -0
  57. package/demos/mobile-first/app/base-select/slot-prefix.vue +39 -0
  58. package/demos/mobile-first/app/base-select/slot-reference.vue +41 -0
  59. package/demos/mobile-first/app/base-select/tag-type.vue +36 -0
  60. package/demos/mobile-first/app/base-select/webdoc/base-select.cn.md +7 -0
  61. package/demos/mobile-first/app/base-select/webdoc/base-select.en.md +7 -0
  62. package/demos/mobile-first/app/base-select/webdoc/base-select.js +590 -0
  63. package/demos/mobile-first/app/button/webdoc/button.js +2 -2
  64. package/demos/mobile-first/app/file-upload/show-title.vue +2 -3
  65. package/demos/mobile-first/app/grid-select/basic-usage.vue +70 -0
  66. package/demos/mobile-first/app/grid-select/config.vue +88 -0
  67. package/demos/mobile-first/app/grid-select/extra-query-params.vue +126 -0
  68. package/demos/mobile-first/app/grid-select/init-query.vue +124 -0
  69. package/demos/mobile-first/app/grid-select/radio-bigdata.vue +46 -0
  70. package/demos/mobile-first/app/grid-select/remote.vue +90 -0
  71. package/demos/mobile-first/app/grid-select/webdoc/grid-select.cn.md +7 -0
  72. package/demos/mobile-first/app/grid-select/webdoc/grid-select.en.md +8 -0
  73. package/demos/mobile-first/app/grid-select/webdoc/grid-select.js +92 -0
  74. package/demos/mobile-first/app/select-wrapper/all-text.vue +43 -0
  75. package/demos/mobile-first/app/select-wrapper/allow-create.vue +77 -0
  76. package/demos/mobile-first/app/select-wrapper/automatic-dropdown.vue +62 -0
  77. package/demos/mobile-first/app/select-wrapper/basic-usage.vue +47 -0
  78. package/demos/mobile-first/app/select-wrapper/binding-obj.vue +44 -0
  79. package/demos/mobile-first/app/select-wrapper/cache-usage.vue +49 -0
  80. package/demos/mobile-first/app/select-wrapper/clear-no-match-value.vue +54 -0
  81. package/demos/mobile-first/app/select-wrapper/clearable.vue +34 -0
  82. package/demos/mobile-first/app/select-wrapper/collapse-tags.vue +58 -0
  83. package/demos/mobile-first/app/select-wrapper/copy-multi.vue +77 -0
  84. package/demos/mobile-first/app/select-wrapper/copy-single.vue +157 -0
  85. package/demos/mobile-first/app/select-wrapper/disabled.vue +108 -0
  86. package/demos/mobile-first/app/select-wrapper/events.vue +112 -0
  87. package/demos/mobile-first/app/select-wrapper/extra-query-params.vue +157 -0
  88. package/demos/mobile-first/app/select-wrapper/filter-method.vue +85 -0
  89. package/demos/mobile-first/app/select-wrapper/filter-mode.vue +46 -0
  90. package/demos/mobile-first/app/select-wrapper/hide-drop.vue +34 -0
  91. package/demos/mobile-first/app/select-wrapper/init-label.vue +74 -0
  92. package/demos/mobile-first/app/select-wrapper/is-drop-inherit-width.vue +51 -0
  93. package/demos/mobile-first/app/select-wrapper/manual-focus-blur.vue +90 -0
  94. package/demos/mobile-first/app/select-wrapper/map-field.vue +68 -0
  95. package/demos/mobile-first/app/select-wrapper/memoize-usage.vue +66 -0
  96. package/demos/mobile-first/app/select-wrapper/multiple-mix.vue +84 -0
  97. package/demos/mobile-first/app/select-wrapper/multiple.vue +133 -0
  98. package/demos/mobile-first/app/select-wrapper/native-properties.vue +34 -0
  99. package/demos/mobile-first/app/select-wrapper/nest-grid-disable.vue +122 -0
  100. package/demos/mobile-first/app/select-wrapper/nest-grid-init-query.vue +129 -0
  101. package/demos/mobile-first/app/select-wrapper/nest-grid-remote.vue +144 -0
  102. package/demos/mobile-first/app/select-wrapper/nest-grid.vue +106 -0
  103. package/demos/mobile-first/app/select-wrapper/nest-radio-grid-much-data.vue +50 -0
  104. package/demos/mobile-first/app/select-wrapper/nest-tree.vue +164 -0
  105. package/demos/mobile-first/app/select-wrapper/no-data-text.vue +48 -0
  106. package/demos/mobile-first/app/select-wrapper/optimization.vue +59 -0
  107. package/demos/mobile-first/app/select-wrapper/option-group.vue +105 -0
  108. package/demos/mobile-first/app/select-wrapper/popup-style-position.vue +40 -0
  109. package/demos/mobile-first/app/select-wrapper/remote-method.vue +286 -0
  110. package/demos/mobile-first/app/select-wrapper/show-alloption.vue +34 -0
  111. package/demos/mobile-first/app/select-wrapper/show-tip.vue +28 -0
  112. package/demos/mobile-first/app/select-wrapper/size.vue +57 -0
  113. package/demos/mobile-first/app/select-wrapper/slot-default.vue +95 -0
  114. package/demos/mobile-first/app/select-wrapper/slot-empty.vue +44 -0
  115. package/demos/mobile-first/app/select-wrapper/slot-header-footer.vue +55 -0
  116. package/demos/mobile-first/app/select-wrapper/slot-label.vue +85 -0
  117. package/demos/mobile-first/app/select-wrapper/slot-prefix.vue +39 -0
  118. package/demos/mobile-first/app/select-wrapper/slot-reference.vue +41 -0
  119. package/demos/mobile-first/app/select-wrapper/tag-type.vue +36 -0
  120. package/demos/mobile-first/app/select-wrapper/webdoc/select-wrapper.cn.md +7 -0
  121. package/demos/mobile-first/app/select-wrapper/webdoc/select-wrapper.en.md +7 -0
  122. package/demos/mobile-first/app/select-wrapper/webdoc/select-wrapper.js +695 -0
  123. package/demos/mobile-first/app/space/space-size.vue +1 -1
  124. package/demos/mobile-first/app/tree-select/basic-usage.vue +63 -0
  125. package/demos/mobile-first/app/tree-select/collapse-tags.vue +77 -0
  126. package/demos/mobile-first/app/tree-select/copy.vue +77 -0
  127. package/demos/mobile-first/app/tree-select/disabled.vue +76 -0
  128. package/demos/mobile-first/app/tree-select/lazy.vue +59 -0
  129. package/demos/mobile-first/app/tree-select/map-field.vue +63 -0
  130. package/demos/mobile-first/app/tree-select/multiple.vue +63 -0
  131. package/demos/mobile-first/app/tree-select/native-properties.vue +69 -0
  132. package/demos/mobile-first/app/tree-select/panel-style.vue +80 -0
  133. package/demos/mobile-first/app/tree-select/reference-style.vue +79 -0
  134. package/demos/mobile-first/app/tree-select/size.vue +78 -0
  135. package/demos/mobile-first/app/tree-select/webdoc/tree-select.cn.md +7 -0
  136. package/demos/mobile-first/app/tree-select/webdoc/tree-select.en.md +7 -0
  137. package/demos/mobile-first/app/tree-select/webdoc/tree-select.js +220 -0
  138. package/demos/mobile-first/menus.js +14 -0
  139. package/demos/pc/app/amount/custom-service.spec.js +4 -4
  140. package/demos/pc/app/base-select/all-text.spec.ts +2 -2
  141. package/demos/pc/app/base-select/allow-create.spec.ts +3 -3
  142. package/demos/pc/app/base-select/automatic-dropdown.spec.ts +2 -2
  143. package/demos/pc/app/base-select/basic-usage.spec.ts +4 -4
  144. package/demos/pc/app/base-select/binding-obj.spec.ts +2 -2
  145. package/demos/pc/app/base-select/cache-usage.spec.ts +2 -2
  146. package/demos/pc/app/base-select/clearable.spec.ts +2 -2
  147. package/demos/pc/app/base-select/input-box-type.spec.ts +0 -2
  148. package/demos/pc/app/base-select/multiple.spec.ts +1 -1
  149. package/demos/pc/app/base-select/searchable.spec.ts +1 -1
  150. package/demos/pc/app/base-select/slot-reference.spec.ts +1 -1
  151. package/demos/pc/app/base-select/webdoc/base-select.js +3 -3
  152. package/demos/pc/app/checkbox/checkbox-disabled-composition-api.vue +10 -0
  153. package/demos/pc/app/checkbox/checkbox-disabled.spec.ts +22 -0
  154. package/demos/pc/app/checkbox/checkbox-disabled.vue +18 -0
  155. package/demos/pc/app/checkbox/vertical-checkbox.spec.ts +4 -4
  156. package/demos/pc/app/checkbox/webdoc/checkbox.js +13 -0
  157. package/demos/pc/app/color-picker/webdoc/color-picker.js +2 -2
  158. package/demos/pc/app/color-select-panel/format.spec.ts +3 -3
  159. package/demos/pc/app/country/fields.spec.js +1 -1
  160. package/demos/pc/app/currency/basic-usage.spec.ts +1 -1
  161. package/demos/pc/app/currency/custom-service.spec.ts +3 -3
  162. package/demos/pc/app/date-panel/shortcuts.vue +23 -23
  163. package/demos/pc/app/date-panel/unlink-panels.spec.ts +12 -8
  164. package/demos/pc/app/dept/custom-service.spec.ts +6 -6
  165. package/demos/pc/app/directives/webdoc/directives-auto-tip.js +2 -0
  166. package/demos/pc/app/drawer/close-on-press-escape-composition-api.vue +29 -0
  167. package/demos/pc/app/drawer/close-on-press-escape.spec.ts +19 -0
  168. package/demos/pc/app/drawer/close-on-press-escape.vue +38 -0
  169. package/demos/pc/app/drawer/webdoc/drawer.js +12 -0
  170. package/demos/pc/app/drop-roles/custom-service.spec.ts +1 -1
  171. package/demos/pc/app/drop-times/basic-usage.spec.ts +2 -2
  172. package/demos/pc/app/drop-times/start-end-step.spec.ts +1 -1
  173. package/demos/pc/app/dropdown/trigger-composition-api.vue +13 -0
  174. package/demos/pc/app/dropdown/trigger.spec.ts +13 -0
  175. package/demos/pc/app/dropdown/trigger.vue +13 -0
  176. package/demos/pc/app/dropdown/webdoc/dropdown.js +4 -4
  177. package/demos/pc/app/file-upload/upload-file-list-saas.spec.ts +0 -2
  178. package/demos/pc/app/form/basic-usage.spec.ts +2 -2
  179. package/demos/pc/app/form/custom-validation-string-length.vue +38 -0
  180. package/demos/pc/app/form/webdoc/form.js +12 -0
  181. package/demos/pc/app/grid/custom/column-simple.spec.js +2 -2
  182. package/demos/pc/app/grid/data-source/undefined-field-defalut-value-composition-api.vue +51 -0
  183. package/demos/pc/app/grid/data-source/undefined-field-defalut-value.spec.js +52 -0
  184. package/demos/pc/app/grid/data-source/undefined-field-defalut-value.vue +61 -0
  185. package/demos/pc/app/grid/editor/custom-editor-select-composition-api.vue +6 -1
  186. package/demos/pc/app/grid/editor/custom-editor-select.spec.js +5 -4
  187. package/demos/pc/app/grid/editor/custom-editor-select.vue +5 -1
  188. package/demos/pc/app/grid/editor/mutil-render.spec.js +4 -1
  189. package/demos/pc/app/grid/filter/server-filter-composition-api.vue +1 -1
  190. package/demos/pc/app/grid/filter/server-filter.vue +1 -1
  191. package/demos/pc/app/grid/webdoc/grid-data-source.js +12 -0
  192. package/demos/pc/app/grid-select/basic-usage-composition-api.vue +29 -1
  193. package/demos/pc/app/grid-select/basic-usage.vue +30 -1
  194. package/demos/pc/app/grid-select/config.spec.ts +24 -0
  195. package/demos/pc/app/grid-select/config.vue +1 -1
  196. package/demos/pc/app/grid-select/extra-query-params-composition-api.vue +110 -0
  197. package/demos/pc/app/grid-select/extra-query-params.spec.ts +21 -0
  198. package/demos/pc/app/grid-select/extra-query-params.vue +129 -0
  199. package/demos/pc/app/grid-select/init-query-composition-api.vue +119 -0
  200. package/demos/pc/app/grid-select/init-query.spec.ts +30 -0
  201. package/demos/pc/app/grid-select/init-query.vue +127 -0
  202. package/demos/pc/app/grid-select/radio-bigdata-composition-api.vue +44 -0
  203. package/demos/pc/app/grid-select/radio-bigdata.spec.ts +19 -0
  204. package/demos/pc/app/grid-select/radio-bigdata.vue +52 -0
  205. package/demos/pc/app/grid-select/remote.spec.ts +23 -0
  206. package/demos/pc/app/grid-select/remote.vue +2 -1
  207. package/demos/pc/app/grid-select/webdoc/grid-select.js +48 -29
  208. package/demos/pc/app/guide/basic-usage-composition-api.vue +4 -1
  209. package/demos/pc/app/guide/basic-usage.vue +4 -1
  210. package/demos/pc/app/guide/callback-composition-api.vue +1 -0
  211. package/demos/pc/app/guide/callback.vue +1 -0
  212. package/demos/pc/app/icon/advance-icons.js +412 -0
  213. package/demos/pc/app/icon/advance-usage-composition-api.vue +174 -0
  214. package/demos/pc/app/icon/advance-usage.vue +200 -0
  215. package/demos/pc/app/icon/webdoc/icon.js +20 -0
  216. package/demos/pc/app/modal/modal-header.vue +16 -2
  217. package/demos/pc/app/modal/webdoc/modal.js +7 -6
  218. package/demos/pc/app/query-builder/webdoc/query-builder.js +17 -14
  219. package/demos/pc/app/scroll-text/scroll-direction.spec.ts +4 -4
  220. package/demos/pc/app/select/allow-create.spec.ts +3 -3
  221. package/demos/pc/app/select/automatic-dropdown.spec.ts +2 -2
  222. package/demos/pc/app/select/basic-usage.spec.ts +3 -3
  223. package/demos/pc/app/select/binding-obj.spec.ts +2 -2
  224. package/demos/pc/app/select/cache-usage.spec.ts +2 -2
  225. package/demos/pc/app/select/clearable.spec.ts +1 -1
  226. package/demos/pc/app/select/webdoc/select.js +17 -11
  227. package/demos/pc/app/select-wrapper/all-text-composition-api.vue +35 -0
  228. package/demos/pc/app/select-wrapper/all-text.spec.ts +13 -0
  229. package/demos/pc/app/select-wrapper/all-text.vue +43 -0
  230. package/demos/pc/app/select-wrapper/allow-create-composition-api.vue +102 -0
  231. package/demos/pc/app/select-wrapper/allow-create.spec.ts +50 -0
  232. package/demos/pc/app/select-wrapper/allow-create.vue +112 -0
  233. package/demos/pc/app/select-wrapper/automatic-dropdown-composition-api.vue +54 -0
  234. package/demos/pc/app/select-wrapper/automatic-dropdown.spec.ts +31 -0
  235. package/demos/pc/app/select-wrapper/automatic-dropdown.vue +62 -0
  236. package/demos/pc/app/select-wrapper/basic-usage-composition-api.vue +38 -0
  237. package/demos/pc/app/select-wrapper/basic-usage.spec.ts +47 -0
  238. package/demos/pc/app/select-wrapper/basic-usage.vue +47 -0
  239. package/demos/pc/app/select-wrapper/binding-obj-composition-api.vue +35 -0
  240. package/demos/pc/app/select-wrapper/binding-obj.spec.ts +21 -0
  241. package/demos/pc/app/select-wrapper/binding-obj.vue +44 -0
  242. package/demos/pc/app/select-wrapper/cache-usage-composition-api.vue +39 -0
  243. package/demos/pc/app/select-wrapper/cache-usage.spec.ts +19 -0
  244. package/demos/pc/app/select-wrapper/cache-usage.vue +49 -0
  245. package/demos/pc/app/select-wrapper/clear-no-match-value-composition-api.vue +46 -0
  246. package/demos/pc/app/select-wrapper/clear-no-match-value.spec.ts +24 -0
  247. package/demos/pc/app/select-wrapper/clear-no-match-value.vue +54 -0
  248. package/demos/pc/app/select-wrapper/clearable-composition-api.vue +25 -0
  249. package/demos/pc/app/select-wrapper/clearable.spec.ts +21 -0
  250. package/demos/pc/app/select-wrapper/clearable.vue +34 -0
  251. package/demos/pc/app/select-wrapper/collapse-tags-composition-api.vue +54 -0
  252. package/demos/pc/app/select-wrapper/collapse-tags.spec.ts +32 -0
  253. package/demos/pc/app/select-wrapper/collapse-tags.vue +62 -0
  254. package/demos/pc/app/select-wrapper/copy-multi-composition-api.vue +66 -0
  255. package/demos/pc/app/select-wrapper/copy-multi.spec.ts +65 -0
  256. package/demos/pc/app/select-wrapper/copy-multi.vue +77 -0
  257. package/demos/pc/app/select-wrapper/copy-single-composition-api.vue +150 -0
  258. package/demos/pc/app/select-wrapper/copy-single.spec.ts +76 -0
  259. package/demos/pc/app/select-wrapper/copy-single.vue +157 -0
  260. package/demos/pc/app/select-wrapper/disabled-composition-api.vue +101 -0
  261. package/demos/pc/app/select-wrapper/disabled.spec.ts +88 -0
  262. package/demos/pc/app/select-wrapper/disabled.vue +108 -0
  263. package/demos/pc/app/select-wrapper/events-composition-api.vue +109 -0
  264. package/demos/pc/app/select-wrapper/events.spec.ts +72 -0
  265. package/demos/pc/app/select-wrapper/events.vue +112 -0
  266. package/demos/pc/app/select-wrapper/extra-query-params-composition-api.vue +155 -0
  267. package/demos/pc/app/select-wrapper/extra-query-params.vue +157 -0
  268. package/demos/pc/app/select-wrapper/filter-method-composition-api.vue +75 -0
  269. package/demos/pc/app/select-wrapper/filter-method.spec.ts +89 -0
  270. package/demos/pc/app/select-wrapper/filter-method.vue +85 -0
  271. package/demos/pc/app/select-wrapper/filter-mode-composition-api.vue +37 -0
  272. package/demos/pc/app/select-wrapper/filter-mode.vue +46 -0
  273. package/demos/pc/app/select-wrapper/hide-drop-composition-api.vue +25 -0
  274. package/demos/pc/app/select-wrapper/hide-drop.spec.ts +12 -0
  275. package/demos/pc/app/select-wrapper/hide-drop.vue +34 -0
  276. package/demos/pc/app/select-wrapper/init-label-composition-api.vue +57 -0
  277. package/demos/pc/app/select-wrapper/init-label.vue +65 -0
  278. package/demos/pc/app/select-wrapper/input-box-type-composition-api.vue +49 -0
  279. package/demos/pc/app/select-wrapper/input-box-type.spec.ts +71 -0
  280. package/demos/pc/app/select-wrapper/input-box-type.vue +58 -0
  281. package/demos/pc/app/select-wrapper/is-drop-inherit-width-composition-api.vue +42 -0
  282. package/demos/pc/app/select-wrapper/is-drop-inherit-width.spec.ts +34 -0
  283. package/demos/pc/app/select-wrapper/is-drop-inherit-width.vue +51 -0
  284. package/demos/pc/app/select-wrapper/manual-focus-blur-composition-api.vue +88 -0
  285. package/demos/pc/app/select-wrapper/manual-focus-blur.spec.ts +18 -0
  286. package/demos/pc/app/select-wrapper/manual-focus-blur.vue +90 -0
  287. package/demos/pc/app/select-wrapper/map-field-composition-api.vue +61 -0
  288. package/demos/pc/app/select-wrapper/map-field.spec.ts +60 -0
  289. package/demos/pc/app/select-wrapper/map-field.vue +68 -0
  290. package/demos/pc/app/select-wrapper/memoize-usage-composition-api.vue +52 -0
  291. package/demos/pc/app/select-wrapper/memoize-usage.spec.ts +19 -0
  292. package/demos/pc/app/select-wrapper/memoize-usage.vue +66 -0
  293. package/demos/pc/app/select-wrapper/multiple-composition-api.vue +139 -0
  294. package/demos/pc/app/select-wrapper/multiple-mix-composition-api.vue +75 -0
  295. package/demos/pc/app/select-wrapper/multiple-mix.vue +84 -0
  296. package/demos/pc/app/select-wrapper/multiple.spec.ts +52 -0
  297. package/demos/pc/app/select-wrapper/multiple.vue +146 -0
  298. package/demos/pc/app/select-wrapper/native-properties-composition-api.vue +25 -0
  299. package/demos/pc/app/select-wrapper/native-properties.spec.ts +16 -0
  300. package/demos/pc/app/select-wrapper/native-properties.vue +34 -0
  301. package/demos/pc/app/select-wrapper/nest-grid-composition-api.vue +99 -0
  302. package/demos/pc/app/select-wrapper/nest-grid-disable-composition-api.vue +88 -0
  303. package/demos/pc/app/select-wrapper/nest-grid-disable.spec.ts +41 -0
  304. package/demos/pc/app/select-wrapper/nest-grid-disable.vue +122 -0
  305. package/demos/pc/app/select-wrapper/nest-grid-init-query-composition-api.vue +122 -0
  306. package/demos/pc/app/select-wrapper/nest-grid-init-query.vue +129 -0
  307. package/demos/pc/app/select-wrapper/nest-grid-remote-composition-api.vue +127 -0
  308. package/demos/pc/app/select-wrapper/nest-grid-remote.spec.ts +136 -0
  309. package/demos/pc/app/select-wrapper/nest-grid-remote.vue +144 -0
  310. package/demos/pc/app/select-wrapper/nest-grid.spec.ts +95 -0
  311. package/demos/pc/app/select-wrapper/nest-grid.vue +106 -0
  312. package/demos/pc/app/select-wrapper/nest-radio-grid-much-data-composition-api.vue +43 -0
  313. package/demos/pc/app/select-wrapper/nest-radio-grid-much-data.spec.ts +35 -0
  314. package/demos/pc/app/select-wrapper/nest-radio-grid-much-data.vue +50 -0
  315. package/demos/pc/app/select-wrapper/nest-tree-composition-api.vue +97 -0
  316. package/demos/pc/app/select-wrapper/nest-tree.spec.ts +84 -0
  317. package/demos/pc/app/select-wrapper/nest-tree.vue +164 -0
  318. package/demos/pc/app/select-wrapper/no-data-text-composition-api.vue +39 -0
  319. package/demos/pc/app/select-wrapper/no-data-text.spec.ts +39 -0
  320. package/demos/pc/app/select-wrapper/no-data-text.vue +48 -0
  321. package/demos/pc/app/select-wrapper/optimization-composition-api.vue +50 -0
  322. package/demos/pc/app/select-wrapper/optimization.spec.ts +46 -0
  323. package/demos/pc/app/select-wrapper/optimization.vue +59 -0
  324. package/demos/pc/app/select-wrapper/option-group-composition-api.vue +96 -0
  325. package/demos/pc/app/select-wrapper/option-group.spec.ts +22 -0
  326. package/demos/pc/app/select-wrapper/option-group.vue +105 -0
  327. package/demos/pc/app/select-wrapper/popup-style-position-composition-api.vue +31 -0
  328. package/demos/pc/app/select-wrapper/popup-style-position.spec.ts +16 -0
  329. package/demos/pc/app/select-wrapper/popup-style-position.vue +40 -0
  330. package/demos/pc/app/select-wrapper/remote-method-composition-api.vue +283 -0
  331. package/demos/pc/app/select-wrapper/remote-method.spec.ts +68 -0
  332. package/demos/pc/app/select-wrapper/remote-method.vue +286 -0
  333. package/demos/pc/app/select-wrapper/searchable-composition-api.vue +46 -0
  334. package/demos/pc/app/select-wrapper/searchable.spec.ts +66 -0
  335. package/demos/pc/app/select-wrapper/searchable.vue +55 -0
  336. package/demos/pc/app/select-wrapper/show-alloption-composition-api.vue +25 -0
  337. package/demos/pc/app/select-wrapper/show-alloption.spec.ts +15 -0
  338. package/demos/pc/app/select-wrapper/show-alloption.vue +34 -0
  339. package/demos/pc/app/select-wrapper/show-tip-composition-api.vue +19 -0
  340. package/demos/pc/app/select-wrapper/show-tip.vue +28 -0
  341. package/demos/pc/app/select-wrapper/size-composition-api.vue +49 -0
  342. package/demos/pc/app/select-wrapper/size.spec.ts +61 -0
  343. package/demos/pc/app/select-wrapper/size.vue +57 -0
  344. package/demos/pc/app/select-wrapper/slot-default-composition-api.vue +86 -0
  345. package/demos/pc/app/select-wrapper/slot-default.spec.ts +18 -0
  346. package/demos/pc/app/select-wrapper/slot-default.vue +95 -0
  347. package/demos/pc/app/select-wrapper/slot-empty-composition-api.vue +35 -0
  348. package/demos/pc/app/select-wrapper/slot-empty.spec.ts +16 -0
  349. package/demos/pc/app/select-wrapper/slot-empty.vue +44 -0
  350. package/demos/pc/app/select-wrapper/slot-header-footer-composition-api.vue +45 -0
  351. package/demos/pc/app/select-wrapper/slot-header-footer.spec.ts +17 -0
  352. package/demos/pc/app/select-wrapper/slot-header-footer.vue +55 -0
  353. package/demos/pc/app/select-wrapper/slot-label-composition-api.vue +77 -0
  354. package/demos/pc/app/select-wrapper/slot-label.vue +85 -0
  355. package/demos/pc/app/select-wrapper/slot-prefix-composition-api.vue +31 -0
  356. package/demos/pc/app/select-wrapper/slot-prefix.spec.ts +18 -0
  357. package/demos/pc/app/select-wrapper/slot-prefix.vue +39 -0
  358. package/demos/pc/app/select-wrapper/slot-reference-composition-api.vue +33 -0
  359. package/demos/pc/app/select-wrapper/slot-reference.spec.ts +16 -0
  360. package/demos/pc/app/select-wrapper/slot-reference.vue +41 -0
  361. package/demos/pc/app/select-wrapper/tag-type-composition-api.vue +27 -0
  362. package/demos/pc/app/select-wrapper/tag-type.spec.ts +13 -0
  363. package/demos/pc/app/select-wrapper/tag-type.vue +36 -0
  364. package/demos/pc/app/select-wrapper/webdoc/select-wrapper.cn.md +7 -0
  365. package/demos/pc/app/select-wrapper/webdoc/select-wrapper.en.md +7 -0
  366. package/demos/pc/app/select-wrapper/webdoc/select-wrapper.js +721 -0
  367. package/demos/pc/app/space/space-size.vue +1 -1
  368. package/demos/pc/app/switch/webdoc/switch.js +12 -0
  369. package/demos/pc/app/switch/width-composition-api.vue +29 -0
  370. package/demos/pc/app/switch/width.spec.ts +17 -0
  371. package/demos/pc/app/switch/width.vue +35 -0
  372. package/demos/pc/app/tabs/header-only-composition-api.vue +56 -0
  373. package/demos/pc/app/tabs/header-only.vue +40 -29
  374. package/demos/pc/app/time-picker/picker-options.spec.ts +3 -4
  375. package/demos/pc/app/time-picker/step.spec.ts +2 -2
  376. package/demos/pc/app/transfer/basic-usage.spec.ts +4 -4
  377. package/demos/pc/app/tree/filter-view.spec.ts +1 -1
  378. package/demos/pc/app/tree-menu/clearable.spec.ts +1 -5
  379. package/demos/pc/app/tree-select/collapse-tags.vue +2 -18
  380. package/demos/pc/app/tree-select/lazy-composition-api.vue +51 -0
  381. package/demos/pc/app/tree-select/lazy-multiple-composition-api.vue +58 -0
  382. package/demos/pc/app/tree-select/lazy-multiple.vue +66 -0
  383. package/demos/pc/app/tree-select/lazy.vue +59 -0
  384. package/demos/pc/app/tree-select/webdoc/tree-select.js +14 -0
  385. package/demos/pc/app/user/custom-service.spec.ts +1 -1
  386. package/demos/pc/menus.js +19 -10
  387. package/demos/pc/webdoc/architecture.png +0 -0
  388. package/demos/pc/webdoc/import-components-en.md +4 -2
  389. package/demos/pc/webdoc/import-components.md +4 -2
  390. package/demos/pc/webdoc/installation-en.md +5 -3
  391. package/demos/pc/webdoc/installation.md +5 -3
  392. package/demos/pc/webdoc/introduce.md +64 -0
  393. package/demos/pc/webdoc/motion-configuration-en.md +183 -0
  394. package/demos/pc/webdoc/motion-configuration.md +183 -0
  395. package/demos/pc/webdoc/theme-en.md +7 -5
  396. package/demos/pc/webdoc/theme.md +12 -7
  397. package/demos/saas/menus.js +14 -1
  398. package/env/.env.saaspages +1 -1
  399. package/package.json +20 -20
  400. package/playground/App.vue +270 -84
  401. package/playground/assets/icon-layout-vertical.svg +4 -0
  402. package/playground/icons/Github.vue +14 -2
  403. package/playground/icons/Layout.vue +18 -0
  404. package/playground/icons/Reverse.vue +115 -0
  405. package/playground/icons/Set.vue +80 -0
  406. package/playground/icons/Share.vue +103 -8
  407. package/playground/icons/Vertical.vue +19 -0
  408. package/public/static/css/design-common.css +1 -0
  409. package/src/assets/custom-block.less +2 -2
  410. package/src/components/anchor.vue +2 -1
  411. package/src/components/api-docs.vue +2 -2
  412. package/src/components/async-highlight.vue +6 -0
  413. package/src/components/header.vue +19 -0
  414. package/src/views/components-doc/common.vue +20 -3
  415. package/src/views/overview.vue +1 -1
  416. package/demos/pc/app/grid-select/filter-composition-api.vue +0 -49
  417. package/demos/pc/app/grid-select/filter.vue +0 -57
  418. package/demos/pc/app/grid-select/multiple-composition-api.vue +0 -38
  419. package/demos/pc/app/grid-select/multiple.vue +0 -45
@@ -0,0 +1,1067 @@
1
+ export default {
2
+ mode: ['pc', 'mobile-first'],
3
+ apis: [
4
+ {
5
+ name: 'select',
6
+ type: 'component',
7
+ props: [
8
+ {
9
+ name: 'all-text',
10
+ type: 'string',
11
+ defaultValue: '',
12
+ desc: {
13
+ 'zh-CN': '当下拉中显示全部时,自定义全部的显示文本。不指定时,则默认显示"全部"',
14
+ 'en-US':
15
+ 'When all is displayed in the drop-down list, you can customize the display text of all. If this parameter is not specified, All is displayed by default.'
16
+ },
17
+ mode: ['pc', 'mobile-first'],
18
+ pcDemo: 'all-text',
19
+ mfDemo: 'all-text'
20
+ },
21
+ {
22
+ name: 'show-all-text-tag',
23
+ type: 'boolean',
24
+ defaultValue: 'false',
25
+ desc: {
26
+ 'zh-CN':
27
+ '指定多选模式全选后,在输入框中,是否只显示 all-text 指定的Tag。 默认值为 <code>false</code>,所有选项循环显示在输入框。',
28
+ 'en-US':
29
+ 'Specifies whether only the tag specified by all-text is displayed in the text box after the multi-select mode is specified. The default value is <code>false</code>. All options are displayed in the text box cyclically.'
30
+ },
31
+ mode: ['pc'],
32
+ pcDemo: 'all-text'
33
+ },
34
+ {
35
+ name: 'allow-copy',
36
+ type: 'boolean',
37
+ defaultValue: 'false',
38
+ desc: {
39
+ 'zh-CN': '是否允许复制输入框的内容,适用单选可搜索场景',
40
+ 'en-US':
41
+ 'Is it allowed to copy the content of the input box, applicable to single choice searchable scenarios'
42
+ },
43
+ mode: ['pc', 'mobile-first'],
44
+ pcDemo: 'copy-single',
45
+ mfDemo: 'copy-single'
46
+ },
47
+ {
48
+ name: 'allow-create',
49
+ type: 'boolean',
50
+ defaultValue: 'false',
51
+ desc: {
52
+ 'zh-CN': '是否允许创建新条目,需配合 filterable 使用。若搜索字段不在选项列表中,可创建为新的选项',
53
+ 'en-US':
54
+ 'Is it allowed to create new entries? It needs to be used in conjunction with filterable. If the search field is not in the option list, it can be created as a new option'
55
+ },
56
+ mode: ['pc', 'mobile-first'],
57
+ pcDemo: 'allow-create',
58
+ mfDemo: 'allow-create'
59
+ },
60
+ {
61
+ name: 'autocomplete',
62
+ type: 'string',
63
+ defaultValue: "'off'",
64
+ desc: {
65
+ 'zh-CN': '输入框的原生 autocomplete 属性',
66
+ 'en-US': 'The native autocomplete attribute of the input box'
67
+ },
68
+ mode: ['pc', 'mobile-first'],
69
+ pcDemo: 'native-properties',
70
+ mfDemo: 'native-properties'
71
+ },
72
+ {
73
+ name: 'cache-op',
74
+ typeAnchorName: 'ICacheOp',
75
+ type: 'ICacheOp',
76
+ defaultValue:
77
+ "<pre>\n{\n key: '',\n sortBy: 'frequency',\n sort: 'desc',\n dataKey: 'value',\n highlightClass: \n 'memorize-highlight',\n highlightNum: Infinity,\n cacheNum: Infinity,\n serialize: JSON.stringify\n deserialize: JSON.parse\n}\n</pre>",
78
+ desc: {
79
+ 'zh-CN': '启用本地缓存已选项的功能配置(根据用户点击选择的次数、最后时间继续存储排序)',
80
+ 'en-US': 'Set the component type when Grid or Tree is embedded in the drop-down list box.'
81
+ },
82
+ mode: ['pc', 'mobile-first'],
83
+ pcDemo: 'cache-usage',
84
+ mfDemo: 'cache-usage'
85
+ },
86
+ {
87
+ name: 'clear-no-match-value',
88
+ type: 'boolean',
89
+ defaultValue: 'false',
90
+ desc: {
91
+ 'zh-CN': '是否自动清空无法在 options 中找到匹配项的值',
92
+ 'en-US': 'Automatically clear values that cannot find matching items in options'
93
+ },
94
+ mode: ['pc', 'mobile-first'],
95
+ pcDemo: 'clear-no-match-value',
96
+ mfDemo: 'clear-no-match-value'
97
+ },
98
+ {
99
+ name: 'clearable',
100
+ type: 'boolean',
101
+ defaultValue: 'false',
102
+ desc: {
103
+ 'zh-CN': '是否启用一键清除的功能',
104
+ 'en-US': 'Whether to display the one click clear button, only applicable to radio selection'
105
+ },
106
+ mode: ['pc', 'mobile-first'],
107
+ pcDemo: 'clearable',
108
+ mfDemo: 'clearable'
109
+ },
110
+ {
111
+ name: 'click-expend',
112
+ type: 'boolean',
113
+ defaultValue: 'false',
114
+ desc: {
115
+ 'zh-CN': '点击可展开或收起显示不全的选项。仅用于多选',
116
+ 'en-US': 'Click to expand or collapse options. Only applicable to multiple selections'
117
+ }
118
+ },
119
+ {
120
+ name: 'collapse-tags',
121
+ type: 'boolean',
122
+ defaultValue: 'false',
123
+ desc: {
124
+ 'zh-CN': '是否将多个标签折叠显示。仅适用多选',
125
+ 'en-US': 'Whether to collapse multiple labels for display. Only applicable to multiple selections'
126
+ },
127
+ mode: ['pc', 'mobile-first'],
128
+ pcDemo: 'collapse-tags',
129
+ mfDemo: 'collapse-tags'
130
+ },
131
+ {
132
+ name: 'copyable',
133
+ type: 'boolean',
134
+ defaultValue: 'false',
135
+ desc: {
136
+ 'zh-CN': '是否启用一键复制的功能。点击复制按钮一键复制所有标签的文本内容并以逗号分隔,仅适用于多选',
137
+ 'en-US':
138
+ 'Is the one click copy function enabled. Click the copy button to copy the text content of all labels with one click, separated by commas, only applicable to multiple selections'
139
+ },
140
+ mode: ['pc', 'mobile-first'],
141
+ pcDemo: 'copy-multi',
142
+ mfDemo: 'copy-multi'
143
+ },
144
+ {
145
+ name: 'default-first-option',
146
+ type: 'boolean',
147
+ defaultValue: 'false',
148
+ desc: {
149
+ 'zh-CN': '是否启用按 Enter 键选择第一个匹配项的功能。需配合 filterable 或 remote 使用',
150
+ 'en-US':
151
+ 'Whether to enable the function of pressing the Enter key to select the first match. Must be used in conjunction with filterable or remote'
152
+ },
153
+ mode: ['pc', 'mobile-first'],
154
+ pcDemo: 'allow-create',
155
+ mfDemo: 'allow-create'
156
+ },
157
+ {
158
+ name: 'disabled',
159
+ type: 'boolean',
160
+ defaultValue: 'false',
161
+ desc: {
162
+ 'zh-CN': '是否禁用',
163
+ 'en-US': 'Is it disabled'
164
+ },
165
+ mode: ['pc', 'mobile-first'],
166
+ pcDemo: 'disabled',
167
+ mfDemo: 'disabled'
168
+ },
169
+ {
170
+ name: 'dropdown-icon',
171
+ type: 'Component',
172
+ defaultValue: '',
173
+ desc: {
174
+ 'zh-CN': '自定义下拉图标',
175
+ 'en-US': 'Custom drop-down icon'
176
+ },
177
+ mode: ['pc'],
178
+ pcDemo: 'multiple'
179
+ },
180
+ {
181
+ name: 'dropdown-style',
182
+ type: 'String',
183
+ defaultValue: '',
184
+ desc: {
185
+ 'zh-CN': '自定义下拉选项样式',
186
+ 'en-US': 'Custom drop-down options style'
187
+ },
188
+ mode: ['pc'],
189
+ pcDemo: 'multiple'
190
+ },
191
+ {
192
+ name: 'filter-method',
193
+ type: '(query: string) => void',
194
+ defaultValue: '',
195
+ desc: {
196
+ 'zh-CN': '自定义过滤方法',
197
+ 'en-US': 'Custom filtering method'
198
+ },
199
+ mode: ['pc', 'mobile-first'],
200
+ pcDemo: 'filter-method',
201
+ mfDemo: 'filter-method'
202
+ },
203
+ {
204
+ name: 'filterable',
205
+ type: 'boolean',
206
+ defaultValue: 'false',
207
+ desc: {
208
+ 'zh-CN': '是否可搜索',
209
+ 'en-US': 'Is it searchable'
210
+ },
211
+ mode: ['pc', 'mobile-first'],
212
+ pcDemo: 'filter-method',
213
+ mfDemo: 'filter-method'
214
+ },
215
+ {
216
+ name: 'grid-op',
217
+ typeAnchorName: 'IGridOption',
218
+ type: 'IGridOption',
219
+ defaultValue: '',
220
+ desc: {
221
+ 'zh-CN': '下拉表格时,内置表格的配置,用法同 Grid 组件。需结合 render-type 属性使用',
222
+ 'en-US':
223
+ 'When pulling down a table, the configuration of the built-in table is the same as that of the Grid component. To be used in conjunction with the render type attribute'
224
+ },
225
+ mode: ['pc', 'mobile-first'],
226
+ pcDemo: 'nest-grid',
227
+ mfDemo: 'nest-grid'
228
+ },
229
+ {
230
+ name: 'input-box-type',
231
+ type: "'input' | 'underline'",
232
+ defaultValue: "'input'",
233
+ desc: {
234
+ 'zh-CN': '输入框的显示类型',
235
+ 'en-US': 'Display type of input box'
236
+ },
237
+ mode: ['pc', 'mobile-first'],
238
+ pcDemo: 'input-box-type',
239
+ mfDemo: 'input-box-type'
240
+ },
241
+ {
242
+ name: 'is-drop-inherit-width',
243
+ type: 'boolean',
244
+ defaultValue: 'false',
245
+ desc: {
246
+ 'zh-CN': '下拉弹框的宽度是否跟输入框保持一致。默认超出输入框宽度时由内容撑开',
247
+ 'en-US':
248
+ 'Is the width of the dropdown box consistent with the input box. By default, when the width of the input box is exceeded, it is supported by the content'
249
+ },
250
+ mode: ['pc', 'mobile-first'],
251
+ pcDemo: 'is-drop-inherit-width',
252
+ mfDemo: 'is-drop-inherit-width'
253
+ },
254
+ {
255
+ name: 'loading',
256
+ type: 'boolean',
257
+ defaultValue: 'false',
258
+ desc: {
259
+ 'zh-CN': '是否加载中,适用于远程搜索场景',
260
+ 'en-US': 'Loading or not, suitable for remote search scenarios'
261
+ },
262
+ mode: ['pc', 'mobile-first'],
263
+ pcDemo: 'remote-method',
264
+ mfDemo: 'remote-method'
265
+ },
266
+ {
267
+ name: 'loading-text',
268
+ type: 'string',
269
+ defaultValue: "'加载中'",
270
+ desc: {
271
+ 'zh-CN': '远程加载时显示的文本',
272
+ 'en-US': 'Text displayed during remote loading'
273
+ },
274
+ mode: ['pc', 'mobile-first'],
275
+ pcDemo: 'remote-method',
276
+ mfDemo: 'remote-method'
277
+ },
278
+ {
279
+ name: 'max-visible-rows',
280
+ type: 'number',
281
+ defaultValue: '1',
282
+ desc: {
283
+ 'zh-CN': '多行默认最大显示行数,超出后选项自动隐藏',
284
+ 'en-US':
285
+ 'Default maximum display lines for multiple lines, with automatic hiding option for exceeding lines'
286
+ },
287
+ mode: ['pc'],
288
+ pcDemo: 'collapse-tags'
289
+ },
290
+ {
291
+ name: 'modelValue / v-model',
292
+ type: 'string | number | Array<string|number>',
293
+ defaultValue: '',
294
+ desc: {
295
+ 'zh-CN': '绑定值',
296
+ 'en-US': 'Bind value'
297
+ },
298
+ mode: ['pc', 'mobile-first'],
299
+ pcDemo: 'multiple',
300
+ mfDemo: 'multiple'
301
+ },
302
+ {
303
+ name: 'multiple',
304
+ type: 'boolean',
305
+ defaultValue: 'false',
306
+ desc: {
307
+ 'zh-CN': '是否允许选择多个选项',
308
+ 'en-US': 'Allow multiple options to be selected'
309
+ },
310
+ mode: ['pc', 'mobile-first'],
311
+ pcDemo: 'multiple',
312
+ mfDemo: 'multiple'
313
+ },
314
+ {
315
+ name: 'multiple-limit',
316
+ type: 'number',
317
+ defaultValue: '0',
318
+ desc: {
319
+ 'zh-CN': '多选时最多可选择的个数,默认为 0 不限制',
320
+ 'en-US':
321
+ 'When selecting multiple options, the maximum number of options available is 0, with no limit by default'
322
+ },
323
+ mode: ['pc', 'mobile-first'],
324
+ pcDemo: 'multiple-limit',
325
+ mfDemo: 'multiple-limit'
326
+ },
327
+ {
328
+ name: 'name',
329
+ type: 'string',
330
+ defaultValue: '',
331
+ desc: {
332
+ 'zh-CN': '输入框的原生 name 属性',
333
+ 'en-US': 'The native name attribute of the input box'
334
+ },
335
+ mode: ['pc', 'mobile-first'],
336
+ pcDemo: 'native-properties',
337
+ mfDemo: 'native-properties'
338
+ },
339
+ {
340
+ name: 'no-data-text',
341
+ type: 'string',
342
+ defaultValue: "'暂无相关数据'",
343
+ desc: {
344
+ 'zh-CN': '选项列表为空时显示的文本,也可以使用 empty 插槽设置',
345
+ 'en-US': 'The text displayed when the option list is empty can also be set using empty slots'
346
+ },
347
+ mode: ['pc', 'mobile-first'],
348
+ pcDemo: 'no-data-text',
349
+ mfDemo: 'no-data-text'
350
+ },
351
+ {
352
+ name: 'no-match-text',
353
+ type: 'string',
354
+ defaultValue: "'无匹配数据'",
355
+ desc: {
356
+ 'zh-CN': '搜索条件无匹配时显示的文本,也可以使用 empty 插槽设置',
357
+ 'en-US':
358
+ 'The text displayed when there is no match for the search criteria can also be set using empty slots'
359
+ },
360
+ mode: ['pc'],
361
+ pcDemo: 'filter-method'
362
+ },
363
+ {
364
+ name: 'optimization',
365
+ type: 'boolean',
366
+ defaultValue: 'false',
367
+ desc: {
368
+ 'zh-CN': '是否开启大数据虚拟滚动功能。仅配置式(使用 options 属性)时支持',
369
+ 'en-US':
370
+ 'Whether to enable the big data virtual scrolling feature. Supported only when configured (using the options attribute)'
371
+ },
372
+ mode: ['pc', 'mobile-first'],
373
+ pcDemo: 'optimization',
374
+ mfDemo: 'optimization'
375
+ },
376
+ {
377
+ name: 'options',
378
+ typeAnchorName: 'IOption',
379
+ type: 'IOption[]',
380
+ defaultValue: '',
381
+ desc: {
382
+ 'zh-CN': '选项列表配置,使用后不需要再配置 tiny-option',
383
+ 'en-US': 'Option list configuration, no need to configure tiny options after use'
384
+ },
385
+ mode: ['pc', 'mobile-first'],
386
+ pcDemo: 'map-field',
387
+ mfDemo: 'map-field'
388
+ },
389
+ {
390
+ name: 'placeholder',
391
+ type: 'string',
392
+ defaultValue: "'请选择'",
393
+ desc: {
394
+ 'zh-CN': '占位符',
395
+ 'en-US': 'Placeholder'
396
+ },
397
+ mode: ['pc', 'mobile-first'],
398
+ pcDemo: 'native-properties',
399
+ mfDemo: 'native-properties'
400
+ },
401
+ {
402
+ name: 'placement',
403
+ typeAnchorName: 'IPlacement',
404
+ type: 'IPlacement',
405
+ defaultValue: "'bottom-start'",
406
+ desc: {
407
+ 'zh-CN': '下拉弹框相对于触发源的弹出位置',
408
+ 'en-US': 'The pop-up position of the pull-down pop-up box relative to the trigger source'
409
+ },
410
+ mode: ['pc', 'mobile-first'],
411
+ pcDemo: 'popup-style-position',
412
+ mfDemo: 'popup-style-position'
413
+ },
414
+ {
415
+ name: 'popper-append-to-body',
416
+ type: 'boolean',
417
+ defaultValue: 'true',
418
+ desc: {
419
+ 'zh-CN': '是否将弹出框的 dom 元素插入至 body 元素',
420
+ 'en-US': 'Whether to insert the dom element of the pop-up box into the body element'
421
+ },
422
+ mode: ['pc', 'mobile-first'],
423
+ pcDemo: 'popup-style-position',
424
+ mfDemo: 'popup-style-position'
425
+ },
426
+ {
427
+ name: 'popper-class',
428
+ type: 'string',
429
+ defaultValue: '',
430
+ desc: {
431
+ 'zh-CN': '自定义下拉框的类名,用于自定义样式',
432
+ 'en-US': 'The class name of the custom dropdown box, used for customizing styles'
433
+ },
434
+ mode: ['pc', 'mobile-first'],
435
+ pcDemo: 'popup-style-position',
436
+ mfDemo: 'popup-style-position'
437
+ },
438
+ {
439
+ name: 'popper-options',
440
+ typeAnchorName: 'IPopperOption',
441
+ type: 'IPopperOption',
442
+ defaultValue: ' { }',
443
+ desc: {
444
+ 'zh-CN': '弹出层参数',
445
+ 'en-US': 'Advanced parameters; Refer to the description of IPopperOption'
446
+ },
447
+ mode: ['pc', 'mobile-first'],
448
+ pcDemo: '',
449
+ mfDemo: ''
450
+ },
451
+ {
452
+ name: 'remote',
453
+ type: 'boolean',
454
+ defaultValue: 'false',
455
+ desc: {
456
+ 'zh-CN': '是否为远程搜索',
457
+ 'en-US': 'Is it a remote search'
458
+ },
459
+ mode: ['pc', 'mobile-first'],
460
+ pcDemo: 'remote-method',
461
+ mfDemo: 'remote-method'
462
+ },
463
+ {
464
+ name: 'remote-method',
465
+ type: '(query:string) => void',
466
+ defaultValue: '',
467
+ desc: {
468
+ 'zh-CN': '远程搜索的方法',
469
+ 'en-US': 'Remote search methods'
470
+ },
471
+ mode: ['pc', 'mobile-first'],
472
+ pcDemo: 'remote-method',
473
+ mfDemo: 'remote-method'
474
+ },
475
+ {
476
+ name: 'render-type',
477
+ type: "'tree' | 'grid'",
478
+ defaultValue: '',
479
+ desc: {
480
+ 'zh-CN': '渲染为下拉表格或下拉树,需结合 grid-op / tree-op 使用',
481
+ 'en-US': 'Rendered as a dropdown table or tree, to be used in conjunction with grid op/tree op'
482
+ },
483
+ mode: ['pc', 'mobile-first'],
484
+ pcDemo: 'nest-grid',
485
+ mfDemo: 'nest-grid'
486
+ },
487
+ {
488
+ name: 'reserve-keyword',
489
+ type: 'boolean',
490
+ defaultValue: 'false',
491
+ desc: {
492
+ 'zh-CN': '多选可搜索时,是否在选中一个选项后仍然保留当前的搜索关键词',
493
+ 'en-US':
494
+ 'When selecting multiple searchable options, do you still keep the current search keywords after selecting one option'
495
+ },
496
+ mode: ['pc', 'mobile-first'],
497
+ pcDemo: 'remote-method',
498
+ mfDemo: 'remote-method'
499
+ },
500
+ {
501
+ name: 'searchable',
502
+ type: 'boolean',
503
+ defaultValue: 'false',
504
+ desc: {
505
+ 'zh-CN': '是否启用下拉面板搜索',
506
+ 'en-US': 'Whether to allow users to create new items. This parameter must be used together with filterable.'
507
+ },
508
+ mode: ['pc', 'mobile-first'],
509
+ pcDemo: 'searchable',
510
+ mfDemo: 'searchable'
511
+ },
512
+ {
513
+ name: 'show-alloption',
514
+ type: 'boolean',
515
+ defaultValue: 'true',
516
+ desc: {
517
+ 'zh-CN': '是否展示 “全选” 选项',
518
+ 'en-US': 'Whether to display the "Select All" option'
519
+ },
520
+ mode: ['pc', 'mobile-first'],
521
+ pcDemo: 'show-alloption',
522
+ mfDemo: 'show-alloption'
523
+ },
524
+ {
525
+ name: 'show-empty-image',
526
+ type: 'boolean',
527
+ defaultValue: 'false',
528
+ desc: {
529
+ 'zh-CN': '是否显示空数据图片',
530
+ 'en-US': 'Display empty data image'
531
+ },
532
+ mode: ['pc', 'mobile-first'],
533
+ pcDemo: 'no-data-text',
534
+ mfDemo: 'no-data-text'
535
+ },
536
+ {
537
+ name: 'size',
538
+ type: "'medium' | 'small' | 'mini'",
539
+ defaultValue: '',
540
+ desc: {
541
+ 'zh-CN': '输入框尺寸。',
542
+ 'en-US': 'Text box size'
543
+ },
544
+ mode: ['pc', 'mobile-first'],
545
+ pcDemo: 'size',
546
+ mfDemo: 'size'
547
+ },
548
+ {
549
+ name: 'tag-selectable',
550
+ type: 'boolean',
551
+ defaultValue: 'false',
552
+ desc: {
553
+ 'zh-CN': '输入框中的标签是否可通过鼠标选中复制',
554
+ 'en-US': 'Can the label in the input box be copied by selecting it with the mouse'
555
+ },
556
+ mode: ['pc', 'mobile-first'],
557
+ pcDemo: 'copy-multi',
558
+ mfDemo: 'copy-multi'
559
+ },
560
+ {
561
+ name: 'tag-type',
562
+ type: "'success' | 'info' | 'warning' | 'danger'",
563
+ defaultValue: '',
564
+ desc: {
565
+ 'zh-CN': '标签类型,仅多选适用。使用 aurora 主题时设置该属性为 info',
566
+ 'en-US':
567
+ 'Label type, only applicable for multiple choices. Set this property to info when using the aurora theme'
568
+ },
569
+ mode: ['pc', 'mobile-first'],
570
+ pcDemo: 'tag-type',
571
+ mfDemo: 'tag-type'
572
+ },
573
+ {
574
+ name: 'max-tag-width',
575
+ type: 'string',
576
+ defaultValue: '',
577
+ desc: {
578
+ 'zh-CN': '多选时,设置最大标签宽度',
579
+ 'en-US': 'When multiple selections are made, set the maximum label width.'
580
+ },
581
+ mode: ['pc', 'mobile-first'],
582
+ pcDemo: '',
583
+ meta: {
584
+ stable: '3.22.0'
585
+ }
586
+ },
587
+ {
588
+ name: 'text-field',
589
+ type: 'string',
590
+ defaultValue: "'label'",
591
+ desc: {
592
+ 'zh-CN': '显示值字段',
593
+ 'en-US': 'Show Value Fields'
594
+ },
595
+ mode: ['pc', 'mobile-first'],
596
+ pcDemo: 'map-field',
597
+ mfDemo: 'map-field'
598
+ },
599
+ {
600
+ name: 'text-split',
601
+ type: 'string',
602
+ defaultValue: "','",
603
+ desc: {
604
+ 'zh-CN': '自定义复制文本的分隔符,需结合 copyable 属性使用',
605
+ 'en-US': 'The separator for custom copied text needs to be used in conjunction with the copyable attribute'
606
+ },
607
+ mode: ['pc', 'mobile-first'],
608
+ pcDemo: 'copy-multi',
609
+ mfDemo: 'copy-multi'
610
+ },
611
+ {
612
+ name: 'top-create',
613
+ type: 'boolean',
614
+ defaultValue: '',
615
+ desc: {
616
+ 'zh-CN': '是否显示下拉框顶部新增按钮,点击按钮会抛出一个 top-create-click 事件,可以在事件中自定义一些行为',
617
+ 'en-US':
618
+ 'Indicates whether to display a new button on the top of the drop-down list box. When a button is clicked, a top-create-click event is thrown. You can customize some behaviors in the event'
619
+ },
620
+ mode: ['pc'],
621
+ pcDemo: 'allow-create'
622
+ },
623
+ {
624
+ name: 'tree-op',
625
+ typeAnchorName: 'ITreeOption',
626
+ type: 'ITreeOption',
627
+ defaultValue: '',
628
+ desc: {
629
+ 'zh-CN': '下拉树时,内置树组件的配置,用法同 Tree 组件。需结合 render-type 属性使用',
630
+ 'en-US':
631
+ 'When pulling down a tree, the configuration of the built-in tree component is the same as that of the Tree component. To be used in conjunction with the render type attribute'
632
+ },
633
+ mode: ['pc', 'mobile-first'],
634
+ pcDemo: 'nest-tree',
635
+ mfDemo: 'nest-tree'
636
+ },
637
+ {
638
+ name: 'value-field',
639
+ type: 'string',
640
+ defaultValue: "'value'",
641
+ desc: {
642
+ 'zh-CN': '绑定值字段',
643
+ 'en-US': 'Bind Value Field'
644
+ },
645
+ mode: ['pc', 'mobile-first'],
646
+ pcDemo: 'map-field',
647
+ mfDemo: 'map-field'
648
+ },
649
+ {
650
+ name: 'value-key',
651
+ type: 'string',
652
+ defaultValue: "'value'",
653
+ desc: {
654
+ 'zh-CN': '作为 value 唯一标识的键名,绑定值为对象类型时必填',
655
+ 'en-US':
656
+ 'The key name that uniquely identifies the value must be filled in when the binding value is of object type'
657
+ },
658
+ mode: ['pc', 'mobile-first'],
659
+ pcDemo: 'binding-obj',
660
+ mfDemo: 'binding-obj'
661
+ },
662
+ {
663
+ name: 'show-proportion',
664
+ type: 'boolean',
665
+ defaultValue: 'false',
666
+ desc: {
667
+ 'zh-CN': '是否展示多选框选中条数和总条数的占比的文字提示',
668
+ 'en-US':
669
+ 'Display the proportion of the number of selected items and the total number of items in the multiple-choice box'
670
+ },
671
+ mode: ['pc', 'mobile-first'],
672
+ pcDemo: 'collapse-tags',
673
+ mfDemo: 'collapse-tags'
674
+ },
675
+ {
676
+ name: 'show-limit-text',
677
+ type: 'boolean',
678
+ defaultValue: 'false',
679
+ desc: {
680
+ 'zh-CN':
681
+ '是否展示多选框开启多选限制选择数量时,选中条数和限制总条数的占比的文字提示。 该属性的优先级大于<code>show-proportion</code> 属性。',
682
+ 'en-US':
683
+ 'Display the proportion of the number of selected items and the maximum number of options available in the multiple-choice box. This attribute has a higher priority than the <code>show-proportion</code> attribute.'
684
+ },
685
+ mode: ['pc'],
686
+ pcDemo: 'multiple'
687
+ },
688
+ {
689
+ name: 'init-label',
690
+ type: 'string',
691
+ defaultValue: '',
692
+ desc: {
693
+ 'zh-CN':
694
+ '通过 <code>init-label</code> 属性设置远程搜索或者嵌套树懒加载数据未获取到时显示的初始化 <code>label </code>值。',
695
+ 'en-US':
696
+ 'Use the <code>init-label</code> attribute to set the initial <code>label </code> value displayed when remote search or nested sloth loading data is not obtained.'
697
+ },
698
+ mode: ['pc'],
699
+ pcDemo: 'init-label'
700
+ },
701
+ {
702
+ name: 'display-only',
703
+ type: 'boolean',
704
+ defaultValue: 'false',
705
+ desc: {
706
+ 'zh-CN': '设置组件只显示文字。在Form中使用时,会默认继承上级的<code>display-only</code>的值。',
707
+ 'en-US':
708
+ 'Sets the widget to display only text.When used in a form, the value of <code>display-only</code> is inherited by default.'
709
+ },
710
+ mode: ['pc'],
711
+ pcDemo: 'multiple-mix'
712
+ },
713
+ {
714
+ name: 'hover-expand',
715
+ type: 'boolean',
716
+ defaultValue: 'false',
717
+ desc: {
718
+ 'zh-CN': '多选时,鼠标移入触发标签的自动展开',
719
+ 'en-US':
720
+ 'When multiple selections are selected, move the cursor to trigger the automatic expansion of the label.'
721
+ },
722
+ mode: ['pc'],
723
+ pcDemo: 'multiple-mix'
724
+ }
725
+ ],
726
+ events: [
727
+ {
728
+ name: 'blur',
729
+ type: '(event:MouseEvent) => void',
730
+ defaultValue: '',
731
+ desc: {
732
+ 'zh-CN': '监听输入框失去焦点事件',
733
+ 'en-US': 'Listening for input box lose focus event'
734
+ },
735
+ mode: ['pc', 'mobile-first'],
736
+ pcDemo: 'events',
737
+ mfDemo: 'events'
738
+ },
739
+ {
740
+ name: 'change',
741
+ type: '(value:string|number|Array<string|number>, list:Array<IOption|ITreeNode>) => void',
742
+ defaultValue: '',
743
+ desc: {
744
+ 'zh-CN': '监听绑定值变更事件',
745
+ 'en-US': 'Listening for binding value change events'
746
+ },
747
+ mode: ['pc', 'mobile-first'],
748
+ pcDemo: 'events',
749
+ mfDemo: 'events'
750
+ },
751
+ {
752
+ name: 'clear',
753
+ type: '() => void',
754
+ defaultValue: '',
755
+ desc: {
756
+ 'zh-CN': '监听一键清除事件',
757
+ 'en-US': 'Listening for one click clear events'
758
+ },
759
+ mode: ['pc', 'mobile-first'],
760
+ pcDemo: 'events',
761
+ mfDemo: 'events'
762
+ },
763
+ {
764
+ name: 'focus',
765
+ type: '(event:MouseEvent) => void',
766
+ defaultValue: '',
767
+ desc: {
768
+ 'zh-CN': '监听输入框获取焦点事件',
769
+ 'en-US': 'Listening to input boxes to obtain focus events'
770
+ },
771
+ mode: ['pc', 'mobile-first'],
772
+ pcDemo: 'events',
773
+ mfDemo: 'events'
774
+ },
775
+ {
776
+ name: 'remove-tag',
777
+ type: '(tag:string|number) => void',
778
+ defaultValue: '',
779
+ desc: {
780
+ 'zh-CN': '监听多选时移除标签事件',
781
+ 'en-US': 'Remove label events when listening for multiple selections'
782
+ },
783
+ mode: ['pc', 'mobile-first'],
784
+ pcDemo: 'events',
785
+ mfDemo: 'events'
786
+ },
787
+ {
788
+ name: 'top-create-click',
789
+ type: '() => void',
790
+ defaultValue: '',
791
+ desc: {
792
+ 'zh-CN': '监听顶部新增按钮点击事件,同 top-create 属性一起使用',
793
+ 'en-US':
794
+ 'Listens to the click event of a new button on the top. This parameter is used together with the top-create attribute'
795
+ },
796
+ mode: ['pc'],
797
+ pcDemo: 'events'
798
+ },
799
+ {
800
+ name: 'visible-change',
801
+ type: '(status:boolean) => void',
802
+ defaultValue: '',
803
+ desc: {
804
+ 'zh-CN': '监听下拉弹框的显示隐藏状态',
805
+ 'en-US': 'Monitor the display and hidden status of dropdown pop ups'
806
+ },
807
+ mode: ['pc', 'mobile-first'],
808
+ pcDemo: 'events',
809
+ mfDemo: 'events'
810
+ }
811
+ ],
812
+ methods: [
813
+ {
814
+ name: 'blur',
815
+ type: '() => void',
816
+ defaultValue: '',
817
+ desc: {
818
+ 'zh-CN': '使输入框失去焦点',
819
+ 'en-US': 'Causes the input box to lose focus'
820
+ },
821
+ mode: ['pc', 'mobile-first'],
822
+ pcDemo: 'manual-focus-blur',
823
+ mfDemo: 'manual-focus-blur'
824
+ },
825
+ {
826
+ name: 'focus',
827
+ type: '() => void',
828
+ defaultValue: '',
829
+ desc: {
830
+ 'zh-CN': '使输入框获取焦点',
831
+ 'en-US': 'Bring the input box to focus'
832
+ },
833
+ mode: ['pc', 'mobile-first'],
834
+ pcDemo: 'manual-focus-blur',
835
+ mfDemo: 'manual-focus-blur'
836
+ }
837
+ ],
838
+ slots: [
839
+ {
840
+ name: 'default',
841
+ type: '',
842
+ defaultValue: '',
843
+ desc: {
844
+ 'zh-CN': '选项默认插槽',
845
+ 'en-US': 'Option default slot'
846
+ },
847
+ mode: ['pc', 'mobile-first'],
848
+ pcDemo: 'slot-default',
849
+ mfDemo: 'slot-default'
850
+ },
851
+ {
852
+ name: 'empty',
853
+ type: '',
854
+ defaultValue: '',
855
+ desc: {
856
+ 'zh-CN': '空数据插槽',
857
+ 'en-US': 'Empty data slot'
858
+ },
859
+ mode: ['pc', 'mobile-first'],
860
+ pcDemo: 'slot-empty',
861
+ mfDemo: 'slot-empty'
862
+ },
863
+ {
864
+ name: 'footer',
865
+ type: '',
866
+ defaultValue: '',
867
+ desc: {
868
+ 'zh-CN': '下拉弹框底部插槽',
869
+ 'en-US': 'Pull down the bottom slot of the pop-up box'
870
+ },
871
+ mode: ['pc', 'mobile-first'],
872
+ pcDemo: 'slot-header-footer',
873
+ mfDemo: 'slot-footer'
874
+ },
875
+ {
876
+ name: 'dropdown',
877
+ type: '',
878
+ defaultValue: '',
879
+ desc: {
880
+ 'zh-CN': '下拉弹框顶部插槽',
881
+ 'en-US': 'Pull down the pop-up box slot'
882
+ },
883
+ mode: ['pc', 'mobile-first'],
884
+ pcDemo: 'slot-header-footer'
885
+ },
886
+ {
887
+ name: 'prefix',
888
+ type: '',
889
+ defaultValue: '',
890
+ desc: {
891
+ 'zh-CN': '输入框前缀插槽',
892
+ 'en-US': 'Input box prefix slot'
893
+ },
894
+ mode: ['pc', 'mobile-first'],
895
+ pcDemo: 'slot-prefix',
896
+ mfDemo: 'slot-prefix'
897
+ },
898
+ {
899
+ name: 'reference',
900
+ type: '',
901
+ defaultValue: '',
902
+ desc: {
903
+ 'zh-CN': '触发源插槽',
904
+ 'en-US': 'Trigger Source Slot'
905
+ },
906
+ mode: ['pc', 'mobile-first'],
907
+ pcDemo: 'slot-reference',
908
+ mfDemo: 'slot-reference'
909
+ }
910
+ ]
911
+ },
912
+ {
913
+ name: 'option',
914
+ type: 'component',
915
+ props: [
916
+ {
917
+ name: 'disabled',
918
+ type: 'boolean',
919
+ defaultValue: 'false',
920
+ desc: {
921
+ 'zh-CN': '选项是否禁用',
922
+ 'en-US': 'Is the option disabled'
923
+ },
924
+ mode: ['pc', 'mobile-first'],
925
+ pcDemo: 'disabled',
926
+ mfDemo: 'disabled'
927
+ },
928
+ {
929
+ name: 'icon',
930
+ type: 'Component',
931
+ defaultValue: '',
932
+ desc: {
933
+ 'zh-CN': '自定义选项的图标',
934
+ 'en-US': 'Customize icons for options'
935
+ },
936
+ mode: ['pc', 'mobile-first'],
937
+ pcDemo: 'basic-usage',
938
+ mfDemo: 'basic-usage'
939
+ },
940
+ {
941
+ name: 'label',
942
+ type: 'string',
943
+ defaultValue: '',
944
+ desc: {
945
+ 'zh-CN': '选项的显示文本',
946
+ 'en-US': 'Display text for option'
947
+ },
948
+ mode: ['pc', 'mobile-first'],
949
+ pcDemo: 'basic-usage',
950
+ mfDemo: 'basic-usage'
951
+ },
952
+ {
953
+ name: 'required',
954
+ type: 'boolean',
955
+ defaultValue: 'false',
956
+ desc: {
957
+ 'zh-CN': '选项是否必选',
958
+ 'en-US': 'Is it mandatory to select an option'
959
+ },
960
+ mode: ['pc', 'mobile-first'],
961
+ pcDemo: '',
962
+ mfDemo: ''
963
+ },
964
+ {
965
+ name: 'value',
966
+ type: 'string',
967
+ defaultValue: '',
968
+ desc: {
969
+ 'zh-CN': '选项的值',
970
+ 'en-US': 'Value for option'
971
+ },
972
+ mode: ['pc', 'mobile-first'],
973
+ pcDemo: 'basic-usage',
974
+ mfDemo: 'basic-usage'
975
+ }
976
+ ],
977
+ events: [],
978
+ methods: [],
979
+ slots: []
980
+ }
981
+ ],
982
+ types: [
983
+ {
984
+ name: 'IOption',
985
+ type: 'interface',
986
+ code: `
987
+ interface IOption {
988
+ value?: string | number
989
+ label?: string
990
+ disabled?: boolean
991
+ icon?: Component
992
+ required?:boolean
993
+ }
994
+ `
995
+ },
996
+ {
997
+ name: 'ICacheOp',
998
+ type: 'interface',
999
+ code: `
1000
+ interface ICacheItem {
1001
+ frequency: number
1002
+ key: string
1003
+ time: number
1004
+ }
1005
+
1006
+ interface ICacheOp {
1007
+ key: string // 本地缓存的唯一 key 值
1008
+ sortBy?: 'frequency' | 'time' // 排序的字段,默认 frequency (频次)
1009
+ sort?: 'desc' | 'asc' // 排序方式,默认 desc (降序)
1010
+ dataKey?: string // 数据中的唯一标识的 key 名称,默认 value
1011
+ highlightClass?: string // 个性化高亮 class 名称,默认:memorize-highlight
1012
+ highlightNum?: number // 高亮个性化的条数,默认:Infinity
1013
+ cacheNum?: number // 存储个性化的条数,默认:Infinity
1014
+ serialize?: () => string // 本地存储序列化方法,默认:JSON.stringify
1015
+ deserialize?: () => ICacheItem[] // 本地存储序反列化方法,默认:JSON.parse
1016
+ }
1017
+ `
1018
+ },
1019
+ {
1020
+ name: 'IGridOption',
1021
+ type: 'interface',
1022
+ code: `
1023
+ interface IGridOption {
1024
+ data: any[] // 表格数据,用法同 Grid
1025
+ columns: any[] // 列配置,用法同 Grid
1026
+ }
1027
+ `
1028
+ },
1029
+ {
1030
+ name: 'ITreeOption',
1031
+ type: 'interface',
1032
+ code: `
1033
+ interface ITreeNode {
1034
+ label: string // 默认树节点的文本字段
1035
+ id: number|string // 树节点唯一标识
1036
+ children: ITreeNode[] // 子节点
1037
+ }
1038
+
1039
+ interface ITreeOption {
1040
+ data: ITreeNode[] // 树数据,用法同 Tree
1041
+ }
1042
+ `
1043
+ },
1044
+ {
1045
+ name: 'IPlacement',
1046
+ type: 'type',
1047
+ code: `
1048
+ type IPlacement = 'top' | 'top-start' | 'top-end' | 'bottom' | 'bottom-start' | 'bottom-end' | 'left' | 'left-start' | 'left-end' | 'right' | 'right-start' | 'right-end'
1049
+ `
1050
+ },
1051
+ {
1052
+ name: 'IPopperOption',
1053
+ type: 'interface',
1054
+ code: `
1055
+ interface IPopperOption {
1056
+ bubbling: boolean // 是否监听元素所有上级有滚动元素的scroll事件,监听到则更新popper的位置。用于解决某些弹出层位置在页面滚动时,位置不正确的场景,默认false
1057
+ followReferenceHide: boolean // 当触发源隐藏时,自动隐藏弹出层,默认true
1058
+ removeOnDestroy: boolean // 弹出层消失后,是否移除弹出层的DOM元素,布尔false
1059
+ updateHiddenPopperOnScroll: boolean // 滚动过程中是否更新隐藏的弹出层位置
1060
+ boundariesElement: 'viewport' | 'body' | HTMLElement // 滚动过程中,弹出层的碰撞边界。 默认值为: 'viewport'
1061
+ ignoreBoundaries: boolean // 忽略边界判断,弹出的位置始终是设置的 placement 值
1062
+ scrollParent: HTMLElement // 指定滚动的父节点,优化级最高。 默认为null
1063
+ }
1064
+ `
1065
+ }
1066
+ ]
1067
+ }