@douyinfe/semi-foundation 2.24.3 → 2.25.0-alpha.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 (971) hide show
  1. package/anchor/anchor.scss +6 -0
  2. package/anchor/foundation.ts +7 -6
  3. package/anchor/linkFoundation.ts +0 -1
  4. package/anchor/variables.scss +4 -0
  5. package/autoComplete/autoComplete.scss +2 -0
  6. package/autoComplete/foundation.ts +23 -20
  7. package/autoComplete/optionFoundation.ts +0 -2
  8. package/avatar/animation.scss +19 -0
  9. package/avatar/avatar.scss +314 -1
  10. package/avatar/constants.ts +21 -4
  11. package/avatar/foundation.ts +21 -4
  12. package/avatar/variables.scss +66 -10
  13. package/badge/badge.scss +13 -0
  14. package/badge/constants.ts +1 -1
  15. package/badge/variables.scss +4 -0
  16. package/base/foundation.ts +2 -3
  17. package/breadcrumb/breadcrumb.scss +10 -4
  18. package/breadcrumb/foundation.ts +0 -1
  19. package/breadcrumb/variables.scss +4 -0
  20. package/button/button.scss +88 -21
  21. package/button/iconButton.scss +1 -0
  22. package/button/splitButtonGroup.scss +10 -9
  23. package/button/variables.scss +13 -0
  24. package/calendar/calendar.scss +1 -1
  25. package/calendar/eventUtil.ts +14 -10
  26. package/calendar/foundation.ts +9 -9
  27. package/carousel/carousel.scss +4 -0
  28. package/carousel/foundation.ts +12 -7
  29. package/cascader/cascader.scss +66 -23
  30. package/cascader/constants.ts +5 -1
  31. package/cascader/foundation.ts +111 -63
  32. package/cascader/util.ts +64 -10
  33. package/cascader/variables.scss +5 -1
  34. package/checkbox/checkbox.scss +0 -1
  35. package/checkbox/checkboxFoundation.ts +1 -2
  36. package/checkbox/checkboxGroupFoundation.ts +0 -1
  37. package/collapse/foundation.ts +1 -0
  38. package/datePicker/_utils/getDefaultFormatToken.ts +1 -0
  39. package/datePicker/_utils/getInsetInputFormatToken.ts +1 -0
  40. package/datePicker/_utils/getInsetInputValueFromInsetInputStr.ts +1 -0
  41. package/datePicker/_utils/getYears.ts +8 -4
  42. package/datePicker/_utils/isValidTimeZone.ts +3 -0
  43. package/datePicker/constants.ts +1 -1
  44. package/datePicker/datePicker.scss +170 -21
  45. package/datePicker/foundation.ts +175 -150
  46. package/datePicker/inputFoundation.ts +34 -16
  47. package/datePicker/monthFoundation.ts +0 -1
  48. package/datePicker/monthsGridFoundation.ts +52 -32
  49. package/datePicker/variables.scss +13 -4
  50. package/datePicker/yearAndMonthFoundation.ts +68 -21
  51. package/descriptions/constants.ts +2 -1
  52. package/descriptions/descriptions.scss +20 -0
  53. package/descriptions/foundation.ts +36 -0
  54. package/descriptions/variables.scss +10 -0
  55. package/dropdown/constants.ts +1 -1
  56. package/dropdown/dropdown.scss +5 -0
  57. package/dropdown/foundation.ts +4 -3
  58. package/dropdown/menuFoundation.ts +3 -3
  59. package/form/constants.ts +2 -1
  60. package/form/form.scss +5 -2
  61. package/form/foundation.ts +12 -10
  62. package/form/interface.ts +5 -6
  63. package/form/utils.ts +39 -16
  64. package/form/variables.scss +3 -0
  65. package/grid/grid.scss +1 -1
  66. package/image/constants.ts +5 -1
  67. package/image/image.scss +9 -5
  68. package/image/previewFooterFoundation.ts +1 -4
  69. package/image/previewFoundation.ts +1 -1
  70. package/image/previewImageFoundation.ts +61 -70
  71. package/image/previewInnerFoundation.ts +93 -47
  72. package/image/utils.ts +18 -20
  73. package/image/variables.scss +1 -1
  74. package/input/foundation.ts +2 -4
  75. package/input/input.scss +48 -3
  76. package/input/textarea.scss +34 -0
  77. package/input/textareaFoundation.ts +42 -18
  78. package/input/variables.scss +7 -0
  79. package/inputNumber/foundation.ts +0 -5
  80. package/inputNumber/inputNumber.scss +9 -0
  81. package/lib/cjs/anchor/anchor.css +5 -0
  82. package/lib/cjs/anchor/anchor.scss +6 -0
  83. package/lib/cjs/anchor/constants.js +1 -3
  84. package/lib/cjs/anchor/foundation.js +20 -80
  85. package/lib/cjs/anchor/linkFoundation.js +3 -16
  86. package/lib/cjs/anchor/variables.scss +4 -0
  87. package/lib/cjs/autoComplete/autoComplete.css +1 -0
  88. package/lib/cjs/autoComplete/autoComplete.scss +2 -0
  89. package/lib/cjs/autoComplete/constants.js +3 -6
  90. package/lib/cjs/autoComplete/foundation.d.ts +3 -1
  91. package/lib/cjs/autoComplete/foundation.js +37 -149
  92. package/lib/cjs/autoComplete/optionFoundation.js +2 -14
  93. package/lib/cjs/avatar/animation.scss +19 -0
  94. package/lib/cjs/avatar/avatar.css +261 -0
  95. package/lib/cjs/avatar/avatar.scss +314 -1
  96. package/lib/cjs/avatar/constants.js +1 -4
  97. package/lib/cjs/avatar/foundation.d.ts +3 -0
  98. package/lib/cjs/avatar/foundation.js +21 -19
  99. package/lib/cjs/avatar/variables.scss +66 -10
  100. package/lib/cjs/backtop/constants.js +1 -3
  101. package/lib/cjs/backtop/foundation.d.ts +2 -2
  102. package/lib/cjs/backtop/foundation.js +0 -21
  103. package/lib/cjs/badge/badge.css +10 -0
  104. package/lib/cjs/badge/badge.scss +13 -0
  105. package/lib/cjs/badge/constants.js +2 -4
  106. package/lib/cjs/badge/variables.scss +4 -0
  107. package/lib/cjs/banner/constants.js +1 -3
  108. package/lib/cjs/banner/foundation.js +0 -7
  109. package/lib/cjs/base/constants.js +2 -4
  110. package/lib/cjs/base/foundation.d.ts +3 -3
  111. package/lib/cjs/base/foundation.js +12 -46
  112. package/lib/cjs/base/index.js +0 -3
  113. package/lib/cjs/breadcrumb/breadcrumb.css +5 -3
  114. package/lib/cjs/breadcrumb/breadcrumb.scss +10 -4
  115. package/lib/cjs/breadcrumb/constants.js +1 -3
  116. package/lib/cjs/breadcrumb/foundation.js +0 -13
  117. package/lib/cjs/breadcrumb/itemFoundation.js +0 -7
  118. package/lib/cjs/breadcrumb/variables.scss +4 -0
  119. package/lib/cjs/button/button.css +32 -5
  120. package/lib/cjs/button/button.scss +88 -21
  121. package/lib/cjs/button/constants.js +1 -3
  122. package/lib/cjs/button/iconButton.css +1 -0
  123. package/lib/cjs/button/iconButton.scss +1 -0
  124. package/lib/cjs/button/splitButtonGroup.scss +10 -9
  125. package/lib/cjs/button/variables.scss +13 -0
  126. package/lib/cjs/calendar/calendar.css +2 -2
  127. package/lib/cjs/calendar/calendar.scss +1 -1
  128. package/lib/cjs/calendar/constants.js +1 -3
  129. package/lib/cjs/calendar/eventUtil.d.ts +7 -6
  130. package/lib/cjs/calendar/eventUtil.js +15 -83
  131. package/lib/cjs/calendar/foundation.d.ts +4 -4
  132. package/lib/cjs/calendar/foundation.js +32 -128
  133. package/lib/cjs/card/constants.js +1 -3
  134. package/lib/cjs/carousel/carousel.css +4 -0
  135. package/lib/cjs/carousel/carousel.scss +4 -0
  136. package/lib/cjs/carousel/constants.js +9 -11
  137. package/lib/cjs/carousel/foundation.d.ts +2 -0
  138. package/lib/cjs/carousel/foundation.js +7 -52
  139. package/lib/cjs/cascader/cascader.css +45 -4
  140. package/lib/cjs/cascader/cascader.scss +66 -23
  141. package/lib/cjs/cascader/constants.d.ts +3 -0
  142. package/lib/cjs/cascader/constants.js +9 -8
  143. package/lib/cjs/cascader/foundation.d.ts +27 -8
  144. package/lib/cjs/cascader/foundation.js +122 -300
  145. package/lib/cjs/cascader/util.d.ts +9 -1
  146. package/lib/cjs/cascader/util.js +69 -33
  147. package/lib/cjs/cascader/variables.scss +5 -1
  148. package/lib/cjs/checkbox/checkbox.css +0 -1
  149. package/lib/cjs/checkbox/checkbox.scss +0 -1
  150. package/lib/cjs/checkbox/checkboxFoundation.js +1 -38
  151. package/lib/cjs/checkbox/checkboxGroupFoundation.js +1 -23
  152. package/lib/cjs/checkbox/constants.js +13 -15
  153. package/lib/cjs/collapse/constants.js +1 -3
  154. package/lib/cjs/collapse/foundation.d.ts +2 -1
  155. package/lib/cjs/collapse/foundation.js +2 -13
  156. package/lib/cjs/collapsible/constants.js +1 -3
  157. package/lib/cjs/collapsible/foundation.js +0 -9
  158. package/lib/cjs/datePicker/_utils/formatter.js +4 -10
  159. package/lib/cjs/datePicker/_utils/getDayOfWeek.d.ts +1 -1
  160. package/lib/cjs/datePicker/_utils/getDayOfWeek.js +0 -4
  161. package/lib/cjs/datePicker/_utils/getDefaultFormatToken.d.ts +1 -0
  162. package/lib/cjs/datePicker/_utils/getDefaultFormatToken.js +2 -6
  163. package/lib/cjs/datePicker/_utils/getDefaultPickerDate.d.ts +1 -1
  164. package/lib/cjs/datePicker/_utils/getDefaultPickerDate.js +0 -15
  165. package/lib/cjs/datePicker/_utils/getFullDateOffset.js +0 -7
  166. package/lib/cjs/datePicker/_utils/getInsetInputFormatToken.js +2 -6
  167. package/lib/cjs/datePicker/_utils/getInsetInputValueFromInsetInputStr.js +1 -6
  168. package/lib/cjs/datePicker/_utils/getMonthTable.d.ts +1 -1
  169. package/lib/cjs/datePicker/_utils/getMonthTable.js +7 -18
  170. package/lib/cjs/datePicker/_utils/getMonthsInYear.js +1 -3
  171. package/lib/cjs/datePicker/_utils/getYears.d.ts +1 -1
  172. package/lib/cjs/datePicker/_utils/getYears.js +9 -7
  173. package/lib/cjs/datePicker/_utils/index.js +0 -13
  174. package/lib/cjs/datePicker/_utils/isAfter.js +0 -4
  175. package/lib/cjs/datePicker/_utils/isBefore.js +0 -4
  176. package/lib/cjs/datePicker/_utils/isBetween.js +0 -4
  177. package/lib/cjs/datePicker/_utils/isDate.js +0 -1
  178. package/lib/cjs/datePicker/_utils/isSameDay.js +0 -4
  179. package/lib/cjs/datePicker/_utils/isTimestamp.js +0 -4
  180. package/lib/cjs/datePicker/_utils/isUnixTimestamp.js +0 -4
  181. package/lib/cjs/datePicker/_utils/isValidDate.js +0 -1
  182. package/lib/cjs/datePicker/_utils/isValidTimeZone.d.ts +1 -0
  183. package/lib/cjs/datePicker/_utils/isValidTimeZone.js +9 -0
  184. package/lib/cjs/datePicker/_utils/isWithinInterval.js +0 -4
  185. package/lib/cjs/datePicker/_utils/parser.js +0 -10
  186. package/lib/cjs/datePicker/constants.d.ts +1 -1
  187. package/lib/cjs/datePicker/constants.js +28 -31
  188. package/lib/cjs/datePicker/datePicker.css +88 -13
  189. package/lib/cjs/datePicker/datePicker.scss +170 -21
  190. package/lib/cjs/datePicker/foundation.d.ts +79 -50
  191. package/lib/cjs/datePicker/foundation.js +173 -441
  192. package/lib/cjs/datePicker/inputFoundation.d.ts +15 -6
  193. package/lib/cjs/datePicker/inputFoundation.js +35 -98
  194. package/lib/cjs/datePicker/monthFoundation.d.ts +1 -1
  195. package/lib/cjs/datePicker/monthFoundation.js +2 -28
  196. package/lib/cjs/datePicker/monthsGridFoundation.d.ts +18 -13
  197. package/lib/cjs/datePicker/monthsGridFoundation.js +70 -247
  198. package/lib/cjs/datePicker/variables.scss +13 -4
  199. package/lib/cjs/datePicker/yearAndMonthFoundation.d.ts +68 -13
  200. package/lib/cjs/datePicker/yearAndMonthFoundation.js +55 -42
  201. package/lib/cjs/descriptions/constants.d.ts +1 -0
  202. package/lib/cjs/descriptions/constants.js +3 -4
  203. package/lib/cjs/descriptions/descriptions.css +15 -0
  204. package/lib/cjs/descriptions/descriptions.scss +20 -0
  205. package/lib/cjs/descriptions/foundation.d.ts +7 -0
  206. package/lib/cjs/descriptions/foundation.js +45 -0
  207. package/lib/cjs/descriptions/variables.scss +10 -0
  208. package/lib/cjs/divider/constants.js +1 -3
  209. package/lib/cjs/dropdown/constants.js +4 -7
  210. package/lib/cjs/dropdown/dropdown.css +4 -0
  211. package/lib/cjs/dropdown/dropdown.scss +5 -0
  212. package/lib/cjs/dropdown/foundation.js +9 -25
  213. package/lib/cjs/dropdown/menuFoundation.js +9 -28
  214. package/lib/cjs/empty/constants.js +1 -3
  215. package/lib/cjs/form/constants.d.ts +1 -0
  216. package/lib/cjs/form/constants.js +3 -4
  217. package/lib/cjs/form/form.css +4 -0
  218. package/lib/cjs/form/form.scss +5 -2
  219. package/lib/cjs/form/foundation.d.ts +4 -4
  220. package/lib/cjs/form/foundation.js +84 -214
  221. package/lib/cjs/form/interface.d.ts +10 -10
  222. package/lib/cjs/form/utils.d.ts +10 -1
  223. package/lib/cjs/form/utils.js +85 -93
  224. package/lib/cjs/form/variables.scss +3 -0
  225. package/lib/cjs/grid/constants.js +1 -3
  226. package/lib/cjs/grid/grid.css +1 -1
  227. package/lib/cjs/grid/grid.scss +1 -1
  228. package/lib/cjs/highlight/constants.js +1 -3
  229. package/lib/cjs/icons/constants.js +1 -3
  230. package/lib/cjs/image/constants.d.ts +4 -1
  231. package/lib/cjs/image/constants.js +7 -5
  232. package/lib/cjs/image/image.css +4 -2
  233. package/lib/cjs/image/image.scss +9 -5
  234. package/lib/cjs/image/imageFoundation.js +4 -18
  235. package/lib/cjs/image/previewFooterFoundation.d.ts +0 -1
  236. package/lib/cjs/image/previewFooterFoundation.js +0 -14
  237. package/lib/cjs/image/previewFoundation.js +0 -11
  238. package/lib/cjs/image/previewImageFoundation.d.ts +9 -24
  239. package/lib/cjs/image/previewImageFoundation.js +79 -164
  240. package/lib/cjs/image/previewInnerFoundation.d.ts +19 -15
  241. package/lib/cjs/image/previewInnerFoundation.js +108 -114
  242. package/lib/cjs/image/utils.d.ts +1 -1
  243. package/lib/cjs/image/utils.js +46 -35
  244. package/lib/cjs/image/variables.scss +1 -1
  245. package/lib/cjs/input/constants.js +1 -3
  246. package/lib/cjs/input/foundation.js +19 -104
  247. package/lib/cjs/input/input.css +45 -1
  248. package/lib/cjs/input/input.scss +48 -3
  249. package/lib/cjs/input/textarea.css +20 -0
  250. package/lib/cjs/input/textarea.scss +34 -0
  251. package/lib/cjs/input/textareaFoundation.d.ts +1 -1
  252. package/lib/cjs/input/textareaFoundation.js +58 -101
  253. package/lib/cjs/input/util/calculateNodeHeight.js +6 -18
  254. package/lib/cjs/input/util/getSizingData.js +7 -11
  255. package/lib/cjs/input/variables.scss +7 -0
  256. package/lib/cjs/inputNumber/constants.js +0 -2
  257. package/lib/cjs/inputNumber/foundation.js +28 -197
  258. package/lib/cjs/inputNumber/inputNumber.css +4 -0
  259. package/lib/cjs/inputNumber/inputNumber.scss +9 -0
  260. package/lib/cjs/layout/constants.js +1 -3
  261. package/lib/cjs/list/constants.js +1 -3
  262. package/lib/cjs/modal/constants.js +1 -3
  263. package/lib/cjs/modal/modal.css +8 -0
  264. package/lib/cjs/modal/modal.scss +10 -1
  265. package/lib/cjs/modal/modalContentFoundation.js +0 -20
  266. package/lib/cjs/modal/modalFoundation.d.ts +8 -4
  267. package/lib/cjs/modal/modalFoundation.js +40 -15
  268. package/lib/cjs/modal/variables.scss +6 -1
  269. package/lib/cjs/navigation/NavItem.js +0 -12
  270. package/lib/cjs/navigation/constants.js +1 -4
  271. package/lib/cjs/navigation/foundation.js +3 -70
  272. package/lib/cjs/navigation/itemFoundation.js +3 -22
  273. package/lib/cjs/navigation/subNavFoundation.js +7 -42
  274. package/lib/cjs/notification/constants.js +3 -6
  275. package/lib/cjs/notification/notification.css +18 -0
  276. package/lib/cjs/notification/notification.scss +21 -1
  277. package/lib/cjs/notification/notificationFoundation.d.ts +6 -6
  278. package/lib/cjs/notification/notificationFoundation.js +0 -16
  279. package/lib/cjs/notification/notificationListFoundation.d.ts +4 -1
  280. package/lib/cjs/notification/notificationListFoundation.js +15 -18
  281. package/lib/cjs/overflowList/constants.d.ts +6 -4
  282. package/lib/cjs/overflowList/constants.js +3 -3
  283. package/lib/cjs/overflowList/foundation.d.ts +3 -1
  284. package/lib/cjs/overflowList/foundation.js +59 -68
  285. package/lib/cjs/pagination/constants.js +1 -3
  286. package/lib/cjs/pagination/foundation.d.ts +5 -3
  287. package/lib/cjs/pagination/foundation.js +36 -93
  288. package/lib/cjs/pagination/pagination.css +23 -0
  289. package/lib/cjs/pagination/pagination.scss +29 -0
  290. package/lib/cjs/pagination/variables.scss +1 -0
  291. package/lib/cjs/popconfirm/constants.js +2 -4
  292. package/lib/cjs/popconfirm/popconfirm.css +4 -24
  293. package/lib/cjs/popconfirm/popconfirm.scss +4 -16
  294. package/lib/cjs/popconfirm/popconfirmFoundation.d.ts +4 -0
  295. package/lib/cjs/popconfirm/popconfirmFoundation.js +17 -19
  296. package/lib/cjs/popconfirm/rtl.scss +0 -13
  297. package/lib/cjs/popconfirm/variables.scss +0 -4
  298. package/lib/cjs/popover/constants.d.ts +1 -1
  299. package/lib/cjs/popover/constants.js +3 -6
  300. package/lib/cjs/popover/popover.css +2 -0
  301. package/lib/cjs/popover/popover.scss +2 -0
  302. package/lib/cjs/progress/constants.js +1 -3
  303. package/lib/cjs/progress/generates.d.ts +2 -2
  304. package/lib/cjs/progress/generates.js +33 -74
  305. package/lib/cjs/radio/constants.js +13 -15
  306. package/lib/cjs/radio/radio.css +3 -0
  307. package/lib/cjs/radio/radio.scss +6 -3
  308. package/lib/cjs/radio/radioFoundation.js +0 -14
  309. package/lib/cjs/radio/radioGroupFoundation.js +3 -23
  310. package/lib/cjs/radio/radioInnerFoundation.js +1 -19
  311. package/lib/cjs/radio/variables.scss +4 -0
  312. package/lib/cjs/rating/constants.js +1 -3
  313. package/lib/cjs/rating/foundation.js +10 -62
  314. package/lib/cjs/scrollList/constants.js +2 -4
  315. package/lib/cjs/scrollList/foundation.js +0 -4
  316. package/lib/cjs/scrollList/itemFoundation.js +8 -61
  317. package/lib/cjs/scrollList/scrollTo.js +2 -5
  318. package/lib/cjs/select/constants.js +3 -6
  319. package/lib/cjs/select/foundation.d.ts +8 -6
  320. package/lib/cjs/select/foundation.js +172 -433
  321. package/lib/cjs/select/option.scss +1 -1
  322. package/lib/cjs/select/optionFoundation.js +2 -14
  323. package/lib/cjs/select/select.css +50 -0
  324. package/lib/cjs/select/select.scss +74 -5
  325. package/lib/cjs/select/variables.scss +9 -6
  326. package/lib/cjs/sideSheet/constants.js +2 -4
  327. package/lib/cjs/sideSheet/sideSheet.css +30 -0
  328. package/lib/cjs/sideSheet/sideSheet.scss +38 -0
  329. package/lib/cjs/sideSheet/sideSheetFoundation.d.ts +1 -0
  330. package/lib/cjs/sideSheet/sideSheetFoundation.js +0 -18
  331. package/lib/cjs/sideSheet/variables.scss +7 -0
  332. package/lib/cjs/skeleton/constants.js +1 -3
  333. package/lib/cjs/skeleton/skeleton.css +3 -2
  334. package/lib/cjs/skeleton/skeleton.scss +1 -0
  335. package/lib/cjs/skeleton/variables.scss +2 -2
  336. package/lib/cjs/slider/constants.d.ts +1 -0
  337. package/lib/cjs/slider/constants.js +8 -9
  338. package/lib/cjs/slider/foundation.d.ts +13 -2
  339. package/lib/cjs/slider/foundation.js +30 -226
  340. package/lib/cjs/slider/slider.css +25 -11
  341. package/lib/cjs/slider/slider.scss +16 -1
  342. package/lib/cjs/slider/variables.scss +15 -9
  343. package/lib/cjs/space/constants.js +1 -3
  344. package/lib/cjs/spin/constants.js +1 -3
  345. package/lib/cjs/spin/foundation.js +3 -13
  346. package/lib/cjs/spin/spin.css +3 -0
  347. package/lib/cjs/spin/spin.scss +3 -0
  348. package/lib/cjs/steps/bacisSteps.scss +10 -3
  349. package/lib/cjs/steps/constants.js +2 -4
  350. package/lib/cjs/steps/fillSteps.scss +7 -7
  351. package/lib/cjs/steps/steps.css +27 -22
  352. package/lib/cjs/steps/variables.scss +3 -3
  353. package/lib/cjs/switch/constants.js +13 -15
  354. package/lib/cjs/switch/foundation.js +1 -21
  355. package/lib/cjs/switch/switch.css +10 -0
  356. package/lib/cjs/switch/switch.scss +13 -2
  357. package/lib/cjs/table/bodyFoundation.js +1 -34
  358. package/lib/cjs/table/cellFoundation.js +0 -5
  359. package/lib/cjs/table/constants.d.ts +0 -1
  360. package/lib/cjs/table/constants.js +13 -18
  361. package/lib/cjs/table/foundation.d.ts +26 -16
  362. package/lib/cjs/table/foundation.js +79 -308
  363. package/lib/cjs/table/rtl.scss +33 -2
  364. package/lib/cjs/table/table.css +100 -64
  365. package/lib/cjs/table/table.scss +66 -8
  366. package/lib/cjs/table/tableRowFoundation.js +0 -12
  367. package/lib/cjs/table/tableSelectionCellFoundation.js +0 -6
  368. package/lib/cjs/table/utils.d.ts +6 -4
  369. package/lib/cjs/table/utils.js +27 -160
  370. package/lib/cjs/table/variables.scss +6 -3
  371. package/lib/cjs/tabs/constants.js +21 -23
  372. package/lib/cjs/tabs/foundation.js +2 -40
  373. package/lib/cjs/tabs/tabs.css +207 -7
  374. package/lib/cjs/tabs/tabs.scss +339 -24
  375. package/lib/cjs/tag/constants.js +1 -4
  376. package/lib/cjs/tag/tag.css +34 -1
  377. package/lib/cjs/tag/tag.scss +43 -4
  378. package/lib/cjs/tag/variables.scss +5 -0
  379. package/lib/cjs/tagInput/constants.js +1 -3
  380. package/lib/cjs/tagInput/foundation.d.ts +7 -4
  381. package/lib/cjs/tagInput/foundation.js +64 -88
  382. package/lib/cjs/tagInput/tagInput.css +35 -9
  383. package/lib/cjs/tagInput/tagInput.scss +41 -12
  384. package/lib/cjs/tagInput/utils/getSplitedArray.js +0 -11
  385. package/lib/cjs/tagInput/variables.scss +2 -0
  386. package/lib/cjs/timePicker/ComboxFoundation.js +6 -41
  387. package/lib/cjs/timePicker/constants.js +3 -6
  388. package/lib/cjs/timePicker/foundation.d.ts +2 -2
  389. package/lib/cjs/timePicker/foundation.js +28 -107
  390. package/lib/cjs/timePicker/inputFoundation.js +4 -25
  391. package/lib/cjs/timePicker/timePicker.css +15 -0
  392. package/lib/cjs/timePicker/timePicker.scss +22 -1
  393. package/lib/cjs/timePicker/utils/index.js +12 -51
  394. package/lib/cjs/timePicker/utils/localeDate.js +0 -10
  395. package/lib/cjs/timeline/constants.js +2 -4
  396. package/lib/cjs/toast/animation.scss +3 -0
  397. package/lib/cjs/toast/constants.js +3 -6
  398. package/lib/cjs/toast/toast.css +35 -3
  399. package/lib/cjs/toast/toast.scss +43 -3
  400. package/lib/cjs/toast/toastFoundation.d.ts +5 -4
  401. package/lib/cjs/toast/toastFoundation.js +0 -14
  402. package/lib/cjs/toast/toastListFoundation.d.ts +5 -0
  403. package/lib/cjs/toast/toastListFoundation.js +10 -22
  404. package/lib/cjs/toast/variables.scss +14 -0
  405. package/lib/cjs/tooltip/constants.d.ts +1 -1
  406. package/lib/cjs/tooltip/constants.js +2 -4
  407. package/lib/cjs/tooltip/foundation.d.ts +5 -2
  408. package/lib/cjs/tooltip/foundation.js +143 -336
  409. package/lib/cjs/tooltip/tooltip.css +7 -0
  410. package/lib/cjs/tooltip/tooltip.scss +9 -0
  411. package/lib/cjs/transfer/constants.js +1 -3
  412. package/lib/cjs/transfer/foundation.d.ts +1 -1
  413. package/lib/cjs/transfer/foundation.js +4 -69
  414. package/lib/cjs/transfer/transfer.css +4 -0
  415. package/lib/cjs/transfer/transfer.scss +7 -0
  416. package/lib/cjs/transfer/transferUtils.js +5 -27
  417. package/lib/cjs/tree/constants.js +2 -4
  418. package/lib/cjs/tree/foundation.d.ts +14 -9
  419. package/lib/cjs/tree/foundation.js +60 -183
  420. package/lib/cjs/tree/rtl.scss +19 -11
  421. package/lib/cjs/tree/tree.css +147 -65
  422. package/lib/cjs/tree/tree.scss +112 -17
  423. package/lib/cjs/tree/treeUtil.d.ts +17 -8
  424. package/lib/cjs/tree/treeUtil.js +102 -195
  425. package/lib/cjs/tree/variables.scss +3 -2
  426. package/lib/cjs/treeSelect/constants.js +3 -5
  427. package/lib/cjs/treeSelect/foundation.d.ts +26 -13
  428. package/lib/cjs/treeSelect/foundation.js +153 -248
  429. package/lib/cjs/treeSelect/treeSelect.css +55 -10
  430. package/lib/cjs/treeSelect/treeSelect.scss +76 -20
  431. package/lib/cjs/treeSelect/variables.scss +4 -2
  432. package/lib/cjs/typography/constants.d.ts +1 -0
  433. package/lib/cjs/typography/constants.js +2 -3
  434. package/lib/cjs/typography/formatNumeral.d.ts +3 -3
  435. package/lib/cjs/typography/formatNumeral.js +22 -43
  436. package/lib/cjs/typography/typography.css +135 -2
  437. package/lib/cjs/typography/typography.scss +151 -8
  438. package/lib/cjs/typography/variables.scss +52 -0
  439. package/lib/cjs/upload/constants.js +2 -4
  440. package/lib/cjs/upload/fileCardFoundation.d.ts +9 -0
  441. package/lib/cjs/upload/fileCardFoundation.js +18 -0
  442. package/lib/cjs/upload/foundation.d.ts +14 -5
  443. package/lib/cjs/upload/foundation.js +107 -247
  444. package/lib/cjs/upload/upload.css +9 -0
  445. package/lib/cjs/upload/upload.scss +8 -0
  446. package/lib/cjs/upload/utils.js +14 -33
  447. package/lib/cjs/utils/Event.js +1 -21
  448. package/lib/cjs/utils/FocusHandle.d.ts +1 -1
  449. package/lib/cjs/utils/FocusHandle.js +6 -35
  450. package/lib/cjs/utils/Logger.js +0 -21
  451. package/lib/cjs/utils/Store.js +0 -10
  452. package/lib/cjs/utils/a11y.js +18 -43
  453. package/lib/cjs/utils/array.d.ts +2 -2
  454. package/lib/cjs/utils/array.js +2 -9
  455. package/lib/cjs/utils/arrayMove.js +0 -1
  456. package/lib/cjs/utils/classnames.js +0 -12
  457. package/lib/cjs/utils/date-fns-extra.d.ts +28 -17
  458. package/lib/cjs/utils/date-fns-extra.js +82 -51
  459. package/lib/cjs/utils/dom.d.ts +1 -1
  460. package/lib/cjs/utils/dom.js +0 -13
  461. package/lib/cjs/utils/function.js +0 -2
  462. package/lib/cjs/utils/getDataAttr.js +1 -3
  463. package/lib/cjs/utils/getHighlight.js +5 -26
  464. package/lib/cjs/utils/getMotionObjFromProps.js +4 -16
  465. package/lib/cjs/utils/index.js +0 -4
  466. package/lib/cjs/utils/isBothNaN.js +0 -2
  467. package/lib/cjs/utils/isElement.js +0 -1
  468. package/lib/cjs/utils/isEnterPress.js +0 -5
  469. package/lib/cjs/utils/isEscPress.js +0 -5
  470. package/lib/cjs/utils/isNullOrUndefined.js +0 -1
  471. package/lib/cjs/utils/isNumber.js +0 -1
  472. package/lib/cjs/utils/isObject.js +0 -1
  473. package/lib/cjs/utils/isPromise.js +0 -3
  474. package/lib/cjs/utils/isString.js +0 -1
  475. package/lib/cjs/utils/keyCode.js +0 -105
  476. package/lib/cjs/utils/log.js +0 -5
  477. package/lib/cjs/utils/number.js +0 -2
  478. package/lib/cjs/utils/object.d.ts +4 -4
  479. package/lib/cjs/utils/object.js +10 -36
  480. package/lib/cjs/utils/set.js +0 -8
  481. package/lib/cjs/utils/shallowEqualObjects.js +0 -7
  482. package/lib/cjs/utils/touchPolyfill.js +1 -8
  483. package/lib/cjs/utils/type.d.ts +3 -3
  484. package/lib/cjs/utils/uuid.js +4 -11
  485. package/lib/cjs/utils/warning.js +1 -2
  486. package/lib/es/anchor/anchor.css +5 -0
  487. package/lib/es/anchor/anchor.scss +6 -0
  488. package/lib/es/anchor/constants.js +1 -1
  489. package/lib/es/anchor/foundation.js +20 -73
  490. package/lib/es/anchor/linkFoundation.js +3 -12
  491. package/lib/es/anchor/variables.scss +4 -0
  492. package/lib/es/autoComplete/autoComplete.css +1 -0
  493. package/lib/es/autoComplete/autoComplete.scss +2 -0
  494. package/lib/es/autoComplete/constants.js +3 -3
  495. package/lib/es/autoComplete/foundation.d.ts +3 -1
  496. package/lib/es/autoComplete/foundation.js +37 -142
  497. package/lib/es/autoComplete/optionFoundation.js +2 -10
  498. package/lib/es/avatar/animation.scss +19 -0
  499. package/lib/es/avatar/avatar.css +261 -0
  500. package/lib/es/avatar/avatar.scss +314 -1
  501. package/lib/es/avatar/constants.js +1 -2
  502. package/lib/es/avatar/foundation.d.ts +3 -0
  503. package/lib/es/avatar/foundation.js +21 -14
  504. package/lib/es/avatar/variables.scss +66 -10
  505. package/lib/es/backtop/constants.js +1 -1
  506. package/lib/es/backtop/foundation.d.ts +2 -2
  507. package/lib/es/backtop/foundation.js +0 -16
  508. package/lib/es/badge/badge.css +10 -0
  509. package/lib/es/badge/badge.scss +13 -0
  510. package/lib/es/badge/constants.js +2 -2
  511. package/lib/es/badge/variables.scss +4 -0
  512. package/lib/es/banner/constants.js +1 -1
  513. package/lib/es/banner/foundation.js +0 -3
  514. package/lib/es/base/constants.js +2 -2
  515. package/lib/es/base/foundation.d.ts +3 -3
  516. package/lib/es/base/foundation.js +11 -44
  517. package/lib/es/breadcrumb/breadcrumb.css +5 -3
  518. package/lib/es/breadcrumb/breadcrumb.scss +10 -4
  519. package/lib/es/breadcrumb/constants.js +1 -1
  520. package/lib/es/breadcrumb/foundation.js +0 -8
  521. package/lib/es/breadcrumb/itemFoundation.js +0 -3
  522. package/lib/es/breadcrumb/variables.scss +4 -0
  523. package/lib/es/button/button.css +32 -5
  524. package/lib/es/button/button.scss +88 -21
  525. package/lib/es/button/constants.js +1 -1
  526. package/lib/es/button/iconButton.css +1 -0
  527. package/lib/es/button/iconButton.scss +1 -0
  528. package/lib/es/button/splitButtonGroup.scss +10 -9
  529. package/lib/es/button/variables.scss +13 -0
  530. package/lib/es/calendar/calendar.css +2 -2
  531. package/lib/es/calendar/calendar.scss +1 -1
  532. package/lib/es/calendar/constants.js +1 -1
  533. package/lib/es/calendar/eventUtil.d.ts +7 -6
  534. package/lib/es/calendar/eventUtil.js +15 -45
  535. package/lib/es/calendar/foundation.d.ts +4 -4
  536. package/lib/es/calendar/foundation.js +32 -122
  537. package/lib/es/card/constants.js +1 -1
  538. package/lib/es/carousel/carousel.css +4 -0
  539. package/lib/es/carousel/carousel.scss +4 -0
  540. package/lib/es/carousel/constants.js +9 -9
  541. package/lib/es/carousel/foundation.d.ts +2 -0
  542. package/lib/es/carousel/foundation.js +7 -47
  543. package/lib/es/cascader/cascader.css +45 -4
  544. package/lib/es/cascader/cascader.scss +66 -23
  545. package/lib/es/cascader/constants.d.ts +3 -0
  546. package/lib/es/cascader/constants.js +7 -5
  547. package/lib/es/cascader/foundation.d.ts +27 -8
  548. package/lib/es/cascader/foundation.js +125 -286
  549. package/lib/es/cascader/util.d.ts +9 -1
  550. package/lib/es/cascader/util.js +65 -24
  551. package/lib/es/cascader/variables.scss +5 -1
  552. package/lib/es/checkbox/checkbox.css +0 -1
  553. package/lib/es/checkbox/checkbox.scss +0 -1
  554. package/lib/es/checkbox/checkboxFoundation.js +1 -34
  555. package/lib/es/checkbox/checkboxGroupFoundation.js +1 -20
  556. package/lib/es/checkbox/constants.js +13 -13
  557. package/lib/es/collapse/constants.js +1 -1
  558. package/lib/es/collapse/foundation.d.ts +2 -1
  559. package/lib/es/collapse/foundation.js +2 -9
  560. package/lib/es/collapsible/constants.js +1 -1
  561. package/lib/es/collapsible/foundation.js +0 -7
  562. package/lib/es/datePicker/_utils/formatter.js +4 -8
  563. package/lib/es/datePicker/_utils/getDayOfWeek.d.ts +1 -1
  564. package/lib/es/datePicker/_utils/getDayOfWeek.js +0 -3
  565. package/lib/es/datePicker/_utils/getDefaultFormatToken.d.ts +1 -0
  566. package/lib/es/datePicker/_utils/getDefaultFormatToken.js +2 -3
  567. package/lib/es/datePicker/_utils/getDefaultPickerDate.d.ts +1 -1
  568. package/lib/es/datePicker/_utils/getDefaultPickerDate.js +0 -10
  569. package/lib/es/datePicker/_utils/getFullDateOffset.js +0 -3
  570. package/lib/es/datePicker/_utils/getInsetInputFormatToken.js +2 -5
  571. package/lib/es/datePicker/_utils/getInsetInputValueFromInsetInputStr.js +1 -5
  572. package/lib/es/datePicker/_utils/getMonthTable.d.ts +1 -1
  573. package/lib/es/datePicker/_utils/getMonthTable.js +8 -18
  574. package/lib/es/datePicker/_utils/getMonthsInYear.js +1 -2
  575. package/lib/es/datePicker/_utils/getYears.d.ts +1 -1
  576. package/lib/es/datePicker/_utils/getYears.js +9 -6
  577. package/lib/es/datePicker/_utils/isBetween.js +0 -1
  578. package/lib/es/datePicker/_utils/isValidTimeZone.d.ts +1 -0
  579. package/lib/es/datePicker/_utils/isValidTimeZone.js +3 -0
  580. package/lib/es/datePicker/_utils/parser.js +0 -8
  581. package/lib/es/datePicker/constants.d.ts +1 -1
  582. package/lib/es/datePicker/constants.js +28 -28
  583. package/lib/es/datePicker/datePicker.css +88 -13
  584. package/lib/es/datePicker/datePicker.scss +170 -21
  585. package/lib/es/datePicker/foundation.d.ts +79 -50
  586. package/lib/es/datePicker/foundation.js +173 -426
  587. package/lib/es/datePicker/inputFoundation.d.ts +15 -6
  588. package/lib/es/datePicker/inputFoundation.js +35 -85
  589. package/lib/es/datePicker/monthFoundation.d.ts +1 -1
  590. package/lib/es/datePicker/monthFoundation.js +3 -22
  591. package/lib/es/datePicker/monthsGridFoundation.d.ts +18 -13
  592. package/lib/es/datePicker/monthsGridFoundation.js +70 -231
  593. package/lib/es/datePicker/variables.scss +13 -4
  594. package/lib/es/datePicker/yearAndMonthFoundation.d.ts +68 -13
  595. package/lib/es/datePicker/yearAndMonthFoundation.js +55 -37
  596. package/lib/es/descriptions/constants.d.ts +1 -0
  597. package/lib/es/descriptions/constants.js +3 -2
  598. package/lib/es/descriptions/descriptions.css +15 -0
  599. package/lib/es/descriptions/descriptions.scss +20 -0
  600. package/lib/es/descriptions/foundation.d.ts +7 -0
  601. package/lib/es/descriptions/foundation.js +37 -0
  602. package/lib/es/descriptions/variables.scss +10 -0
  603. package/lib/es/divider/constants.js +1 -1
  604. package/lib/es/dropdown/constants.js +4 -4
  605. package/lib/es/dropdown/dropdown.css +4 -0
  606. package/lib/es/dropdown/dropdown.scss +5 -0
  607. package/lib/es/dropdown/foundation.js +9 -20
  608. package/lib/es/dropdown/menuFoundation.js +9 -23
  609. package/lib/es/empty/constants.js +1 -1
  610. package/lib/es/form/constants.d.ts +1 -0
  611. package/lib/es/form/constants.js +3 -2
  612. package/lib/es/form/form.css +4 -0
  613. package/lib/es/form/form.scss +5 -2
  614. package/lib/es/form/foundation.d.ts +4 -4
  615. package/lib/es/form/foundation.js +84 -203
  616. package/lib/es/form/interface.d.ts +10 -10
  617. package/lib/es/form/utils.d.ts +10 -1
  618. package/lib/es/form/utils.js +83 -86
  619. package/lib/es/form/variables.scss +3 -0
  620. package/lib/es/grid/constants.js +1 -1
  621. package/lib/es/grid/grid.css +1 -1
  622. package/lib/es/grid/grid.scss +1 -1
  623. package/lib/es/highlight/constants.js +1 -1
  624. package/lib/es/icons/constants.js +1 -1
  625. package/lib/es/image/constants.d.ts +4 -1
  626. package/lib/es/image/constants.js +5 -2
  627. package/lib/es/image/image.css +4 -2
  628. package/lib/es/image/image.scss +9 -5
  629. package/lib/es/image/imageFoundation.js +4 -13
  630. package/lib/es/image/previewFooterFoundation.d.ts +0 -1
  631. package/lib/es/image/previewFooterFoundation.js +0 -10
  632. package/lib/es/image/previewFoundation.js +0 -7
  633. package/lib/es/image/previewImageFoundation.d.ts +9 -24
  634. package/lib/es/image/previewImageFoundation.js +79 -156
  635. package/lib/es/image/previewInnerFoundation.d.ts +19 -15
  636. package/lib/es/image/previewInnerFoundation.js +108 -107
  637. package/lib/es/image/utils.d.ts +1 -1
  638. package/lib/es/image/utils.js +46 -27
  639. package/lib/es/image/variables.scss +1 -1
  640. package/lib/es/input/constants.js +1 -1
  641. package/lib/es/input/foundation.js +19 -96
  642. package/lib/es/input/input.css +45 -1
  643. package/lib/es/input/input.scss +48 -3
  644. package/lib/es/input/textarea.css +20 -0
  645. package/lib/es/input/textarea.scss +34 -0
  646. package/lib/es/input/textareaFoundation.d.ts +1 -1
  647. package/lib/es/input/textareaFoundation.js +58 -91
  648. package/lib/es/input/util/calculateNodeHeight.js +6 -18
  649. package/lib/es/input/util/getSizingData.js +7 -11
  650. package/lib/es/input/variables.scss +7 -0
  651. package/lib/es/inputNumber/foundation.js +28 -188
  652. package/lib/es/inputNumber/inputNumber.css +4 -0
  653. package/lib/es/inputNumber/inputNumber.scss +9 -0
  654. package/lib/es/layout/constants.js +1 -1
  655. package/lib/es/list/constants.js +1 -1
  656. package/lib/es/modal/constants.js +1 -1
  657. package/lib/es/modal/modal.css +8 -0
  658. package/lib/es/modal/modal.scss +10 -1
  659. package/lib/es/modal/modalContentFoundation.js +0 -15
  660. package/lib/es/modal/modalFoundation.d.ts +8 -4
  661. package/lib/es/modal/modalFoundation.js +40 -11
  662. package/lib/es/modal/variables.scss +6 -1
  663. package/lib/es/navigation/NavItem.js +0 -8
  664. package/lib/es/navigation/constants.js +2 -2
  665. package/lib/es/navigation/foundation.js +3 -63
  666. package/lib/es/navigation/itemFoundation.js +3 -19
  667. package/lib/es/navigation/subNavFoundation.js +7 -38
  668. package/lib/es/notification/constants.js +4 -4
  669. package/lib/es/notification/notification.css +18 -0
  670. package/lib/es/notification/notification.scss +21 -1
  671. package/lib/es/notification/notificationFoundation.d.ts +6 -6
  672. package/lib/es/notification/notificationFoundation.js +0 -11
  673. package/lib/es/notification/notificationListFoundation.d.ts +4 -1
  674. package/lib/es/notification/notificationListFoundation.js +15 -14
  675. package/lib/es/overflowList/constants.d.ts +6 -4
  676. package/lib/es/overflowList/constants.js +3 -1
  677. package/lib/es/overflowList/foundation.d.ts +3 -1
  678. package/lib/es/overflowList/foundation.js +59 -64
  679. package/lib/es/pagination/constants.js +1 -1
  680. package/lib/es/pagination/foundation.d.ts +5 -3
  681. package/lib/es/pagination/foundation.js +36 -90
  682. package/lib/es/pagination/pagination.css +23 -0
  683. package/lib/es/pagination/pagination.scss +29 -0
  684. package/lib/es/pagination/variables.scss +1 -0
  685. package/lib/es/popconfirm/constants.js +2 -2
  686. package/lib/es/popconfirm/popconfirm.css +4 -24
  687. package/lib/es/popconfirm/popconfirm.scss +4 -16
  688. package/lib/es/popconfirm/popconfirmFoundation.d.ts +4 -0
  689. package/lib/es/popconfirm/popconfirmFoundation.js +17 -14
  690. package/lib/es/popconfirm/rtl.scss +0 -13
  691. package/lib/es/popconfirm/variables.scss +0 -4
  692. package/lib/es/popover/constants.d.ts +1 -1
  693. package/lib/es/popover/constants.js +3 -3
  694. package/lib/es/popover/popover.css +2 -0
  695. package/lib/es/popover/popover.scss +2 -0
  696. package/lib/es/progress/constants.js +1 -1
  697. package/lib/es/progress/generates.d.ts +2 -2
  698. package/lib/es/progress/generates.js +33 -73
  699. package/lib/es/radio/constants.js +13 -13
  700. package/lib/es/radio/radio.css +3 -0
  701. package/lib/es/radio/radio.scss +6 -3
  702. package/lib/es/radio/radioFoundation.js +0 -9
  703. package/lib/es/radio/radioGroupFoundation.js +3 -19
  704. package/lib/es/radio/radioInnerFoundation.js +1 -15
  705. package/lib/es/radio/variables.scss +4 -0
  706. package/lib/es/rating/constants.js +1 -1
  707. package/lib/es/rating/foundation.js +10 -55
  708. package/lib/es/scrollList/constants.js +2 -2
  709. package/lib/es/scrollList/itemFoundation.js +8 -60
  710. package/lib/es/scrollList/scrollTo.js +2 -4
  711. package/lib/es/select/constants.js +3 -3
  712. package/lib/es/select/foundation.d.ts +8 -6
  713. package/lib/es/select/foundation.js +172 -419
  714. package/lib/es/select/option.scss +1 -1
  715. package/lib/es/select/optionFoundation.js +2 -10
  716. package/lib/es/select/select.css +50 -0
  717. package/lib/es/select/select.scss +74 -5
  718. package/lib/es/select/variables.scss +9 -6
  719. package/lib/es/sideSheet/constants.js +2 -2
  720. package/lib/es/sideSheet/sideSheet.css +30 -0
  721. package/lib/es/sideSheet/sideSheet.scss +38 -0
  722. package/lib/es/sideSheet/sideSheetFoundation.d.ts +1 -0
  723. package/lib/es/sideSheet/sideSheetFoundation.js +0 -12
  724. package/lib/es/sideSheet/variables.scss +7 -0
  725. package/lib/es/skeleton/constants.js +1 -1
  726. package/lib/es/skeleton/skeleton.css +3 -2
  727. package/lib/es/skeleton/skeleton.scss +1 -0
  728. package/lib/es/skeleton/variables.scss +2 -2
  729. package/lib/es/slider/constants.d.ts +1 -0
  730. package/lib/es/slider/constants.js +8 -7
  731. package/lib/es/slider/foundation.d.ts +13 -2
  732. package/lib/es/slider/foundation.js +30 -219
  733. package/lib/es/slider/slider.css +25 -11
  734. package/lib/es/slider/slider.scss +16 -1
  735. package/lib/es/slider/variables.scss +15 -9
  736. package/lib/es/space/constants.js +1 -1
  737. package/lib/es/spin/constants.js +1 -1
  738. package/lib/es/spin/foundation.js +3 -11
  739. package/lib/es/spin/spin.css +3 -0
  740. package/lib/es/spin/spin.scss +3 -0
  741. package/lib/es/steps/bacisSteps.scss +10 -3
  742. package/lib/es/steps/constants.js +2 -2
  743. package/lib/es/steps/fillSteps.scss +7 -7
  744. package/lib/es/steps/steps.css +27 -22
  745. package/lib/es/steps/variables.scss +3 -3
  746. package/lib/es/switch/constants.js +13 -13
  747. package/lib/es/switch/foundation.js +1 -16
  748. package/lib/es/switch/switch.css +10 -0
  749. package/lib/es/switch/switch.scss +13 -2
  750. package/lib/es/table/bodyFoundation.js +1 -25
  751. package/lib/es/table/cellFoundation.js +0 -1
  752. package/lib/es/table/constants.d.ts +0 -1
  753. package/lib/es/table/constants.js +13 -16
  754. package/lib/es/table/foundation.d.ts +26 -16
  755. package/lib/es/table/foundation.js +79 -313
  756. package/lib/es/table/rtl.scss +33 -2
  757. package/lib/es/table/table.css +100 -64
  758. package/lib/es/table/table.scss +66 -8
  759. package/lib/es/table/tableRowFoundation.js +1 -9
  760. package/lib/es/table/tableSelectionCellFoundation.js +0 -2
  761. package/lib/es/table/utils.d.ts +6 -4
  762. package/lib/es/table/utils.js +25 -119
  763. package/lib/es/table/variables.scss +6 -3
  764. package/lib/es/tabs/constants.js +21 -21
  765. package/lib/es/tabs/foundation.js +2 -35
  766. package/lib/es/tabs/tabs.css +207 -7
  767. package/lib/es/tabs/tabs.scss +339 -24
  768. package/lib/es/tag/constants.js +1 -2
  769. package/lib/es/tag/tag.css +34 -1
  770. package/lib/es/tag/tag.scss +43 -4
  771. package/lib/es/tag/variables.scss +5 -0
  772. package/lib/es/tagInput/constants.js +1 -1
  773. package/lib/es/tagInput/foundation.d.ts +7 -4
  774. package/lib/es/tagInput/foundation.js +64 -78
  775. package/lib/es/tagInput/tagInput.css +35 -9
  776. package/lib/es/tagInput/tagInput.scss +41 -12
  777. package/lib/es/tagInput/utils/getSplitedArray.js +0 -7
  778. package/lib/es/tagInput/variables.scss +2 -0
  779. package/lib/es/timePicker/ComboxFoundation.js +6 -32
  780. package/lib/es/timePicker/constants.js +3 -3
  781. package/lib/es/timePicker/foundation.d.ts +2 -2
  782. package/lib/es/timePicker/foundation.js +30 -101
  783. package/lib/es/timePicker/inputFoundation.js +4 -22
  784. package/lib/es/timePicker/timePicker.css +15 -0
  785. package/lib/es/timePicker/timePicker.scss +22 -1
  786. package/lib/es/timePicker/utils/index.js +12 -30
  787. package/lib/es/timePicker/utils/localeDate.js +0 -8
  788. package/lib/es/timeline/constants.js +2 -2
  789. package/lib/es/toast/animation.scss +3 -0
  790. package/lib/es/toast/constants.js +4 -4
  791. package/lib/es/toast/toast.css +35 -3
  792. package/lib/es/toast/toast.scss +43 -3
  793. package/lib/es/toast/toastFoundation.d.ts +5 -4
  794. package/lib/es/toast/toastFoundation.js +0 -9
  795. package/lib/es/toast/toastListFoundation.d.ts +5 -0
  796. package/lib/es/toast/toastListFoundation.js +10 -18
  797. package/lib/es/toast/variables.scss +14 -0
  798. package/lib/es/tooltip/constants.d.ts +1 -1
  799. package/lib/es/tooltip/constants.js +2 -2
  800. package/lib/es/tooltip/foundation.d.ts +5 -2
  801. package/lib/es/tooltip/foundation.js +143 -332
  802. package/lib/es/tooltip/tooltip.css +7 -0
  803. package/lib/es/tooltip/tooltip.scss +9 -0
  804. package/lib/es/transfer/constants.js +1 -1
  805. package/lib/es/transfer/foundation.d.ts +1 -1
  806. package/lib/es/transfer/foundation.js +5 -62
  807. package/lib/es/transfer/transfer.css +4 -0
  808. package/lib/es/transfer/transfer.scss +7 -0
  809. package/lib/es/transfer/transferUtils.js +5 -21
  810. package/lib/es/tree/constants.js +2 -2
  811. package/lib/es/tree/foundation.d.ts +14 -9
  812. package/lib/es/tree/foundation.js +60 -176
  813. package/lib/es/tree/rtl.scss +19 -11
  814. package/lib/es/tree/tree.css +147 -65
  815. package/lib/es/tree/tree.scss +112 -17
  816. package/lib/es/tree/treeUtil.d.ts +17 -8
  817. package/lib/es/tree/treeUtil.js +102 -161
  818. package/lib/es/tree/variables.scss +3 -2
  819. package/lib/es/treeSelect/constants.js +3 -3
  820. package/lib/es/treeSelect/foundation.d.ts +26 -13
  821. package/lib/es/treeSelect/foundation.js +155 -235
  822. package/lib/es/treeSelect/treeSelect.css +55 -10
  823. package/lib/es/treeSelect/treeSelect.scss +76 -20
  824. package/lib/es/treeSelect/variables.scss +4 -2
  825. package/lib/es/typography/constants.d.ts +1 -0
  826. package/lib/es/typography/constants.js +2 -1
  827. package/lib/es/typography/formatNumeral.d.ts +3 -3
  828. package/lib/es/typography/formatNumeral.js +22 -40
  829. package/lib/es/typography/typography.css +135 -2
  830. package/lib/es/typography/typography.scss +151 -8
  831. package/lib/es/typography/variables.scss +52 -0
  832. package/lib/es/upload/constants.js +2 -2
  833. package/lib/es/upload/fileCardFoundation.d.ts +9 -0
  834. package/lib/es/upload/fileCardFoundation.js +10 -0
  835. package/lib/es/upload/foundation.d.ts +14 -5
  836. package/lib/es/upload/foundation.js +107 -240
  837. package/lib/es/upload/upload.css +9 -0
  838. package/lib/es/upload/upload.scss +8 -0
  839. package/lib/es/upload/utils.js +14 -28
  840. package/lib/es/utils/Event.js +1 -17
  841. package/lib/es/utils/FocusHandle.d.ts +1 -1
  842. package/lib/es/utils/FocusHandle.js +6 -32
  843. package/lib/es/utils/Logger.js +0 -20
  844. package/lib/es/utils/Store.js +0 -9
  845. package/lib/es/utils/a11y.js +18 -31
  846. package/lib/es/utils/array.d.ts +2 -2
  847. package/lib/es/utils/array.js +2 -7
  848. package/lib/es/utils/classnames.js +0 -10
  849. package/lib/es/utils/date-fns-extra.d.ts +28 -17
  850. package/lib/es/utils/date-fns-extra.js +78 -40
  851. package/lib/es/utils/dom.d.ts +1 -1
  852. package/lib/es/utils/dom.js +0 -9
  853. package/lib/es/utils/function.js +0 -1
  854. package/lib/es/utils/getDataAttr.js +1 -2
  855. package/lib/es/utils/getHighlight.js +5 -26
  856. package/lib/es/utils/getMotionObjFromProps.js +4 -12
  857. package/lib/es/utils/isBothNaN.js +0 -1
  858. package/lib/es/utils/isEnterPress.js +0 -2
  859. package/lib/es/utils/isEscPress.js +0 -2
  860. package/lib/es/utils/keyCode.js +0 -104
  861. package/lib/es/utils/log.js +0 -3
  862. package/lib/es/utils/object.d.ts +4 -4
  863. package/lib/es/utils/object.js +10 -29
  864. package/lib/es/utils/set.js +0 -5
  865. package/lib/es/utils/shallowEqualObjects.js +0 -6
  866. package/lib/es/utils/touchPolyfill.js +1 -6
  867. package/lib/es/utils/type.d.ts +3 -3
  868. package/lib/es/utils/uuid.js +4 -10
  869. package/lib/es/utils/warning.js +1 -1
  870. package/modal/modal.scss +10 -1
  871. package/modal/modalContentFoundation.ts +3 -3
  872. package/modal/modalFoundation.ts +32 -7
  873. package/modal/variables.scss +6 -1
  874. package/navigation/NavItem.ts +0 -2
  875. package/navigation/foundation.ts +1 -3
  876. package/navigation/itemFoundation.ts +0 -1
  877. package/navigation/subNavFoundation.ts +3 -2
  878. package/notification/notification.scss +21 -1
  879. package/notification/notificationFoundation.ts +3 -3
  880. package/notification/notificationListFoundation.ts +14 -4
  881. package/overflowList/constants.ts +4 -2
  882. package/overflowList/foundation.ts +51 -33
  883. package/package.json +6 -5
  884. package/pagination/foundation.ts +13 -3
  885. package/pagination/pagination.scss +29 -0
  886. package/pagination/variables.scss +1 -0
  887. package/popconfirm/popconfirm.scss +4 -16
  888. package/popconfirm/popconfirmFoundation.ts +20 -2
  889. package/popconfirm/rtl.scss +0 -13
  890. package/popconfirm/variables.scss +0 -4
  891. package/popover/constants.ts +1 -1
  892. package/popover/popover.scss +2 -0
  893. package/radio/radio.scss +6 -3
  894. package/radio/radioFoundation.ts +1 -1
  895. package/radio/radioGroupFoundation.ts +0 -1
  896. package/radio/radioInnerFoundation.ts +0 -1
  897. package/radio/variables.scss +4 -0
  898. package/rating/foundation.ts +0 -1
  899. package/select/foundation.ts +68 -31
  900. package/select/option.scss +1 -1
  901. package/select/optionFoundation.ts +0 -2
  902. package/select/select.scss +74 -5
  903. package/select/variables.scss +9 -6
  904. package/sideSheet/sideSheet.scss +38 -0
  905. package/sideSheet/sideSheetFoundation.ts +3 -2
  906. package/sideSheet/variables.scss +7 -0
  907. package/skeleton/skeleton.scss +1 -0
  908. package/skeleton/variables.scss +2 -2
  909. package/slider/constants.ts +1 -0
  910. package/slider/foundation.ts +25 -29
  911. package/slider/slider.scss +16 -1
  912. package/slider/variables.scss +15 -9
  913. package/spin/spin.scss +3 -0
  914. package/steps/bacisSteps.scss +10 -3
  915. package/steps/fillSteps.scss +7 -7
  916. package/steps/variables.scss +3 -3
  917. package/switch/foundation.ts +2 -4
  918. package/switch/switch.scss +13 -2
  919. package/table/bodyFoundation.ts +0 -1
  920. package/table/constants.ts +0 -3
  921. package/table/foundation.ts +33 -31
  922. package/table/rtl.scss +33 -2
  923. package/table/table.scss +66 -8
  924. package/table/tableRowFoundation.ts +0 -1
  925. package/table/utils.ts +23 -43
  926. package/table/variables.scss +6 -3
  927. package/tabs/foundation.ts +2 -2
  928. package/tabs/tabs.scss +339 -24
  929. package/tag/constants.ts +19 -2
  930. package/tag/tag.scss +43 -4
  931. package/tag/variables.scss +5 -0
  932. package/tagInput/foundation.ts +57 -3
  933. package/tagInput/tagInput.scss +41 -12
  934. package/tagInput/variables.scss +2 -0
  935. package/timePicker/foundation.ts +27 -18
  936. package/timePicker/inputFoundation.ts +0 -2
  937. package/timePicker/timePicker.scss +22 -1
  938. package/timePicker/utils/index.ts +3 -2
  939. package/toast/animation.scss +3 -0
  940. package/toast/toast.scss +43 -3
  941. package/toast/toastFoundation.ts +4 -6
  942. package/toast/toastListFoundation.ts +13 -3
  943. package/toast/variables.scss +14 -0
  944. package/tooltip/constants.ts +1 -1
  945. package/tooltip/foundation.ts +96 -58
  946. package/tooltip/tooltip.scss +9 -0
  947. package/transfer/foundation.ts +0 -1
  948. package/transfer/transfer.scss +7 -0
  949. package/tree/foundation.ts +38 -33
  950. package/tree/rtl.scss +19 -11
  951. package/tree/tree.scss +112 -17
  952. package/tree/treeUtil.ts +64 -32
  953. package/tree/variables.scss +3 -2
  954. package/treeSelect/foundation.ts +132 -70
  955. package/treeSelect/treeSelect.scss +76 -20
  956. package/treeSelect/variables.scss +4 -2
  957. package/typography/constants.ts +1 -0
  958. package/typography/formatNumeral.ts +2 -5
  959. package/typography/typography.scss +151 -8
  960. package/typography/variables.scss +52 -0
  961. package/upload/fileCardFoundation.ts +17 -0
  962. package/upload/foundation.ts +85 -10
  963. package/upload/upload.scss +8 -0
  964. package/utils/Event.ts +0 -1
  965. package/utils/a11y.ts +6 -6
  966. package/utils/array.ts +4 -4
  967. package/utils/date-fns-extra.ts +83 -22
  968. package/utils/function.ts +0 -1
  969. package/utils/getDataAttr.ts +1 -1
  970. package/utils/getMotionObjFromProps.ts +3 -2
  971. package/utils/object.ts +0 -3
@@ -1,4 +1,4 @@
1
- import { isNumber, isFunction, get, isUndefined, isString, cloneDeep, isEmpty, difference } from 'lodash';
1
+ import { isNumber, isFunction, get, isUndefined, isString, isEmpty, difference } from 'lodash';
2
2
  import { strings } from '../treeSelect/constants';
3
3
  import BaseFoundation, { DefaultAdapter } from '../base/foundation';
4
4
  import {
@@ -47,7 +47,9 @@ export interface BasicTriggerRenderProps {
47
47
  inputValue: string;
48
48
  placeholder: string;
49
49
  value: BasicTreeNodeData[];
50
- onClear: (e: any) => void
50
+ onClear: (e: any) => void;
51
+ onSearch: (inputValue: string) => void;
52
+ onRemove: (key: string) => void
51
53
  }
52
54
 
53
55
  export type BasicOnChangeWithObject = (node: BasicTreeNodeData[] | BasicTreeNodeData, e: any) => void;
@@ -95,7 +97,9 @@ export interface BasicTreeSelectProps extends Pick<BasicTreeProps,
95
97
  | 'disableStrictly'
96
98
  | 'aria-label'
97
99
  | 'checkRelation'
100
+ | 'preventScroll'
98
101
  > {
102
+ borderless?: boolean;
99
103
  motion?: Motion;
100
104
  mouseEnterDelay?: number;
101
105
  mouseLeaveDelay?: number;
@@ -127,8 +131,9 @@ export interface BasicTreeSelectProps extends Pick<BasicTreeProps,
127
131
  loadedKeys?: string[];
128
132
  showRestTagsPopover?: boolean;
129
133
  restTagsPopoverProps?: any;
134
+ clickTriggerToHide?: boolean;
130
135
  loadData?: (data: BasicTreeNodeData) => Promise<void>;
131
- onSelect?: (selectedKeys: string, selected: boolean, selectedNode: BasicTreeNodeData) => void;
136
+ onSelect?: (selectedKey: string, selected: boolean, selectedNode: BasicTreeNodeData) => void;
132
137
  searchRender?: (inputProps: any) => any;
133
138
  renderSelectedItem?: BasicRenderSelectedItem;
134
139
  getPopupContainer?: () => HTMLElement;
@@ -145,6 +150,7 @@ export interface BasicTreeSelectInnerData extends Pick<BasicTreeInnerData,
145
150
  'keyEntities'
146
151
  | 'treeData'
147
152
  | 'flattenNodes'
153
+ | 'cachedFlattenNodes'
148
154
  | 'selectedKeys'
149
155
  | 'checkedKeys'
150
156
  | 'halfCheckedKeys'
@@ -163,7 +169,7 @@ export interface BasicTreeSelectInnerData extends Pick<BasicTreeInnerData,
163
169
  > {
164
170
  inputTriggerFocus: boolean;
165
171
  isOpen: boolean;
166
- isInput: boolean;
172
+ // isInput: boolean;
167
173
  rePosKey: number;
168
174
  dropdownMinWidth: null | number;
169
175
  isHovering: boolean;
@@ -176,13 +182,14 @@ export interface TreeSelectAdapter<P = Record<string, any>, S = Record<string, a
176
182
  unregisterClickOutsideHandler: () => void;
177
183
  rePositionDropdown: () => void;
178
184
  updateState: (states: Partial<BasicTreeSelectInnerData>) => void;
179
- notifySelect: (selectedKeys: string, selected: boolean, selectedNode: BasicTreeNodeData) => void;
185
+ notifySelect: (selectedKey: string, selected: boolean, selectedNode: BasicTreeNodeData) => void;
180
186
  notifySearch: (input: string, filteredExpandedKeys: string[]) => void;
181
187
  cacheFlattenNodes: (bool: boolean) => void;
182
188
  openMenu: () => void;
183
189
  closeMenu: (cb?: () => void) => void;
184
190
  getTriggerWidth: () => boolean | number;
185
191
  setOptionWrapperWidth: (width: null | number) => void;
192
+ notifyClear: (e: any) => void;
186
193
  notifyChange: BasicOnChangeWithBasic;
187
194
  notifyChangeWithObject: BasicOnChangeWithObject;
188
195
  notifyExpand: (expandedKeys: Set<string>, expandedOtherProps: BasicExpandedOtherProps) => void;
@@ -191,10 +198,10 @@ export interface TreeSelectAdapter<P = Record<string, any>, S = Record<string, a
191
198
  toggleHovering: (bool: boolean) => void;
192
199
  notifyLoad: (newLoadedKeys: Set<string>, data: BasicTreeNodeData) => void;
193
200
  updateInputFocus: (bool: boolean) => void;
194
- updateLoadKeys: (data: BasicTreeNodeData, resolve: (value?: any) => void) => void
201
+ updateLoadKeys: (data: BasicTreeNodeData, resolve: (value?: any) => void) => void;
202
+ updateIsFocus: (bool: boolean) => void
195
203
  }
196
204
 
197
- // eslint-disable-next-line max-len
198
205
  export default class TreeSelectFoundation<P = Record<string, any>, S = Record<string, any>> extends BaseFoundation<TreeSelectAdapter<P, S>, P, S> {
199
206
 
200
207
  constructor(adapter: TreeSelectAdapter<P, S>) {
@@ -210,6 +217,9 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
210
217
  if (isOpen) {
211
218
  this.open();
212
219
  }
220
+ if (triggerSearchAutoFocus) {
221
+ this.handleTriggerFocus(null);
222
+ }
213
223
  }
214
224
 
215
225
  destroy() {
@@ -262,12 +272,38 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
262
272
  return Boolean(inputValue) && showFilteredOnly;
263
273
  }
264
274
 
265
- getCopyFromState(items: string | string[]) {
266
- const res = {};
267
- normalizedArr(items).forEach(key => {
268
- res[key] = cloneDeep(this.getState(key));
275
+ findDataForValue(findValue: string) {
276
+ const { value, defaultValue, keyMaps } = this.getProps();
277
+ const realValueName = get(keyMaps, 'value', 'value');
278
+ const realKeyName = get(keyMaps, 'key', 'key');
279
+ let valueArr = [];
280
+ if (value) {
281
+ valueArr = Array.isArray(value) ? value : [value];
282
+ } else if (defaultValue) {
283
+ valueArr = Array.isArray(defaultValue) ? defaultValue : [defaultValue];
284
+ }
285
+ return valueArr.find(item => {
286
+ return item[realValueName] === findValue || item[realKeyName] === findValue;
269
287
  });
270
- return res as BasicTreeInnerData;
288
+ }
289
+
290
+ constructDataForValue(value: string) {
291
+ const { treeNodeLabelProp, keyMaps } = this.getProps();
292
+ const keyName = get(keyMaps, 'key', 'key');
293
+ const labelName = get(keyMaps, 'label', treeNodeLabelProp);
294
+ return {
295
+ [keyName]: value,
296
+ [labelName]: value
297
+ };
298
+ }
299
+
300
+ getDataForKeyNotInKeyEntities(value: string) {
301
+ const { onChangeWithObject } = this.getProps();
302
+ if (onChangeWithObject) {
303
+ return this.findDataForValue(value);
304
+ } else {
305
+ return this.constructDataForValue(value);
306
+ }
271
307
  }
272
308
 
273
309
  getTreeNodeProps(key: string) {
@@ -304,9 +340,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
304
340
  const isSearching = Boolean(inputValue);
305
341
  const treeNodeProps: BasicTreeNodeProps = {
306
342
  eventKey: key,
307
- expanded: isSearching && !this._isExpandControlled()
308
- ? filteredExpandedKeys.has(key)
309
- : expandedKeys.has(key),
343
+ expanded: isSearching ? filteredExpandedKeys.has(key) : expandedKeys.has(key),
310
344
  selected: selectedKeys.includes(key),
311
345
  checked: realChecked,
312
346
  halfChecked: realHalfChecked,
@@ -333,10 +367,8 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
333
367
  return {};
334
368
  }
335
369
  loadData(data).then(() => {
336
- const {
337
- loadedKeys: prevLoadedKeys,
338
- loadingKeys: prevLoadingKeys
339
- } = this.getCopyFromState(['loadedKeys', 'loadingKeys']);
370
+ const prevLoadedKeys = new Set(this.getState('loadedKeys')) as Set<string>;
371
+ const prevLoadingKeys = new Set(this.getState('loadingKeys')) as Set<string>;
340
372
  const newLoadedKeys: Set<string> = prevLoadedKeys.add(key);
341
373
  const newLoadingKeys: Set<string> = new Set([...prevLoadingKeys]);
342
374
  newLoadingKeys.delete(key);
@@ -363,29 +395,30 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
363
395
 
364
396
  _notifyMultipleChange(key: string[], e: any) {
365
397
  const { keyEntities } = this.getStates();
366
- const { leafOnly, checkRelation } = this.getProps();
398
+ const { leafOnly, checkRelation, keyMaps } = this.getProps();
367
399
  let keyList = [];
368
400
  if (checkRelation === 'related') {
369
- keyList = normalizeKeyList(key, keyEntities, leafOnly);
401
+ keyList = normalizeKeyList(key, keyEntities, leafOnly, true);
370
402
  } else if (checkRelation === 'unRelated') {
371
403
  keyList = key as string[];
372
404
  }
373
- const nodes = keyList.map(i => keyEntities[i].data);
405
+ const nodes = keyList.map(key => (keyEntities[key] && keyEntities[key].key === key) ? keyEntities[key].data : this.getDataForKeyNotInKeyEntities(key));
374
406
  if (this.getProp('onChangeWithObject')) {
375
407
  this._adapter.notifyChangeWithObject(nodes, e);
376
408
  } else {
377
- const value = getValueOrKey(nodes);
409
+ const value = getValueOrKey(nodes, keyMaps);
378
410
  this._adapter.notifyChange(value, nodes, e);
379
411
  }
380
412
  }
381
413
 
382
414
  _notifyChange(key: any, e: any) {
383
415
  const { keyEntities } = this.getStates();
416
+ const { keyMaps } = this.getProps();
384
417
  if (this._isMultiple() && Array.isArray(key)) {
385
418
  this._notifyMultipleChange(key, e);
386
419
  } else {
387
420
  const nodes = isUndefined(key) ? key : keyEntities[key].data;
388
- const value = isUndefined(key) ? key : getValueOrKey(nodes);
421
+ const value = isUndefined(key) ? key : getValueOrKey(nodes, keyMaps);
389
422
  if (this.getProp('onChangeWithObject')) {
390
423
  this._adapter.notifyChangeWithObject(nodes, e);
391
424
  } else {
@@ -394,12 +427,30 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
394
427
  }
395
428
  }
396
429
 
430
+ _registerClickOutsideHandler = (e) => {
431
+ this._adapter.registerClickOutsideHandler(e => {
432
+ this.handlerTriggerBlur(e);
433
+ this.close(e);
434
+ });
435
+ }
436
+
437
+ clearInputValue = () => {
438
+ const { inputValue } = this.getStates();
439
+ inputValue && this._adapter.updateInputValue('');
440
+ }
441
+
397
442
  // Scenes that may trigger focus:
398
443
  // 1、click selection
399
444
  _notifyFocus(e: any) {
400
445
  this._adapter.notifyFocus(e);
401
446
  }
402
447
 
448
+ handleTriggerFocus(e: any) {
449
+ this._adapter.updateIsFocus(true);
450
+ this._notifyFocus(e);
451
+ this._registerClickOutsideHandler(e);
452
+ }
453
+
403
454
  // Scenes that may trigger blur
404
455
  // 1、clickOutSide
405
456
  // 2、click option / press enter, and then select complete(when multiple is false
@@ -408,6 +459,12 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
408
459
  this._adapter.notifyBlur(e);
409
460
  }
410
461
 
462
+ handlerTriggerBlur(e) {
463
+ this._adapter.updateIsFocus(false);
464
+ this._notifyBlur(e);
465
+ this._adapter.unregisterClickOutsideHandler();
466
+ }
467
+
411
468
  toggleHoverState(bool: boolean) {
412
469
  this._adapter.toggleHovering(bool);
413
470
  }
@@ -415,15 +472,10 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
415
472
  open() {
416
473
  this._adapter.openMenu();
417
474
  this._setDropdownWidth();
418
- this._adapter.registerClickOutsideHandler(e => {
419
- this.close(e);
420
- });
421
475
  }
422
476
 
423
477
  close(e: any) {
424
478
  this._adapter.closeMenu();
425
- this._adapter.unregisterClickOutsideHandler();
426
- this._notifyBlur(e);
427
479
  if (this.getProp('motionExpand')) {
428
480
  this._adapter.updateState({ motionKeys: new Set([]) });
429
481
  }
@@ -431,18 +483,22 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
431
483
 
432
484
  handleClick(e: any) {
433
485
  const isDisabled = this._isDisabled();
434
- const { isOpen, inputValue } = this.getStates();
435
- const { searchPosition } = this.getProps();
486
+ const { isOpen, inputValue, isFocus } = this.getStates();
487
+ const { searchPosition, clickTriggerToHide } = this.getProps();
436
488
  if (isDisabled) {
437
489
  return;
438
- } else if (!isOpen) {
439
- this.open();
440
- this._notifyFocus(e);
441
- } else if (isOpen) {
442
- if (searchPosition === 'trigger' && inputValue) {
443
- return;
490
+ } else {
491
+ if (!isFocus) {
492
+ this.handleTriggerFocus(e);
493
+ }
494
+ if (isOpen) {
495
+ if (searchPosition === 'trigger' && inputValue) {
496
+ return;
497
+ }
498
+ clickTriggerToHide && this.close(e);
499
+ } else {
500
+ this.open();
444
501
  }
445
- this.close(e);
446
502
  }
447
503
  }
448
504
 
@@ -483,6 +539,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
483
539
  }
484
540
  }
485
541
  }
542
+ this._adapter.notifyClear(e);
486
543
  }
487
544
 
488
545
  /**
@@ -496,10 +553,11 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
496
553
  }
497
554
 
498
555
  removeTag(eventKey: BasicTreeNodeData['key']) {
499
- const { disableStrictly, checkRelation } = this.getProps();
556
+ const { disableStrictly, checkRelation, keyMaps } = this.getProps();
500
557
  const { keyEntities, disabledKeys, realCheckedKeys } = this.getStates();
501
- const item = keyEntities[eventKey].data;
502
- if (item.disabled || (disableStrictly && disabledKeys.has(eventKey))) {
558
+ const item = (keyEntities[eventKey] && keyEntities[eventKey].key === eventKey) ? keyEntities[eventKey].data : this.getDataForKeyNotInKeyEntities(eventKey);
559
+ const disabledName = get(keyMaps, 'disabled', 'disabled');
560
+ if (item[disabledName] || (disableStrictly && disabledKeys.has(eventKey))) {
503
561
  return;
504
562
  }
505
563
  if (checkRelation === 'unRelated') {
@@ -527,15 +585,16 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
527
585
 
528
586
  clearInput() {
529
587
  const { flattenNodes, expandedKeys, selectedKeys, keyEntities, treeData } = this.getStates();
588
+ const { keyMaps } = this.getProps();
530
589
  const newExpandedKeys: Set<string> = new Set(expandedKeys);
531
590
  const isExpandControlled = this._isExpandControlled();
532
591
  const expandedOptsKeys = findAncestorKeys(selectedKeys, keyEntities);
533
592
  expandedOptsKeys.forEach(item => newExpandedKeys.add(item));
534
- const newFlattenNodes = flattenTreeData(treeData, newExpandedKeys);
593
+ const newFlattenNodes = flattenTreeData(treeData, newExpandedKeys, keyMaps);
535
594
 
536
595
  this._adapter.updateState({
537
- expandedKeys: isExpandControlled ? expandedKeys : newExpandedKeys,
538
- flattenNodes: isExpandControlled ? flattenNodes : newFlattenNodes,
596
+ expandedKeys: newExpandedKeys,
597
+ flattenNodes: newFlattenNodes,
539
598
  inputValue: '',
540
599
  motionKeys: new Set([]),
541
600
  filteredKeys: new Set([]),
@@ -548,7 +607,8 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
548
607
  // Input is used as controlled component
549
608
  this._adapter.updateInputValue(sugInput);
550
609
  const { flattenNodes, expandedKeys, selectedKeys, keyEntities, treeData } = this.getStates();
551
- const { showFilteredOnly, filterTreeNode, treeNodeFilterProp } = this.getProps();
610
+ const { showFilteredOnly, filterTreeNode, treeNodeFilterProp, keyMaps } = this.getProps();
611
+ const realFilterProp = treeNodeFilterProp !== 'label' ? treeNodeFilterProp : get(keyMaps, 'label', 'label');
552
612
  const newExpandedKeys: Set<string> = new Set(expandedKeys);
553
613
  let filteredOptsKeys: string[] = [];
554
614
  let expandedOptsKeys = [];
@@ -557,24 +617,24 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
557
617
  if (!sugInput) {
558
618
  expandedOptsKeys = findAncestorKeys(selectedKeys, keyEntities);
559
619
  expandedOptsKeys.forEach(item => newExpandedKeys.add(item));
560
- newFlattenNodes = flattenTreeData(treeData, newExpandedKeys);
620
+ newFlattenNodes = flattenTreeData(treeData, newExpandedKeys, keyMaps);
561
621
  } else {
562
622
  filteredOptsKeys = Object.values(keyEntities)
563
623
  .filter((item: BasicKeyEntity) => {
564
624
  const { data } = item;
565
- return filter(sugInput, data, filterTreeNode, treeNodeFilterProp);
625
+ return filter(sugInput, data, filterTreeNode, realFilterProp);
566
626
  })
567
627
  .map((item: BasicKeyEntity) => item.key);
568
628
  expandedOptsKeys = findAncestorKeys(filteredOptsKeys, keyEntities, false);
569
629
  const shownChildKeys = findDescendantKeys(filteredOptsKeys, keyEntities, true);
570
630
  filteredShownKeys = new Set([...shownChildKeys, ...expandedOptsKeys]);
571
- newFlattenNodes = flattenTreeData(treeData, new Set(expandedOptsKeys), showFilteredOnly && filteredShownKeys);
631
+ newFlattenNodes = flattenTreeData(treeData, new Set(expandedOptsKeys), keyMaps, showFilteredOnly && filteredShownKeys);
572
632
  }
573
633
  const newFilteredExpandedKeys = new Set(expandedOptsKeys);
574
634
  this._adapter.notifySearch(sugInput, Array.from(newFilteredExpandedKeys));
575
635
  this._adapter.updateState({
576
- expandedKeys: this._isExpandControlled() ? expandedKeys : newExpandedKeys,
577
- flattenNodes: this._isExpandControlled() ? flattenNodes : newFlattenNodes,
636
+ expandedKeys: newExpandedKeys,
637
+ flattenNodes: newFlattenNodes,
578
638
  motionKeys: new Set([]),
579
639
  filteredKeys: new Set(filteredOptsKeys),
580
640
  filteredExpandedKeys: newFilteredExpandedKeys,
@@ -595,7 +655,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
595
655
  }
596
656
 
597
657
  handleSingleSelect(e: any, treeNode: BasicTreeNodeProps) {
598
- let { selectedKeys } = this.getCopyFromState('selectedKeys');
658
+ let selectedKeys = [...this.getState('selectedKeys')];
599
659
  const { clickToHide } = this.getProps();
600
660
  const { selected, eventKey, data } = treeNode;
601
661
  this._adapter.notifySelect(eventKey, true, data);
@@ -609,15 +669,14 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
609
669
  }
610
670
  if (clickToHide && (this._isSelectToClose() || !data.children)) {
611
671
  this.close(e);
672
+ this.handlerTriggerBlur(e);
612
673
  }
613
674
  }
614
675
 
615
676
  calcCheckedKeys(eventKey: BasicTreeNodeProps['eventKey'], targetStatus: boolean) {
616
677
  const { keyEntities } = this.getStates();
617
- const {
618
- checkedKeys,
619
- halfCheckedKeys
620
- } = this.getCopyFromState(['checkedKeys', 'halfCheckedKeys']);
678
+ const checkedKeys = new Set(this.getState('checkedKeys')) as Set<string>;
679
+ const halfCheckedKeys = new Set(this.getState('halfCheckedKeys')) as Set<string>;
621
680
  if (targetStatus) {
622
681
  return calcCheckedKeysForChecked(eventKey, keyEntities, checkedKeys, halfCheckedKeys);
623
682
  } else {
@@ -667,7 +726,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
667
726
 
668
727
  calcNonDisabledCheckedKeys(eventKey: string, targetStatus: boolean) {
669
728
  const { keyEntities, disabledKeys } = this.getStates();
670
- const { checkedKeys } = this.getCopyFromState(['checkedKeys']);
729
+ const checkedKeys = new Set(this.getState('checkedKeys'));
671
730
  const descendantKeys = normalizeKeyList(findDescendantKeys([eventKey], keyEntities, false), keyEntities, true);
672
731
  const hasDisabled = descendantKeys.some(key => disabledKeys.has(key));
673
732
  if (!hasDisabled) {
@@ -676,7 +735,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
676
735
  const nonDisabled = descendantKeys.filter(key => !disabledKeys.has(key));
677
736
  const newCheckedKeys = targetStatus ?
678
737
  [...nonDisabled, ...checkedKeys] :
679
- difference(normalizeKeyList([...checkedKeys], keyEntities, true), nonDisabled);
738
+ difference(normalizeKeyList([...checkedKeys], keyEntities, true, true), nonDisabled);
680
739
  return calcCheckedKeys(newCheckedKeys, keyEntities);
681
740
  }
682
741
 
@@ -695,10 +754,10 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
695
754
  return !allChecked;
696
755
  }
697
756
  handleNodeExpandInSearch(e: any, treeNode: BasicTreeNodeProps) {
698
- const { treeData, filteredShownKeys, keyEntities } = this.getStates();
757
+ const { treeData, filteredShownKeys, keyEntities, keyMaps } = this.getStates();
699
758
  const showFilteredOnly = this._showFilteredOnly();
700
759
  // clone otherwise will be modified unexpectedly
701
- const { filteredExpandedKeys } = this.getCopyFromState('filteredExpandedKeys');
760
+ const filteredExpandedKeys = new Set(this.getState('filteredExpandedKeys')) as Set<string>;
702
761
  let motionType = 'show';
703
762
  const { eventKey, expanded, data } = treeNode;
704
763
 
@@ -715,7 +774,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
715
774
 
716
775
  if (!this._isExpandControlled()) {
717
776
  // debugger;
718
- const flattenNodes = flattenTreeData(treeData, filteredExpandedKeys, showFilteredOnly && filteredShownKeys);
777
+ const flattenNodes = flattenTreeData(treeData, filteredExpandedKeys, keyMaps, showFilteredOnly && filteredShownKeys);
719
778
  const motionKeys = this._isAnimated() ? getMotionKeys(eventKey, filteredExpandedKeys, keyEntities) : [];
720
779
  const newState = {
721
780
  filteredExpandedKeys,
@@ -735,7 +794,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
735
794
 
736
795
  handleNodeExpand(e: any, treeNode: BasicTreeNodeProps) {
737
796
  // debugger;
738
- const { loadData } = this.getProps();
797
+ const { loadData, keyMaps } = this.getProps();
739
798
  const { inputValue, keyEntities } = this.getStates();
740
799
  const isSearching = Boolean(inputValue);
741
800
  if (!loadData && (!treeNode.children || !treeNode.children.length)) {
@@ -743,14 +802,14 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
743
802
  }
744
803
 
745
804
  const isExpandControlled = this._isExpandControlled();
746
- if (isSearching && !isExpandControlled) {
805
+ if (isSearching) {
747
806
  this.handleNodeExpandInSearch(e, treeNode);
748
807
  return;
749
808
  }
750
809
 
751
810
  const { treeData } = this.getStates();
752
811
  // clone otherwise will be modified unexpectedly
753
- const { expandedKeys } = this.getCopyFromState('expandedKeys');
812
+ const expandedKeys = new Set(this.getState('expandedKeys')) as Set<string>;
754
813
  let motionType = 'show';
755
814
  const { eventKey, expanded, data } = treeNode;
756
815
  if (!expanded) {
@@ -763,7 +822,7 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
763
822
 
764
823
  if (!isExpandControlled) {
765
824
  // debugger;
766
- const flattenNodes = flattenTreeData(treeData, expandedKeys);
825
+ const flattenNodes = flattenTreeData(treeData, expandedKeys, keyMaps);
767
826
  const motionKeys = this._isAnimated() ? getMotionKeys(eventKey, expandedKeys, keyEntities) : [];
768
827
  const newState = {
769
828
  expandedKeys,
@@ -784,15 +843,18 @@ export default class TreeSelectFoundation<P = Record<string, any>, S = Record<st
784
843
  * The selected items that need to be displayed in the search box when obtaining a single selection
785
844
  */
786
845
  getRenderTextInSingle() {
787
- const { renderSelectedItem: propRenderSelectedItem, treeNodeLabelProp } = this.getProps();
846
+ const { renderSelectedItem: propRenderSelectedItem, treeNodeLabelProp, keyMaps } = this.getProps();
788
847
  const { selectedKeys, keyEntities } = this.getStates();
848
+ const realLabelName = get(keyMaps, 'label', treeNodeLabelProp);
789
849
  const renderSelectedItem = isFunction(propRenderSelectedItem) ?
790
850
  propRenderSelectedItem :
791
- (item: BasicTreeNodeData) => get(item, treeNodeLabelProp, null);
792
- const item = selectedKeys.length && keyEntities[selectedKeys[0]] ?
793
- keyEntities[selectedKeys[0]].data :
794
- undefined;
795
- const renderText = item && treeNodeLabelProp in item ? renderSelectedItem(item) : null;
851
+ (item: BasicTreeNodeData) => get(item, realLabelName, null);
852
+ let item;
853
+ if (selectedKeys.length) {
854
+ const key = selectedKeys[0];
855
+ item = (keyEntities[key] && keyEntities[key].key === key) ? keyEntities[key].data : this.getDataForKeyNotInKeyEntities(key);
856
+ }
857
+ const renderText = item ? renderSelectedItem(item) : null;
796
858
  return renderText;
797
859
  }
798
860
 
@@ -16,16 +16,41 @@ $module: #{$prefix}-tree-select;
16
16
  position: relative;
17
17
  cursor: pointer;
18
18
 
19
+
19
20
  &:hover {
20
21
  background-color: $color-treeSelect_default-bg-hover;
21
22
  border: $width-treeSelect_hover-border solid $color-treeSelect_default-border-hover;
22
23
  }
23
24
 
25
+ &:focus {
26
+ border: $width-treeSelect_focus-border solid $color-treeSelect_default-border-focus;
27
+ background-color: $color-treeSelect_default-bg-focus;
28
+ outline: 0;
29
+ }
30
+
31
+ &:active{
32
+ background-color: $color-treeSelect_default-bg-active;
33
+ }
34
+
35
+
24
36
  &-focus {
37
+ background-color: $color-treeSelect_default-bg-focus;
25
38
  border: $width-treeSelect_focus-border solid $color-treeSelect_default-border-focus;
26
39
  outline: 0;
40
+
41
+ &:hover {
42
+ background-color: $color-treeSelect_default-bg-focus;
43
+ border: $width-treeSelect_focus-border solid $color-treeSelect_default-border-focus;
44
+ outline: 0;
45
+ }
46
+
47
+
48
+ &:active{
49
+ background-color: $color-treeSelect_default-bg-active;
50
+ }
27
51
  }
28
52
 
53
+
29
54
  &-warning {
30
55
  background-color: $color-treeSelect_warning-bg-default;
31
56
  border-color: $color-treeSelect_warning-border-default;
@@ -108,11 +133,15 @@ $module: #{$prefix}-tree-select;
108
133
  padding-right: 0;
109
134
  cursor: pointer;
110
135
  color: $color-treeSelect_selection-text-default;
136
+ position: relative;
111
137
 
112
- &-placeholder {
138
+ &-content {
113
139
  overflow: hidden;
114
140
  white-space: nowrap;
115
141
  text-overflow: ellipsis;
142
+ }
143
+
144
+ &-placeholder {
116
145
  color: $color-treeSelect_input_placeholder-text-default;
117
146
  }
118
147
 
@@ -129,6 +158,10 @@ $module: #{$prefix}-tree-select;
129
158
 
130
159
  &-TriggerSearchItem {
131
160
  position: absolute;
161
+ max-width: calc(100% - $spacing-treeSelect_selection-paddingLeft);
162
+ text-overflow: ellipsis;
163
+ overflow: hidden;
164
+ white-space: nowrap;
132
165
 
133
166
  &-placeholder {
134
167
  opacity: .6;
@@ -171,23 +204,20 @@ $module: #{$prefix}-tree-select;
171
204
  .#{$prefix}-tagInput {
172
205
  border: hidden;
173
206
  background: transparent;
207
+ min-height: $height-treeSelect_selection_tagInput_wrapper_default;
208
+
209
+ &-small {
210
+ min-height: $height-treeSelect_selection_tagInput_wrapper_small;
211
+ }
212
+
213
+ &-large {
214
+ min-height: $height-treeSelect_selection_tagInput_wrapper_large;
215
+ }
174
216
 
175
217
  .#{$prefix}-tagInput-wrapper {
176
218
  padding-left: $spacing-treeSelect_selection_tagInput_wrapper-paddingX;
177
219
  padding-right: $spacing-treeSelect_selection_tagInput_wrapper-paddingX;
178
220
 
179
- &-default {
180
- min-height: $height-treeSelect_selection_tagInput_wrapper_default;
181
- }
182
-
183
- &-small {
184
- min-height: $height-treeSelect_selection_tagInput_wrapper_small;
185
- }
186
-
187
- &-large {
188
- min-height: $height-treeSelect_selection_tagInput_wrapper_large;
189
- }
190
-
191
221
  .#{$prefix}-input-wrapper {
192
222
  // height: $height-treeSelect_selection_tagInput_input_default;
193
223
 
@@ -205,13 +235,6 @@ $module: #{$prefix}-tree-select;
205
235
  margin-bottom: $spacing-treeSelect_tag-marginY;
206
236
  }
207
237
  }
208
-
209
- // .#{$prefix}-input-wrapper-small {
210
- // height: $height-treeSelect_selection_tagInput_input_small;
211
- // }
212
- // .#{$prefix}-input-wrapper-large {
213
- // height: $height-treeSelect_selection_tagInput_input_large;
214
- // }
215
238
  }
216
239
  }
217
240
  }
@@ -357,4 +380,37 @@ $module: #{$prefix}-tree-select;
357
380
  }
358
381
  }
359
382
 
383
+ .#{$module}-borderless{
384
+
385
+ &:not(:focus-within):not(:hover){
386
+ background-color:transparent;
387
+ border-color: transparent;
388
+ .#{$module}-arrow {
389
+ opacity: 0;
390
+ }
391
+ }
392
+
393
+ &:focus-within:not(:active){
394
+ background-color:transparent;
395
+ }
396
+
397
+ // split style into not and normal to avoid style override
398
+ &.#{$module}-error:not(:focus-within){
399
+ border-color: $color-treeSelect_danger-border-focus;
400
+ }
401
+
402
+ &.#{$module}-warning:not(:focus-within){
403
+ border-color: $color-treeSelect_warning-border-focus;
404
+ }
405
+
406
+ &.#{$module}-error:focus-within{
407
+ border-color: $color-treeSelect_danger-border-focus;
408
+ }
409
+
410
+ &.#{$module}-warning:focus-within{
411
+ border-color: $color-treeSelect_warning-border-focus;
412
+ }
413
+
414
+ }
415
+
360
416
  @import './rtl.scss';
@@ -1,12 +1,14 @@
1
1
  $color-treeSelect_default-bg-default: var(--semi-color-fill-0); // 树选择器选择框背景颜色 - 默认
2
+ $color-treeSelect_default-bg-hover: var(--semi-color-fill-1); // 树选择器选择框背景颜色 - 悬停
3
+ $color-treeSelect_default-bg-active: var(--semi-color-fill-2); // 树选择器选择框背景颜色 - 按下
4
+ $color-treeSelect_default-bg-focus: var(--semi-color-fill-0); // 树选择器选择框背景颜色 - 选中
2
5
  $color-treeSelect_default-border-default: transparent; // 树选择器选择框描边颜色 - 默认
3
6
  $color-treeSelect_selection-text-default: var(--semi-color-text-0); // 树选择器选择框回填内容文本颜色 - 默认
4
7
  $color-treeSelect_default-icon-default: var(--semi-color-text-2); // 树选择器选择框图标颜色 - 默认
5
8
  $color-treeSelect_default-icon-hover: var(--semi-color-primary-hover); // 树选择器选择框清空按钮颜色 - 悬停
6
9
  $color-treeSelect_default-icon-active: var(--semi-color-primary-active); // 树选择器选择框清空按钮颜色 - 按下
7
- $color-treeSelect_default-bg-hover: var(--semi-color-fill-1); // 树选择器选择框背景颜色 - 悬停
8
10
 
9
- $color-treeSelect_default-border-hover: inherit; // 树选择器选择框描边颜色 - 悬浮
11
+ $color-treeSelect_default-border-hover: transparent; // 树选择器选择框描边颜色 - 悬浮
10
12
  $color-treeSelect_default-border-focus: var(--semi-color-focus-border);// 树选择器选择框描边颜色 - 选中
11
13
 
12
14
  $color-treeSelect_search-border-default: var(--semi-color-fill-0); // 树选择器菜单搜索框描边颜色 - 默认
@@ -5,6 +5,7 @@ const cssClasses = {
5
5
  };
6
6
 
7
7
  const strings = {
8
+ WEIGHT: ['light', 'regular', 'medium', 'semibold', 'bold', "default"],
8
9
  TYPE: ['primary', 'secondary', 'danger', 'warning', 'success', 'tertiary', 'quaternary'],
9
10
  SIZE: ['normal', 'small'],
10
11
  SPACING: ['normal', 'extended'],