@king-design/intact 2.0.0-beta.1 → 2.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (544) hide show
  1. package/README.md +20 -118
  2. package/components/affix/demos/basic.md +2 -1
  3. package/components/affix/demos/custom.md +5 -5
  4. package/components/affix/index.md +2 -2
  5. package/components/affix/styles.ts +1 -1
  6. package/components/badge/demos/text.md +1 -1
  7. package/components/badge/index.md +3 -3
  8. package/components/badge/styles.ts +1 -1
  9. package/components/breadcrumb/demos/basic.md +1 -1
  10. package/components/breadcrumb/index.md +3 -10
  11. package/components/breadcrumb/item.ts +4 -14
  12. package/components/breadcrumb/styles.ts +9 -5
  13. package/components/button/demos/group.md +2 -2
  14. package/components/button/demos/icon.md +1 -0
  15. package/components/button/demos/loading.md +1 -1
  16. package/components/button/demos/tagName.md +0 -1
  17. package/components/button/index.md +13 -13
  18. package/components/button/index.vdt +32 -23
  19. package/components/button/styles.ts +22 -12
  20. package/components/card/demos/basic.md +4 -4
  21. package/components/card/demos/extra.md +13 -7
  22. package/components/card/demos/noHeader.md +4 -4
  23. package/components/card/index.md +3 -3
  24. package/components/card/styles.ts +2 -2
  25. package/components/carousel/index.md +4 -4
  26. package/components/carousel/styles.ts +2 -2
  27. package/components/carousel/useSlide.ts +3 -2
  28. package/components/cascader/demos/loadData.md +1 -1
  29. package/components/cascader/index.md +45 -16
  30. package/components/cascader/index.spec.ts +60 -1
  31. package/components/cascader/index.vdt +4 -4
  32. package/components/cascader/styles.ts +1 -1
  33. package/components/cascader/useLabel.ts +9 -9
  34. package/components/checkbox/demos/basic.md +1 -1
  35. package/components/checkbox/demos/indeterminate.md +4 -20
  36. package/components/checkbox/demos/value.md +1 -1
  37. package/components/checkbox/index.md +10 -10
  38. package/components/checkbox/index.vdt +16 -13
  39. package/components/checkbox/styles.ts +3 -7
  40. package/components/code/demos/basic.md +3 -3
  41. package/components/code/index.md +8 -10
  42. package/components/collapse/index.md +8 -8
  43. package/components/collapse/item.vdt +1 -1
  44. package/components/collapse/styles.ts +4 -3
  45. package/components/colorpicker/index.md +3 -3
  46. package/components/colorpicker/index.spec.ts +1 -1
  47. package/components/colorpicker/index.ts +3 -0
  48. package/components/colorpicker/index.vdt +5 -1
  49. package/components/colorpicker/styles.ts +1 -1
  50. package/components/context.ts +14 -7
  51. package/components/datepicker/demos/disabledDate.md +0 -2
  52. package/components/datepicker/demos/format.md +1 -1
  53. package/components/datepicker/demos/shortcuts.md +2 -2
  54. package/components/datepicker/helpers.ts +9 -2
  55. package/components/datepicker/index.md +50 -27
  56. package/components/datepicker/index.spec.ts +1 -1
  57. package/components/datepicker/index.vdt +7 -6
  58. package/components/datepicker/styles.ts +1 -1
  59. package/components/diagram/index.md +108 -59
  60. package/components/diagram/shapes/line.ts +2 -3
  61. package/components/dialog/base.ts +2 -1
  62. package/components/dialog/demos/block.md +10 -56
  63. package/components/dialog/demos/size.md +1 -1
  64. package/components/dialog/index.md +47 -56
  65. package/components/dialog/index.spec.ts +2 -18
  66. package/components/dialog/styles.ts +4 -3
  67. package/components/dialog/useFixBody.ts +16 -0
  68. package/components/drawer/index.md +23 -20
  69. package/components/drawer/index.spec.ts +5 -5
  70. package/components/drawer/styles.ts +2 -2
  71. package/components/dropdown/demos/basic.md +4 -16
  72. package/components/dropdown/demos/contextmenu.md +1 -7
  73. package/components/dropdown/demos/disabled.md +1 -1
  74. package/components/dropdown/demos/nested.md +2 -4
  75. package/components/dropdown/demos/position.md +5 -6
  76. package/components/dropdown/demos/trigger.md +2 -4
  77. package/components/dropdown/dropdown.ts +2 -0
  78. package/components/dropdown/index.md +26 -15
  79. package/components/dropdown/index.spec.ts +3 -3
  80. package/components/dropdown/index.ts +1 -2
  81. package/components/dropdown/styles.ts +2 -2
  82. package/components/editable/index.md +10 -15
  83. package/components/editable/index.vdt +1 -0
  84. package/components/editable/styles.ts +1 -1
  85. package/components/form/demos/basic.md +15 -15
  86. package/components/form/index.md +29 -13
  87. package/components/form/index.spec.ts +9 -9
  88. package/components/form/item.vdt +6 -1
  89. package/components/form/methods.ts +6 -1
  90. package/components/form/styles.ts +1 -1
  91. package/components/form/useError.ts +3 -0
  92. package/components/form/useValidate.ts +2 -2
  93. package/components/grid/col.vdt +1 -1
  94. package/components/grid/index.md +34 -13
  95. package/components/grid/styles.ts +4 -1
  96. package/components/icon/index.md +4 -2
  97. package/components/icon/index.vdt +2 -2
  98. package/components/icon/styles.ts +11 -8
  99. package/components/input/demos/blocks.md +2 -2
  100. package/components/input/demos/clearable.md +3 -3
  101. package/components/input/demos/inline.md +12 -0
  102. package/components/input/demos/size.md +0 -1
  103. package/components/input/index.md +18 -22
  104. package/components/input/index.ts +2 -0
  105. package/components/input/index.vdt +42 -33
  106. package/components/input/search.vdt +4 -1
  107. package/components/input/styles.ts +8 -12
  108. package/components/layout/demos/asideFix.md +2 -3
  109. package/components/layout/index.md +5 -5
  110. package/components/layout/styles.ts +5 -4
  111. package/components/menu/demos/collapse.md +3 -1
  112. package/components/menu/index.md +11 -11
  113. package/components/menu/index.spec.ts +12 -6
  114. package/components/menu/item.ts +10 -16
  115. package/components/menu/item.vdt +3 -3
  116. package/components/menu/menu.ts +4 -0
  117. package/components/menu/styles.ts +6 -5
  118. package/components/menu/useExpanded.ts +1 -1
  119. package/components/menu/useHighlight.ts +45 -40
  120. package/components/message/index.md +23 -25
  121. package/components/message/index.spec.ts +1 -1
  122. package/components/message/styles.ts +7 -3
  123. package/components/pagination/index.md +11 -19
  124. package/components/pagination/styles.ts +2 -2
  125. package/components/progress/demos/customColor.md +1 -1
  126. package/components/progress/index.md +11 -5
  127. package/components/progress/styles.ts +2 -2
  128. package/components/radio/index.md +4 -7
  129. package/components/radio/index.vdt +15 -12
  130. package/components/radio/styles.ts +6 -10
  131. package/components/rate/index.md +5 -5
  132. package/components/rate/styles.ts +3 -2
  133. package/components/scrollSelect/index.md +14 -5
  134. package/components/scrollSelect/styles.ts +7 -2
  135. package/components/select/base.ts +0 -1
  136. package/components/select/base.vdt +128 -112
  137. package/components/select/demos/creatable.md +1 -1
  138. package/components/select/demos/customMenu.md +1 -1
  139. package/components/select/demos/format.md +3 -7
  140. package/components/select/index.md +35 -30
  141. package/components/select/index.spec.ts +1 -1
  142. package/components/select/menu.vdt +1 -0
  143. package/components/select/styles.ts +15 -9
  144. package/components/slider/demos/marks.md +2 -2
  145. package/components/slider/index.md +31 -16
  146. package/components/slider/styles.ts +5 -4
  147. package/components/spin/index.md +2 -2
  148. package/components/spin/styles.ts +1 -1
  149. package/components/spinner/index.md +23 -14
  150. package/components/spinner/index.ts +2 -2
  151. package/components/spinner/styles.ts +1 -1
  152. package/components/split/index.md +7 -7
  153. package/components/split/style.ts +2 -2
  154. package/components/steps/index.md +3 -3
  155. package/components/steps/styles.ts +3 -2
  156. package/components/switch/index.md +10 -19
  157. package/components/switch/styles.ts +5 -4
  158. package/components/table/demos/animation.md +92 -0
  159. package/components/table/demos/basic.md +1 -1
  160. package/components/table/demos/checkedKeys.md +2 -3
  161. package/components/table/demos/disableRow.md +2 -2
  162. package/components/table/demos/empty.md +1 -1
  163. package/components/table/demos/export.md +8 -7
  164. package/components/table/demos/fixColumn.md +2 -2
  165. package/components/table/demos/fixHeader.md +3 -3
  166. package/components/table/demos/group.md +3 -3
  167. package/components/table/demos/mergeCell.md +1 -1
  168. package/components/table/demos/resizable.md +1 -1
  169. package/components/table/demos/rowClassName.md +1 -1
  170. package/components/table/demos/rowExpandable.md +2 -6
  171. package/components/table/demos/sort.md +2 -1
  172. package/components/table/demos/stickHeader.md +3 -3
  173. package/components/table/demos/stickScrollbar.md +3 -3
  174. package/components/table/demos/tooltip.md +1 -2
  175. package/components/table/index.md +92 -66
  176. package/components/table/index.spec.ts +4 -1
  177. package/components/table/index.ts +1 -0
  178. package/components/table/row.vdt +5 -1
  179. package/components/table/styles.ts +17 -5
  180. package/components/table/table.ts +2 -0
  181. package/components/table/table.vdt +91 -86
  182. package/components/table/useFixedColumns.ts +5 -3
  183. package/components/table/useWidth.ts +8 -1
  184. package/components/tabs/index.md +15 -8
  185. package/components/tabs/index.spec.ts +1 -1
  186. package/components/tabs/styles.ts +11 -7
  187. package/components/tabs/tab.vdt +1 -1
  188. package/components/tabs/useActiveBar.ts +3 -2
  189. package/components/tag/base.ts +3 -0
  190. package/components/tag/demos/border.md +2 -1
  191. package/components/tag/index.md +4 -3
  192. package/components/tag/styles.ts +9 -4
  193. package/components/timeline/styles.ts +3 -3
  194. package/components/timepicker/constants.ts +3 -2
  195. package/components/timepicker/demos/basic.md +2 -2
  196. package/components/timepicker/demos/step.md +1 -1
  197. package/components/timepicker/index.md +47 -16
  198. package/components/timepicker/index.spec.ts +11 -10
  199. package/components/timepicker/styles.ts +1 -1
  200. package/components/timepicker/useStep.ts +3 -3
  201. package/components/timepicker/useValue.ts +2 -2
  202. package/components/tip/demos/closable.md +1 -1
  203. package/components/tip/index.md +8 -4
  204. package/components/tip/styles.ts +1 -1
  205. package/components/tooltip/demos/basic.md +2 -13
  206. package/components/tooltip/demos/trigger.md +1 -2
  207. package/components/tooltip/index.md +26 -13
  208. package/components/tooltip/index.spec.ts +24 -15
  209. package/components/tooltip/styles.ts +1 -1
  210. package/components/transfer/index.md +36 -23
  211. package/components/transfer/index.spec.ts +7 -6
  212. package/components/transfer/styles.ts +3 -9
  213. package/components/tree/index.md +76 -49
  214. package/components/tree/index.spec.ts +13 -12
  215. package/components/tree/index.ts +1 -0
  216. package/components/tree/index.vdt +1 -0
  217. package/components/tree/styles.ts +7 -4
  218. package/components/treeSelect/index.md +50 -20
  219. package/components/treeSelect/index.spec.ts +5 -5
  220. package/components/treeSelect/styles.ts +3 -2
  221. package/components/upload/index.md +55 -19
  222. package/components/upload/index.spec.ts +1 -1
  223. package/components/upload/index.ts +1 -1
  224. package/components/upload/index.vdt +3 -4
  225. package/components/upload/styles.ts +5 -4
  226. package/components/utils.ts +1 -1
  227. package/components/wave/index.ts +94 -0
  228. package/components/wave/styles.ts +50 -0
  229. package/es/components/breadcrumb/item.d.ts +1 -1
  230. package/es/components/breadcrumb/item.js +3 -14
  231. package/es/components/breadcrumb/styles.js +1 -1
  232. package/es/components/button/index.vdt.js +26 -17
  233. package/es/components/button/styles.d.ts +82 -1
  234. package/es/components/button/styles.js +16 -2
  235. package/es/components/card/styles.js +1 -1
  236. package/es/components/carousel/styles.js +4 -1
  237. package/es/components/carousel/useSlide.js +10 -9
  238. package/es/components/cascader/index.spec.js +89 -1
  239. package/es/components/cascader/index.vdt.js +4 -4
  240. package/es/components/cascader/useLabel.js +8 -12
  241. package/es/components/checkbox/index.vdt.js +15 -10
  242. package/es/components/checkbox/styles.js +2 -2
  243. package/es/components/collapse/item.vdt.js +2 -1
  244. package/es/components/collapse/styles.js +5 -1
  245. package/es/components/colorpicker/index.d.ts +2 -0
  246. package/es/components/colorpicker/index.js +2 -1
  247. package/es/components/colorpicker/index.spec.js +1 -1
  248. package/es/components/colorpicker/index.vdt.js +3 -1
  249. package/es/components/context.d.ts +5 -2
  250. package/es/components/context.js +7 -4
  251. package/es/components/datepicker/helpers.d.ts +2 -1
  252. package/es/components/datepicker/helpers.js +8 -2
  253. package/es/components/datepicker/index.spec.js +1 -1
  254. package/es/components/datepicker/index.vdt.js +10 -5
  255. package/es/components/datepicker/styles.d.ts +46 -1
  256. package/es/components/diagram/shapes/generateShapes.js +3 -3
  257. package/es/components/diagram/shapes/line.d.ts +2 -2
  258. package/es/components/diagram/shapes/line.js +0 -1
  259. package/es/components/dialog/base.d.ts +2 -0
  260. package/es/components/dialog/base.js +2 -1
  261. package/es/components/dialog/index.spec.js +59 -94
  262. package/es/components/dialog/styles.js +5 -1
  263. package/es/components/dialog/useFixBody.d.ts +6 -0
  264. package/es/components/dialog/useFixBody.js +12 -0
  265. package/es/components/drawer/index.spec.js +5 -5
  266. package/es/components/drawer/styles.js +1 -1
  267. package/es/components/dropdown/dropdown.js +1 -0
  268. package/es/components/dropdown/index.js +1 -2
  269. package/es/components/dropdown/index.spec.js +3 -3
  270. package/es/components/dropdown/styles.js +1 -1
  271. package/es/components/editable/index.vdt.js +2 -1
  272. package/es/components/editable/styles.d.ts +8 -1
  273. package/es/components/form/index.spec.js +10 -12
  274. package/es/components/form/item.vdt.js +13 -9
  275. package/es/components/form/useError.d.ts +4 -0
  276. package/es/components/form/useError.js +3 -1
  277. package/es/components/form/useValidate.js +2 -2
  278. package/es/components/grid/col.vdt.js +4 -2
  279. package/es/components/grid/styles.js +1 -1
  280. package/es/components/grid/useGutter.d.ts +1 -1
  281. package/es/components/icon/index.vdt.js +3 -2
  282. package/es/components/icon/styles.js +8 -4
  283. package/es/components/input/index.d.ts +1 -0
  284. package/es/components/input/index.js +2 -1
  285. package/es/components/input/index.vdt.js +47 -32
  286. package/es/components/input/search.vdt.js +4 -2
  287. package/es/components/input/styles.js +8 -3
  288. package/es/components/layout/styles.d.ts +1 -1
  289. package/es/components/layout/styles.js +7 -3
  290. package/es/components/menu/index.spec.js +15 -8
  291. package/es/components/menu/item.d.ts +1 -2
  292. package/es/components/menu/item.js +10 -17
  293. package/es/components/menu/item.vdt.js +4 -4
  294. package/es/components/menu/menu.d.ts +3 -0
  295. package/es/components/menu/menu.js +4 -0
  296. package/es/components/menu/styles.d.ts +62 -1
  297. package/es/components/menu/styles.js +6 -2
  298. package/es/components/menu/useExpanded.d.ts +1 -4
  299. package/es/components/menu/useHighlight.d.ts +5 -8
  300. package/es/components/menu/useHighlight.js +44 -33
  301. package/es/components/message/index.spec.js +1 -1
  302. package/es/components/message/styles.js +6 -2
  303. package/es/components/pagination/styles.js +1 -1
  304. package/es/components/radio/index.vdt.js +14 -9
  305. package/es/components/radio/styles.js +9 -1
  306. package/es/components/rate/styles.js +5 -1
  307. package/es/components/scrollSelect/styles.d.ts +14 -1
  308. package/es/components/scrollSelect/styles.js +9 -1
  309. package/es/components/select/base.vdt.js +135 -121
  310. package/es/components/select/index.spec.js +1 -1
  311. package/es/components/select/menu.vdt.js +1 -0
  312. package/es/components/select/styles.js +9 -4
  313. package/es/components/select/useSearchable.d.ts +1 -1
  314. package/es/components/slider/styles.js +5 -1
  315. package/es/components/spinner/index.d.ts +1 -1
  316. package/es/components/spinner/index.js +1 -1
  317. package/es/components/split/style.js +1 -1
  318. package/es/components/steps/context.d.ts +1 -1
  319. package/es/components/steps/styles.js +5 -1
  320. package/es/components/switch/styles.js +5 -1
  321. package/es/components/table/index.d.ts +1 -0
  322. package/es/components/table/index.spec.js +2 -1
  323. package/es/components/table/row.vdt.js +12 -4
  324. package/es/components/table/styles.js +6 -1
  325. package/es/components/table/table.d.ts +1 -0
  326. package/es/components/table/table.js +2 -1
  327. package/es/components/table/table.vdt.js +30 -27
  328. package/es/components/table/useColumns.d.ts +1 -1
  329. package/es/components/table/useFixedColumns.d.ts +1 -1
  330. package/es/components/table/useFixedColumns.js +5 -2
  331. package/es/components/table/useGroup.d.ts +1 -1
  332. package/es/components/table/useResizable.d.ts +1 -1
  333. package/es/components/table/useSortable.d.ts +1 -1
  334. package/es/components/table/useWidth.js +7 -1
  335. package/es/components/tabs/index.spec.js +1 -1
  336. package/es/components/tabs/styles.js +9 -2
  337. package/es/components/tabs/tab.vdt.js +2 -1
  338. package/es/components/tabs/useActiveBar.js +6 -3
  339. package/es/components/tag/base.js +1 -0
  340. package/es/components/tag/styles.js +8 -2
  341. package/es/components/timepicker/constants.d.ts +2 -1
  342. package/es/components/timepicker/constants.js +3 -2
  343. package/es/components/timepicker/index.spec.js +36 -35
  344. package/es/components/timepicker/useStep.js +3 -3
  345. package/es/components/timepicker/useValue.js +2 -2
  346. package/es/components/tooltip/index.spec.js +32 -25
  347. package/es/components/transfer/index.spec.js +20 -19
  348. package/es/components/transfer/styles.js +2 -6
  349. package/es/components/tree/index.d.ts +1 -1
  350. package/es/components/tree/index.js +1 -1
  351. package/es/components/tree/index.spec.js +20 -19
  352. package/es/components/tree/index.vdt.js +1 -0
  353. package/es/components/tree/styles.js +5 -1
  354. package/es/components/treeSelect/index.spec.js +5 -5
  355. package/es/components/treeSelect/styles.js +5 -1
  356. package/es/components/upload/index.d.ts +1 -1
  357. package/es/components/upload/index.spec.js +1 -1
  358. package/es/components/upload/index.vdt.js +10 -11
  359. package/es/components/upload/styles.js +5 -1
  360. package/es/components/utils.d.ts +1 -1
  361. package/es/components/wave/index.d.ts +19 -0
  362. package/es/components/wave/index.js +120 -0
  363. package/es/components/wave/styles.d.ts +2 -0
  364. package/es/components/wave/styles.js +17 -0
  365. package/es/hooks/useRouter.d.ts +1 -0
  366. package/es/hooks/useRouter.js +10 -0
  367. package/es/i18n/en-US.d.ts +1 -0
  368. package/es/i18n/en-US.js +1 -0
  369. package/es/index.d.ts +3 -2
  370. package/es/index.js +3 -2
  371. package/es/packages/kpc-react/__tests__/index.js +10 -7
  372. package/es/site/data/components/affix/demos/custom/index.d.ts +2 -2
  373. package/es/site/data/components/affix/demos/custom/index.js +4 -4
  374. package/es/site/data/components/affix/demos/custom/react.d.ts +2 -2
  375. package/es/site/data/components/affix/demos/custom/react.js +6 -6
  376. package/es/site/data/components/button/demos/group/react.js +2 -2
  377. package/es/site/data/components/button/demos/icon/react.js +6 -0
  378. package/es/site/data/components/card/demos/basic/react.js +2 -2
  379. package/es/site/data/components/card/demos/extra/react.js +19 -5
  380. package/es/site/data/components/card/demos/noHeader/react.js +2 -2
  381. package/es/site/data/components/checkbox/demos/indeterminate/index.d.ts +1 -1
  382. package/es/site/data/components/checkbox/demos/indeterminate/index.js +2 -2
  383. package/es/site/data/components/checkbox/demos/indeterminate/react.d.ts +1 -1
  384. package/es/site/data/components/checkbox/demos/indeterminate/react.js +5 -6
  385. package/es/site/data/components/dialog/demos/block/react.d.ts +9 -0
  386. package/es/site/data/components/dialog/demos/block/react.js +88 -0
  387. package/es/site/data/components/dropdown/demos/basic/react.js +1 -3
  388. package/es/site/data/components/dropdown/demos/nested/react.js +1 -3
  389. package/es/site/data/components/dropdown/demos/position/react.js +2 -7
  390. package/es/site/data/components/dropdown/demos/trigger/react.js +1 -3
  391. package/es/site/data/components/input/demos/blocks/react.js +4 -2
  392. package/es/site/data/components/input/demos/clearable/react.js +7 -5
  393. package/es/site/data/components/{dialog/demos/extends → input/demos/inline}/index.d.ts +0 -3
  394. package/es/site/data/components/input/demos/inline/index.js +17 -0
  395. package/es/site/data/components/input/demos/inline/react.d.ts +4 -0
  396. package/es/site/data/components/input/demos/inline/react.js +24 -0
  397. package/es/site/data/components/input/demos/size/react.js +0 -3
  398. package/es/site/data/components/layout/demos/asideFix/react.js +2 -1
  399. package/es/site/data/components/menu/demos/collapse/index.js +1 -0
  400. package/es/site/data/components/menu/demos/collapse/react.js +7 -0
  401. package/es/site/data/components/select/demos/creatable/react.js +1 -1
  402. package/es/site/data/components/select/demos/customMenu/react.js +1 -0
  403. package/es/site/data/components/select/demos/format/react.js +11 -18
  404. package/es/site/data/components/table/demos/animation/index.d.ts +23 -0
  405. package/es/site/data/components/table/demos/animation/index.js +78 -0
  406. package/es/site/data/components/table/demos/animation/react.d.ts +23 -0
  407. package/es/site/data/components/table/demos/animation/react.js +113 -0
  408. package/es/site/data/components/table/demos/export/react.js +1 -2
  409. package/es/site/data/components/table/demos/sort/react.js +4 -1
  410. package/es/site/data/components/tag/demos/border/react.js +3 -1
  411. package/es/site/data/components/tip/demos/closable/react.js +1 -0
  412. package/es/site/data/components/tooltip/demos/trigger/react.js +1 -2
  413. package/es/site/data/docs/design/{button → about}/index.d.ts +13 -11
  414. package/es/site/data/docs/design/{8point → about}/index.js +0 -0
  415. package/es/site/data/docs/design/{dialog → guide-1}/index.d.ts +15 -11
  416. package/es/site/data/docs/design/{button → guide-1}/index.js +0 -0
  417. package/es/site/data/docs/design/guide-2/index.d.ts +64 -0
  418. package/es/site/data/docs/design/{color → guide-2}/index.js +0 -0
  419. package/es/site/data/docs/design/guide-3/index.d.ts +64 -0
  420. package/es/site/data/docs/design/{dialog → guide-3}/index.js +0 -0
  421. package/es/site/data/docs/design/guide-4/index.d.ts +64 -0
  422. package/es/site/data/docs/design/{font → guide-4}/index.js +0 -0
  423. package/es/site/data/docs/design/guide-5/index.d.ts +64 -0
  424. package/es/site/data/docs/design/{format → guide-5}/index.js +0 -0
  425. package/es/site/data/docs/design/guide-6/index.d.ts +64 -0
  426. package/es/site/data/docs/design/{gutter → guide-6}/index.js +0 -0
  427. package/es/site/data/docs/design/guide-7/index.d.ts +64 -0
  428. package/es/site/data/docs/design/{hierarchy → guide-7}/index.js +0 -0
  429. package/es/site/data/docs/design/guide-8/index.d.ts +64 -0
  430. package/es/site/data/docs/design/{language → guide-8}/index.js +0 -0
  431. package/es/site/data/docs/design/guide-9/index.d.ts +64 -0
  432. package/es/site/data/docs/design/{navigator → guide-9}/index.js +0 -0
  433. package/es/site/data/docs/design/model/index.d.ts +64 -0
  434. package/es/site/data/docs/design/{tip → model}/index.js +0 -0
  435. package/es/site/data/docs/design/model-1/index.d.ts +64 -0
  436. package/es/site/data/docs/design/{text → model-1}/index.js +0 -0
  437. package/es/site/data/docs/design/pattern-1/index.d.ts +64 -0
  438. package/es/site/data/docs/design/pattern-1/index.js +42 -0
  439. package/es/site/data/docs/design/pattern-2/index.d.ts +64 -0
  440. package/es/site/data/docs/design/pattern-2/index.js +42 -0
  441. package/es/site/data/docs/design/pattern-3/index.d.ts +64 -0
  442. package/es/site/data/docs/design/pattern-3/index.js +42 -0
  443. package/es/site/data/docs/design/pattern-4/index.d.ts +64 -0
  444. package/es/site/data/docs/design/pattern-4/index.js +42 -0
  445. package/es/site/data/docs/design/pattern-5/index.d.ts +64 -0
  446. package/es/site/data/docs/design/pattern-5/index.js +42 -0
  447. package/es/site/data/docs/design/pattern-6/index.d.ts +64 -0
  448. package/es/site/data/docs/design/pattern-6/index.js +42 -0
  449. package/es/site/data/docs/design/{navigator → principle}/index.d.ts +13 -11
  450. package/es/site/data/docs/design/principle/index.js +42 -0
  451. package/es/site/data/docs/design/{tip → value}/index.d.ts +13 -11
  452. package/es/site/data/docs/design/value/index.js +42 -0
  453. package/es/site/data/docs/theme/index.d.ts +0 -2
  454. package/es/site/src/client.js +4 -1
  455. package/es/site/src/components/ImgBox/index.d.ts +21 -0
  456. package/es/site/src/components/ImgBox/index.js +69 -0
  457. package/es/site/src/{pages/designdoc → components/ImgBox}/styles.d.ts +0 -0
  458. package/es/site/src/components/ImgBox/styles.js +13 -0
  459. package/es/site/src/components/WorkflowCard/styles.js +3 -10
  460. package/es/site/src/components/article/index.d.ts +4 -1
  461. package/es/site/src/components/article/index.js +72 -6
  462. package/es/site/src/components/blockquote/index.d.ts +4 -0
  463. package/es/site/src/components/blockquote/index.js +13 -0
  464. package/es/site/src/components/blockquote/slot.d.ts +11 -0
  465. package/es/site/src/components/blockquote/slot.js +19 -0
  466. package/es/site/src/components/card/index.d.ts +1 -1
  467. package/es/site/src/components/card/index.js +4 -1
  468. package/es/site/src/components/card/styles.js +2 -10
  469. package/es/site/src/components/catalogue/index.js +2 -2
  470. package/es/site/src/components/catalogue/styles.js +1 -1
  471. package/es/site/src/components/footer/styles.js +2 -2
  472. package/es/site/src/components/link/index.d.ts +1 -0
  473. package/es/site/src/components/link/index.js +11 -3
  474. package/es/site/src/pages/design/index.d.ts +1 -0
  475. package/es/site/src/pages/design/index.js +19 -0
  476. package/es/site/src/pages/design/styles.d.ts +1 -0
  477. package/es/site/src/pages/design/styles.js +13 -0
  478. package/es/site/src/pages/document/index.d.ts +4 -2
  479. package/es/site/src/pages/document/index.js +89 -46
  480. package/es/site/src/pages/document/styles.js +1 -1
  481. package/es/site/src/pages/iframe/button/styles.js +4 -4
  482. package/es/site/src/pages/iframe/colorProcess/index.d.ts +1 -0
  483. package/es/site/src/pages/iframe/colorProcess/index.js +9 -5
  484. package/es/site/src/pages/iframe/colorProcess/styles.js +1 -1
  485. package/es/site/src/pages/index/BestPractice/index.d.ts +1 -0
  486. package/es/site/src/pages/index/BestPractice/index.js +14 -14
  487. package/es/site/src/pages/index/BestPractice/styles.d.ts +1 -1
  488. package/es/site/src/pages/index/BestPractice/styles.js +3 -3
  489. package/es/site/src/pages/index/ColorProcess/styles.d.ts +1 -1
  490. package/es/site/src/pages/index/ColorProcess/styles.js +14 -2
  491. package/es/site/src/pages/index/KingVersion/styles.js +1 -1
  492. package/es/site/src/pages/index/NewFunction/index.d.ts +1 -0
  493. package/es/site/src/pages/index/NewFunction/index.js +4 -2
  494. package/es/site/src/pages/index/NewFunction/styles.d.ts +1 -1
  495. package/es/site/src/pages/index/NewFunction/styles.js +4 -3
  496. package/es/site/src/pages/index/index.d.ts +2 -7
  497. package/es/site/src/pages/index/index.js +11 -8
  498. package/es/site/src/pages/index/styles.js +2 -4
  499. package/es/site/src/pages/layout.d.ts +2 -0
  500. package/es/site/src/pages/layout.js +33 -4
  501. package/es/site/src/pages/resource/index.d.ts +6 -0
  502. package/es/site/src/pages/resource/index.js +21 -1
  503. package/es/site/src/pages/resource/styles.js +5 -3
  504. package/es/site/src/pages/solution/index.d.ts +6 -0
  505. package/es/site/src/pages/solution/index.js +19 -1
  506. package/es/site/src/pages/solution/styles.js +3 -2
  507. package/es/site/src/pages/styles.d.ts +1 -0
  508. package/es/site/src/pages/styles.js +5 -2
  509. package/es/site/src/router/index.d.ts +1 -0
  510. package/es/site/src/router/index.js +327 -318
  511. package/es/site/src/styles/default.d.ts +1 -0
  512. package/es/site/src/styles/default.js +3 -2
  513. package/es/styles/global.js +4 -3
  514. package/es/styles/theme.d.ts +16 -7
  515. package/es/styles/theme.js +15 -7
  516. package/hooks/useRouter.ts +11 -0
  517. package/i18n/en-US.ts +1 -0
  518. package/index.ts +3 -2
  519. package/package.json +6 -6
  520. package/styles/global.ts +41 -8
  521. package/styles/theme.ts +12 -8
  522. package/typings/global.d.ts +2 -0
  523. package/components/dialog/demos/asyncOpen.md +0 -111
  524. package/components/dialog/demos/extends.md +0 -87
  525. package/es/site/data/components/dialog/demos/asyncOpen/dialog.d.ts +0 -28
  526. package/es/site/data/components/dialog/demos/asyncOpen/dialog.js +0 -45
  527. package/es/site/data/components/dialog/demos/asyncOpen/index.d.ts +0 -13
  528. package/es/site/data/components/dialog/demos/asyncOpen/index.js +0 -58
  529. package/es/site/data/components/dialog/demos/extends/dialog.d.ts +0 -28
  530. package/es/site/data/components/dialog/demos/extends/dialog.js +0 -39
  531. package/es/site/data/components/dialog/demos/extends/index.js +0 -49
  532. package/es/site/data/docs/design/8point/index.d.ts +0 -58
  533. package/es/site/data/docs/design/color/demos/demos0/index.d.ts +0 -3
  534. package/es/site/data/docs/design/color/demos/demos0/index.js +0 -3
  535. package/es/site/data/docs/design/color/index.d.ts +0 -56
  536. package/es/site/data/docs/design/font/index.d.ts +0 -58
  537. package/es/site/data/docs/design/format/index.d.ts +0 -58
  538. package/es/site/data/docs/design/gutter/index.d.ts +0 -58
  539. package/es/site/data/docs/design/hierarchy/index.d.ts +0 -58
  540. package/es/site/data/docs/design/language/index.d.ts +0 -56
  541. package/es/site/data/docs/design/text/index.d.ts +0 -58
  542. package/es/site/src/pages/designdoc/index.d.ts +0 -11
  543. package/es/site/src/pages/designdoc/index.js +0 -21
  544. package/es/site/src/pages/designdoc/styles.js +0 -6
@@ -11,12 +11,12 @@ import {Card} from 'kpc';
11
11
 
12
12
  <div>
13
13
  <Card title="用户信息">
14
- <div>11111</div>
15
- <div>11111</div>
14
+ <div>卡片内容</div>
15
+ <div>卡片内容</div>
16
16
  </Card>
17
17
  <Card title="用户信息" type="border">
18
- <div>11111</div>
19
- <div>11111</div>
18
+ <div>卡片内容</div>
19
+ <div>卡片内容</div>
20
20
  </Card>
21
21
  </div>
22
22
  ```
@@ -6,22 +6,28 @@ order: 2
6
6
  使用`extra`扩展点,可以在头部右侧追加内容
7
7
 
8
8
  ```vdt
9
- import {Card} from 'kpc';
9
+ import {Card, Tabs, Tab} from 'kpc';
10
10
 
11
11
  <div>
12
12
  <Card title="用户信息">
13
13
  <b:extra>
14
- 数据继承
14
+ <Tabs value="1" size="small">
15
+ <Tab value="1">数据集成</Tab>
16
+ <Tab value="2">数据采集</Tab>
17
+ </Tabs>
15
18
  </b:extra>
16
- <div>11111</div>
17
- <div>11111</div>
19
+ <div>卡片内容</div>
20
+ <div>卡片内容</div>
18
21
  </Card>
19
22
  <Card title="用户信息" type="border">
20
23
  <b:extra>
21
- 数据采集
24
+ <Tabs value="1" size="small">
25
+ <Tab value="1">数据集成</Tab>
26
+ <Tab value="2">数据采集</Tab>
27
+ </Tabs>
22
28
  </b:extra>
23
- <div>11111</div>
24
- <div>11111</div>
29
+ <div>卡片内容</div>
30
+ <div>卡片内容</div>
25
31
  </Card>
26
32
  </div>
27
33
  ```
@@ -10,12 +10,12 @@ import {Card} from 'kpc';
10
10
 
11
11
  <div>
12
12
  <Card>
13
- <div>11111</div>
14
- <div>11111</div>
13
+ <div>卡片内容</div>
14
+ <div>卡片内容</div>
15
15
  </Card>
16
16
  <Card type="border">
17
- <div>11111</div>
18
- <div>11111</div>
17
+ <div>卡片内容</div>
18
+ <div>卡片内容</div>
19
19
  </Card>
20
20
  </div>
21
21
  ```
@@ -11,15 +11,15 @@ sidebar: doc
11
11
 
12
12
  | 属性 | 说明 | 类型 | 默认值 |
13
13
  | --- | --- | --- | --- |
14
- | title | 卡片标题 | `String` &#124; `VNode` | `undefined` |
14
+ | title | 卡片标题 | `string` &#124; `VNode` | `undefined` |
15
15
  | type | 卡片类型 | `"shadow"` &#124; `"border"` &#124; `"none"` | `"shadow"` |
16
16
 
17
17
  ## CardColumn
18
18
 
19
19
  | 属性 | 说明 | 类型 | 默认值 |
20
20
  | --- | --- | --- | --- |
21
- | width | 列宽,必须带单位 | `String` | `undefined` |
22
- | center | 该列内容是否居中 | `Boolean` | `false` |
21
+ | width | 列宽,必须带单位 | `string` | `undefined` |
22
+ | center | 该列内容是否居中 | `boolean` | `false` |
23
23
 
24
24
  # 扩展点
25
25
 
@@ -6,13 +6,13 @@ import '../../styles/global';
6
6
  const defaults = {
7
7
  border: '1px solid #e5e5e5',
8
8
  padding: '16px',
9
- boxShadow: '0 0 20px 0 rgba(0, 0, 0, .06)',
9
+ boxShadow: '0 0 8px 0 rgba(0, 0, 0, .05)',
10
10
  headerHeight: '48px',
11
11
  headerFontSize: '14px',
12
12
  bgColor: '#fff',
13
13
  };
14
14
 
15
- let card: any;
15
+ let card: typeof defaults;
16
16
  setDefault(() => {
17
17
  card = deepDefaults(theme, {card: defaults}).card;
18
18
  });
@@ -11,14 +11,14 @@ sidebar: doc
11
11
 
12
12
  | 属性 | 说明 | 类型 | 默认值 |
13
13
  | --- | --- | --- | --- |
14
- | value | 当前展示的内容块对应的的值 | `String` | `"$0"` |
15
- | autoplay | 是否自动切换,如果指定数值,则表示切换的时间间隔(ms),为`0`则不自动切换 | `Boolean` &#124; `Number` | `false` |
14
+ | value | 当前展示的内容块对应的的值 | `string` | `"$0"` |
15
+ | autoplay | 是否自动切换,如果指定数值,则表示切换的时间间隔(ms),为`0`则不自动切换 | `boolean` &#124; `number` | `false` |
16
16
  | arrow | 左右快速切换箭头展示的方式,`hover`:鼠标移入展示;`always`:一直展示;`never`:不展示 | `"hover"` &#124; `"always"` &#124; `"never"` | `"hover"` |
17
17
  | effect | 指定切换动画 | `"slide"` &#124; `"fade"` | `"slide"` |
18
- | clonedAmount | 指定前后克隆的内容块数量 | `Number` | `1` |
18
+ | clonedAmount | 指定前后克隆的内容块数量 | `number` | `1` |
19
19
 
20
20
  ## CarouselItem
21
21
 
22
22
  | 属性 | 说明 | 类型 | 默认值 |
23
23
  | --- | --- | --- | --- |
24
- | value | 定义内容块选中后的值 | `String` | `"${index}"` |
24
+ | value | 定义内容块选中后的值 | `string` | `"${index}"` |
@@ -4,7 +4,7 @@ import {deepDefaults} from '../../styles/utils';
4
4
  import '../../styles/global';
5
5
 
6
6
  const defaults = {
7
- transition: `.5s ease`,
7
+ get transition() { return theme.transition.large },
8
8
  height: `300px`,
9
9
 
10
10
  indicator: {
@@ -34,7 +34,7 @@ const defaults = {
34
34
  }
35
35
  };
36
36
 
37
- let carousel: any;
37
+ let carousel: typeof defaults;
38
38
  setDefault(() => {
39
39
  carousel = deepDefaults(theme, {carousel: defaults}).carousel;
40
40
  });
@@ -70,9 +70,10 @@ export function useSlide(
70
70
  if (oldIndex === length - 1 && newIndex === 0) {
71
71
  // the current item is the last one and the next item is the first one,
72
72
  // we set translate to the first cloned item immediately without transition
73
- await setTranslate(itemsWithCloned[0], false);
73
+ await setTranslate(itemsWithCloned[(itemsWithCloned.length - length) / 2 - 1], false);
74
74
  } else if (oldIndex === 0 && newIndex === length - 1) {
75
- await setTranslate(itemsWithCloned[itemsWithCloned.length - 1], false);
75
+ const lengthWithCloned = itemsWithCloned.length;
76
+ await setTranslate(itemsWithCloned[lengthWithCloned - (lengthWithCloned - length) / 2], false);
76
77
  }
77
78
  }
78
79
 
@@ -4,7 +4,7 @@ order: 7
4
4
  ---
5
5
 
6
6
  如果数据项中的`children`属性为空数组`[]`,则代表该项子数据为动态加载的,此时可以指定`loadData`
7
- 属性来定义动态加载的逻辑,组件会将当前展开项的数据当做参数`item`传入,你只需要更新`item`的`children`
7
+ 属性来定义动态加载的逻辑,组件会将当前展开项的数据当做参数`data`传入,你只需要更新`data`的`children`
8
8
  属性即可,该函数的返回值为`Promise`对象
9
9
 
10
10
  组件默认遇到`children`为`[]`空数组的情况就会去进行异步加载,你可以通过`loaded`属性设为`true`来
@@ -9,26 +9,55 @@ sidebar: doc
9
9
 
10
10
  | 属性 | 说明 | 类型 | 默认值 |
11
11
  | --- | --- | --- | --- |
12
- | data | 组件要展示的数据 | `Array` | `undefined` |
13
- | value | 组件当前的值,可使用`v-model`双向绑定 | `*` | `""` |
14
- | changeOnSelect | 是否选中父级即改变`value`值 | `Boolean` | `false` |
15
- | trigger | 子菜单触发方式,默认点击触发 | `"click"` &#124; `"hover"` | `"click"` |
16
- | format | 自定义结果显示,组件会将当前选择的所有数据项以数组的格式作为参数传入 | `Function` | `(values) => values.map(value => value.label).join(' / ')` |
17
- | keywords | 如果支持筛选,当前关键词 | `String` | `undefined` |
18
- | filterable | 是否可搜索,默认根据`label`进行搜索 | `Boolean` | `false` |
19
- | filter | 如果可搜索,你可以传入`filter`改变搜索逻辑,组件会将搜索关键词和数据项作为参数传入 | `Function` | `(keywords, props) => props.label.indexOf(keywords) > -1` |
20
- | loadData | 如果`data`中的`children`属性值为空数组`[]`,则可以使用该属性定义动态加载逻辑,组件会将当前选中的数据项作为参数传入 | `Function` | `(item) => {}` |
21
- | disabled | 是否禁用 | `Boolean` | `false` |
22
- | clearable | 是否可清空 | `Boolean` | `false` |
12
+ | value | 当前选择的元素,可用`v-model`双向绑定 | `any` | `""` |
13
+ | multiple | 是否支持多选 | `boolean` | `false` |
14
+ | filterable | 是否支持筛选 | `boolean` | `false` |
15
+ | loading | 数据加载状态 | `boolean` | `false` |
16
+ | disabled | 是否禁用 | `boolean` | `false` |
17
+ | name | 表单元素的`name` | `string` | `undefined` |
23
18
  | size | 尺寸 | `"large"` &#124; `"default"` &#124; `"small"` &#124; `"mini"` | `"default"` |
24
- | fluid | 是否宽度100% | `Boolean` | `false` |
25
- | width | 指定宽度 | `Number` | `undefined` |
26
- | placeholder | 占位文案 | `String` | `"请选择"` |
27
- | loading | 数据加载状态 | `Boolean` | `false` |
19
+ | hideIcon | 是否隐藏后面的图标 | `boolean` | `false` |
20
+ | clearable | 是否可清空 | `boolean` | `false` |
21
+ | fluid | 是否宽度100% | `boolean` | `false` |
22
+ | inline | 展示内联模式,该模式下,组件没有边框,宽度和高度如同内联元素一样由内容撑开 | `boolean` | `false` |
23
+ | placeholder | 占位文案 | `string` | `"请选择"` |
24
+ | container | 指定弹出菜单追加的位置,默认:`Dialog`类型的组件会追加到`Dialog`中,其他会追加到`body`中。你可以传入函数返回一个DOM用来作为插入的容器,或者传入字符串用来给`querySelector`进行查询 | `Container` | `undefined` |
25
+ | width | 指定宽度,组件自动添加单位`px` | `number` &#124; `string` | `undefined` |
26
+ | data | 组件要展示的数据 | `CascaderData<V>[]` | `undefined` |
27
+ | trigger | 子菜单触发方式,默认点击触发 | `"click"` &#124; `"hover"` | `"click"` |
28
+ | changeOnSelect | 是否选中父级即改变`value`值 | `boolean` | `false` |
29
+ | format | 自定义结果显示,组件会将当前选择的所有数据项以数组的格式作为参数传入 | `Function` | `(values: string[]) => values.map(value => value.label).join(' / ')` |
30
+ | loadData | 如果`data`中的`children`属性值为空数组`[]`,则可以使用该属性定义动态加载逻辑,组件会将当前选中的数据项作为参数传入 | `(data: CascaderData<V>) => any` | `undefined` |
31
+ | filter | 如果可搜索,你可以传入`filter`改变搜索逻辑,组件会将搜索关键词和数据项作为参数传入 | `(keywords: string, data: CascaderData<V>) => boolean` | `(keywords: string, data: CascaderData<V>) => data.label.includes(keywords)` |
32
+
33
+ ```ts
34
+ export type CascaderData<V> = {
35
+ value: V
36
+ label: string
37
+ disabled?: boolean
38
+ loaded?: boolean
39
+ children?: CascaderData<V>[]
40
+ }
41
+
42
+ export type Container = string | ((parentDom: Element, anchor: Node | null) => Element)
43
+ ```
28
44
 
29
45
  # 扩展点
30
46
 
31
47
  | 名称 | 说明 | 参数 |
32
48
  | --- | --- | --- |
33
- | format | 扩展选择后展示的内容,等同于`format`属性,优先级比`format`属性高 | `values`: `Array` 当前所有已选值 |
49
+ | value | 自定义选择结果的展示 | `([value: any, label: Children]) => Children` |
50
+ | values | 自定义多选的选择结果的展示 | `([values: any[], labels: Children[]]) => Children` |
51
+ | prefix | 自定义输入框前面展示的内容 | - |
52
+ | suffix | 自定义输入框后面展示的内容 | - |
34
53
 
54
+ ```ts
55
+ import {Children} from 'intact';
56
+ ```
57
+
58
+ # 事件
59
+
60
+ | 事件名 | 说明 | 参数 |
61
+ | --- | --- | --- |
62
+ | show | 菜单弹出时触发 | - |
63
+ | hide | 菜单隐藏时触发 | - |
@@ -5,11 +5,12 @@ import LoadDataDemo from '~/components/cascader/demos/loadData';
5
5
  import FilterDemo from '~/components/cascader/demos/filterable';
6
6
  import {mount, unmount, dispatchEvent, getElement, getElements, wait} from '../../test/utils';
7
7
  import {Cascader} from './';
8
+ import {Component} from 'intact';
8
9
 
9
10
  describe('Cascader', () => {
10
11
  afterEach(async () => {
11
12
  unmount();
12
- await wait(400);
13
+ await wait(500);
13
14
  });
14
15
 
15
16
  it('basic test', async function() {
@@ -146,4 +147,62 @@ describe('Cascader', () => {
146
147
  expect(dropdown.innerHTML).to.matchSnapshot();
147
148
  expect(dropdown.innerText).to.eql('无数据');
148
149
  });
150
+
151
+ it('duplicated sub data', async () => {
152
+ class Demo extends Component {
153
+ static template = `const {Cascader} = this; <Cascader data={this.get('data')} v-model="value" />`;
154
+ static defaults() {
155
+ return {
156
+ value: ['beijing', 'haidian'],
157
+ data: [
158
+ {
159
+ value: 'beijing',
160
+ label: '北京',
161
+ children: [
162
+ {
163
+ value: 'haidian',
164
+ label: '海淀区'
165
+ },
166
+ ]
167
+ },
168
+ {
169
+ value: 'hunan',
170
+ label: '湖南',
171
+ children: [
172
+ {
173
+ value: 'haidian',
174
+ label: '海淀区'
175
+ },
176
+ ]
177
+ },
178
+ ]
179
+ }
180
+ }
181
+ private Cascader = Cascader;
182
+ }
183
+
184
+ const [instance, element] = mount(Demo);
185
+ dispatchEvent(element, 'click');
186
+ await wait();
187
+
188
+ const [dropdown1, dropdown2] = getElements('.k-cascader-menu');
189
+ const [item1, item2] = dropdown1.querySelectorAll(':scope > .k-dropdown-item');
190
+ expect(item1.classList.contains('k-selected')).to.be.true;
191
+ expect(item2.classList.contains('k-selected')).to.be.false;
192
+ const [item21] = dropdown2.querySelectorAll(':scope > .k-dropdown-item');
193
+ expect(item21.classList.contains('k-selected')).to.be.true;
194
+
195
+ dispatchEvent(item2, 'click');
196
+ await wait();
197
+
198
+ const dropdown3 = getElement('.k-cascader-menu')!;
199
+ const [item31] = dropdown3.querySelectorAll(':scope > .k-dropdown-item');
200
+ expect(item31.classList.contains('k-selected')).to.be.false;
201
+
202
+ dispatchEvent(item31, 'click');
203
+ await wait();
204
+
205
+ expect(instance.get('value')).to.eql(['hunan', 'haidian']);
206
+ expect(element.textContent).to.eql('湖南 / 海淀区');
207
+ });
149
208
  });
@@ -11,7 +11,7 @@ const classNameObj = {
11
11
  };
12
12
 
13
13
  const {values, isShowed, isSelected, onSelect, toggleShowedValue} = this.value;
14
- const Options = (data, level, loaded) => {
14
+ const Options = (data, level, loaded, parentSelected) => {
15
15
  if (!data.length) {
16
16
  if (!loaded) {
17
17
  return <Icon class="ion-load-c k-cascader-loading" rotate />
@@ -23,7 +23,7 @@ const Options = (data, level, loaded) => {
23
23
  return data.map((item, index) => {
24
24
  const value = item.value;
25
25
  const showed = isShowed(value, level);
26
- const selected = isSelected(value, level);
26
+ const selected = parentSelected && isSelected(value, level);
27
27
  const children = item.children;
28
28
 
29
29
  const Item = () => {
@@ -58,7 +58,7 @@ const Options = (data, level, loaded) => {
58
58
  >
59
59
  {Item()}
60
60
  <DropdownMenu class={classNameObj}>
61
- {showed ? Options(children, level + 1, item.loaded) : null}
61
+ {showed ? Options(children, level + 1, item.loaded, selected) : null}
62
62
  </DropdownMenu>
63
63
  </Dropdown> :
64
64
  Item()
@@ -74,7 +74,7 @@ const {filter, keywords: {value: keywords}, selectByFilter} = this.filterable;
74
74
  class={classNameObj}
75
75
  key="common"
76
76
  >
77
- {Options(data, 0, true)}
77
+ {Options(data, 0, true, true)}
78
78
  </DropdownMenu>
79
79
  <DropdownMenu v-else
80
80
  key="filter"
@@ -25,7 +25,7 @@ const defaults = {
25
25
  }
26
26
  };
27
27
 
28
- let cascader: any;
28
+ let cascader: typeof defaults;
29
29
  setDefault(() => {
30
30
  cascader = deepDefaults(theme, {cascader: defaults}).cascader;
31
31
  });
@@ -14,23 +14,23 @@ export function useLabel() {
14
14
  const {format} = instance.get();
15
15
  const labels: string[] = [];
16
16
  const length = value.length;
17
- const loop = (data: CascaderStringData[]) => {
17
+ const loop = (data: CascaderStringData[], level: number) => {
18
+ if (level === length) return;
19
+
18
20
  for (let i = 0; i < data.length; i++) {
19
21
  const item = data[i];
20
- if (value.includes(item.value)) {
22
+ if (item.value === value[level]) {
21
23
  labels.push(item.label);
22
- if (labels.length === length) {
23
- return;
24
+
25
+ const children = item.children;
26
+ if (children) {
27
+ loop(children, level + 1);
24
28
  }
25
29
  }
26
- const children = item.children;
27
- if (children) {
28
- loop(children);
29
- }
30
30
  }
31
31
  };
32
32
 
33
- loop(data);
33
+ loop(data, 0);
34
34
 
35
35
  return labels.length ? format!(labels) : null;
36
36
  }
@@ -6,7 +6,7 @@ order: 0
6
6
  `Checkbox`的基本用法,及禁用状态。通过`v-model`进行数据双向绑定。由于`trueValue`的默认值为`true`,所以可以直接传入`value=true`
7
7
  来指定选中状态。
8
8
 
9
- > 选中状态的判定条件是`value === trueValue || value.indexOf(trueValue)`,对于值为对象的情况要注意。
9
+ > 选中状态的判定条件是`value === trueValue || value.includes(trueValue)`,对于值为对象的情况要注意是否是同一引用。
10
10
 
11
11
  ```vdt
12
12
  import {Checkbox} from 'kpc';
@@ -8,12 +8,10 @@ order: 2
8
8
  ```vdt
9
9
  import {Checkbox} from 'kpc';
10
10
 
11
- const length = this.getLength();
12
-
13
11
  <div>
14
- <Checkbox indeterminate={length > 0 && length < 3}
15
- value={length === 3}
16
- ev-$change:value={this._toggleSelectAll}
12
+ <Checkbox indeterminate={this.getLength() > 0 && this.getLength() < 3}
13
+ value={this.getLength() === 3}
14
+ ev-$change:value={this.toggleSelectAll}
17
15
  >全选</Checkbox>
18
16
  <hr />
19
17
  <Checkbox v-for={this.get('options')}
@@ -50,7 +48,7 @@ export default class extends Component<Props> {
50
48
  };
51
49
 
52
50
  @bind
53
- _toggleSelectAll(checked?: boolean) {
51
+ toggleSelectAll(checked?: boolean) {
54
52
  if (checked) {
55
53
  this.set('languages', ['Javascript', 'C++', 'PHP']);
56
54
  } else {
@@ -63,17 +61,3 @@ export default class extends Component<Props> {
63
61
  }
64
62
  }
65
63
  ```
66
-
67
- ```vue-script
68
- computed: {
69
- length(): number {
70
- return this.getLength();
71
- }
72
- },
73
- ```
74
-
75
- ```angular-methods
76
- get length() {
77
- return this.getLength();
78
- }
79
- ```
@@ -8,7 +8,7 @@ order: 1
8
8
 
9
9
  > 当指定值为对象时,不要在模板中直接定义对象字面量(如:trueValue={{a: 1}}),
10
10
  > 因为在模板中创建的对象每次执行模板都会生成一份新数据,使全等判断(`===`)失效。
11
- > 此时应该在js中定义该对象,然后模板中引用它。
11
+ > 此时应该在组件中定义该对象,然后模板中引用它。
12
12
 
13
13
  ```vdt
14
14
  import {Checkbox} from 'kpc';
@@ -9,18 +9,18 @@ sidebar: doc
9
9
 
10
10
  | 属性 | 说明 | 类型 | 默认值 |
11
11
  | --- | --- | --- | --- |
12
- | disabled | 是否禁用 | `Boolean` | `false` |
13
- | name | `input`的`name`属性,用于指定Checkbox组 | `String` | `undefind` |
14
- | value | 复选框组的取值,用于`v-model`进行双向绑定 | `*` | `false` |
15
- | trueValue | 当前复选框选中的值 | `*` | `true` |
16
- | falseValue | 当前复选框取消选中的值 | `*` | `false` |
17
- | indeterminate | 是否半选中状态 | `Boolean` | `false` |
12
+ | disabled | 是否禁用 | `boolean` | `false` |
13
+ | value | 复选框组的取值,用于`v-model`进行双向绑定 | `any` | `false` |
14
+ | trueValue | 当前复选框选中的值 | `any` | `true` |
15
+ | falseValue | 当前复选框取消选中的值 | `any` | `false` |
16
+ | indeterminate | 是否半选中状态 | `boolean` | `false` |
17
+ | name | 原生`name`属性 | `string` | `undefined` |
18
+ | required | 原生`required`属性 | `boolean` | `undefined` |
19
+ | form | 原生`form`属性 | `string` | `undefined` |
20
+ | autofocus | 原生`autofocus`属性 | `boolean` | `undefined` |
18
21
 
19
22
  # 事件
20
23
 
21
24
  | 事件名 | 说明 | 参数 |
22
25
  | --- | --- | --- |
23
- | change | 当点击组件导致值变化时触发,与`$change:value`事件有所不同的是,该事件只会触发一次,而且一定是用户点击行为触发的 | `value` |
24
- | click | 原生`click`事件 | `Event` |
25
- | mouseenter | 原生`mouseenter`事件 | `Event` |
26
- | mouseleave | 原生`mouseleave`事件 | `Event` |
26
+ | change | 当点击组件导致值变化时触发 | `(value: any, e: MouseEvent) => void` |
@@ -1,5 +1,6 @@
1
1
  import {getRestProps} from '../utils';
2
2
  import makeStyles from './styles';
3
+ import {Wave} from '../wave';
3
4
 
4
5
  const {
5
6
  className, disabled, falseValue,
@@ -44,18 +45,20 @@ const events = [
44
45
  ev-keypress={this.onKeypress}
45
46
  {...events}
46
47
  >
47
- <span class="k-checkbox-wrapper">
48
- <input
49
- type="checkbox"
50
- checked={isChecked}
51
- value={trueValue}
52
- v-model-true={trueValue}
53
- v-model-false={falseValue}
54
- disabled={disabled}
55
- tabindex="-1"
56
- ref={this.inputRef}
57
- {...getRestProps(this, rest)}
58
- />
59
- </span>
48
+ <Wave disabled={disabled} inset="-2px">
49
+ <span class="k-checkbox-wrapper">
50
+ <input
51
+ type="checkbox"
52
+ checked={isChecked}
53
+ value={trueValue}
54
+ v-model-true={trueValue}
55
+ v-model-false={falseValue}
56
+ disabled={disabled}
57
+ tabindex="-1"
58
+ ref={this.inputRef}
59
+ {...getRestProps(this, rest)}
60
+ />
61
+ </span>
62
+ </Wave>
60
63
  <span class="k-checkbox-text" v-if={children}>{children}</span>
61
64
  </label>
@@ -1,5 +1,5 @@
1
1
  import {css, cx} from '@emotion/css';
2
- import {theme, ThemeValue, setDefault} from '../../styles/theme';
2
+ import {theme, setDefault} from '../../styles/theme';
3
3
  import {deepDefaults, palette, getLeft} from '../../styles/utils';
4
4
  import '../../styles/global';
5
5
 
@@ -7,7 +7,7 @@ const defaults = {
7
7
  width: '14px',
8
8
  get borderColor() { return theme.color.darkBorder },
9
9
  get borderRadius() { return theme.borderRadius },
10
- get transition() { return theme.transition },
10
+ get transition() { return theme.transition.small },
11
11
  bgColor: '#fff',
12
12
 
13
13
  // text
@@ -43,7 +43,7 @@ const defaults = {
43
43
  }
44
44
  };
45
45
 
46
- let checkbox: any;
46
+ let checkbox: typeof defaults;
47
47
  setDefault(() => {
48
48
  checkbox = deepDefaults(theme, {checkbox: defaults}).checkbox;
49
49
  });
@@ -55,10 +55,8 @@ export default function makeStyles() {
55
55
  cursor: pointer;
56
56
  vertical-align: middle;
57
57
  .k-checkbox-wrapper {
58
- display: inline-block;
59
58
  width: ${checkbox.width};
60
59
  height: ${checkbox.width};
61
- vertical-align: middle;
62
60
  border: 1px solid ${checkbox.borderColor};
63
61
  border-radius: ${checkbox.borderRadius};
64
62
  position: relative;
@@ -94,9 +92,7 @@ export default function makeStyles() {
94
92
  margin: 0;
95
93
  }
96
94
  .k-checkbox-text {
97
- vertical-align: middle;
98
95
  margin-left: ${checkbox.text.gap};
99
- display: inline-block;
100
96
  flex: 0 1 auto;
101
97
  }
102
98
 
@@ -5,11 +5,11 @@ order: 0
5
5
 
6
6
  > `Code`由于基于`Monaco Editor`这个庞大的库,所以没有放入索引文件`index.js`,你只能通过如下方式引入
7
7
  >
8
- > `import {Code} from 'kpc/components/code';`
8
+ > `import {Code} from '@king-design/react/components/code';`
9
9
  >
10
- > 而不能直接通过`kpc`引入
10
+ > 而不能直接引入
11
11
  >
12
- > `import {Code} from 'kpc';`
12
+ > `import {Code} from '@king-design/react';`
13
13
 
14
14
  组件可以通过`v-model`双向绑定编辑的代码,通过`height`指定组件的高度(需要带单位),默认`100%`;通过
15
15
  `language`可以指定编程语言,默认为`javasript`
@@ -5,21 +5,19 @@ order: 99
5
5
  sidebar: doc
6
6
  ---
7
7
 
8
- > 由于Monaco-Editor太大,该组件不会打包进入单文件,所以你不能通过CDN引入组件的方式使用该组件,而必须通过webpack
9
- > 进行构建
8
+ > 由于Monaco-Editor太大,该组件不会默认加入`index.js`
10
9
 
11
10
  # 属性
12
11
 
13
12
  | 属性 | 说明 | 类型 | 默认值 |
14
13
  | --- | --- | --- | --- |
15
- | value | 组件的值,可通过`v-model`双向绑定 | `String` | `''` |
16
- | language | 指定编程语言 | `String` | `javasript` |
17
- | width | 指定宽度,需要带单位 | `String` | `100%` |
18
- | height | 指定高度,需要带单位 | `String` | `100%` |
14
+ | value | 组件的值,可通过`v-model`双向绑定 | `string` | `""` |
15
+ | language | 指定编程语言 | `string` | `javasript` |
19
16
  | theme | 指定主题 | `"vs"` &#124; `"vs-dark"` &#124; `"hc-black"` | `"vs"` |
20
- | readonly | 是否只读 | `Boolean` | `false` |
21
- | loading | 是否正在加载 | `Boolean` | `false` |
22
- | options | 其它可选的配置,会传给`monaco.editor.create()`方法,可选值参考[options](https://microsoft.github.io/monaco-editor/api/interfaces/monaco.editor.ieditorconstructionoptions.html) | `Object` | `{}` |
17
+ | readOnly | 是否只读 | `boolean` | `false` |
18
+ | width | 指定宽度,需要带单位 | `string` | `100%` |
19
+ | height | 指定高度,需要带单位 | `string` | `100%` |
20
+ | options | 其它可选的配置,会传给`monaco.editor.create()`方法,可选值参考[options](https://microsoft.github.io/monaco-editor/api/interfaces/monaco.editor.IStandaloneEditorConstructionOptions.html) | [`editor.IStandaloneEditorConstructionOptions`](https://microsoft.github.io/monaco-editor/api/interfaces/monaco.editor.IStandaloneEditorConstructionOptions.html) | `{}` |
23
21
 
24
22
  > 例如:通过`options`可以隐藏右侧代码的缩影(minimap): `options = {minimap: {enabled: false}}`
25
23
 
@@ -27,4 +25,4 @@ sidebar: doc
27
25
 
28
26
  | 事件名 | 说明 | 参数 |
29
27
  | --- | --- | --- |
30
- | ready | 组件加载并实例化完成触发 | `Code` |
28
+ | ready | 组件加载并实例化完成触发 | (editor: [editor.IStandaloneCodeEditor](https://microsoft.github.io/monaco-editor/api/interfaces/monaco.editor.IStandaloneCodeEditor.html), Editor: typeof [editor](https://microsoft.github.io/monaco-editor/api/modules/monaco.editor.html)) => void |