tntd 2.6.7 → 2.7.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 (812) hide show
  1. package/es/_util/colors.js +3 -0
  2. package/es/_util/colors.js.map +1 -0
  3. package/es/_util/easings.js +9 -0
  4. package/es/_util/easings.js.map +1 -0
  5. package/es/_util/getDataOrAriaProps.js +8 -0
  6. package/es/_util/getDataOrAriaProps.js.map +1 -0
  7. package/es/_util/getScroll.js +14 -0
  8. package/es/_util/getScroll.js.map +1 -0
  9. package/es/_util/interopDefault.js +5 -0
  10. package/es/_util/interopDefault.js.map +1 -0
  11. package/es/_util/isNumeric.js +4 -0
  12. package/es/_util/isNumeric.js.map +1 -0
  13. package/es/_util/motion.js +22 -0
  14. package/es/_util/motion.js.map +1 -0
  15. package/es/_util/openAnimation.js +51 -0
  16. package/es/_util/openAnimation.js.map +1 -0
  17. package/es/_util/raf.js +25 -0
  18. package/es/_util/raf.js.map +1 -0
  19. package/es/_util/reactNode.js +6 -0
  20. package/es/_util/reactNode.js.map +1 -0
  21. package/es/_util/ref.js +15 -0
  22. package/es/_util/ref.js.map +1 -0
  23. package/es/_util/responsiveObserve.js +82 -0
  24. package/es/_util/responsiveObserve.js.map +1 -0
  25. package/es/_util/scrollTo.js +29 -0
  26. package/es/_util/scrollTo.js.map +1 -0
  27. package/es/_util/styleChecker.js +12 -0
  28. package/es/_util/styleChecker.js.map +1 -0
  29. package/es/_util/throttleByAnimationFrame.js +40 -0
  30. package/es/_util/throttleByAnimationFrame.js.map +1 -0
  31. package/es/_util/transButton.js +103 -0
  32. package/es/_util/transButton.js.map +1 -0
  33. package/es/_util/triggerEvent.js +8 -0
  34. package/es/_util/triggerEvent.js.map +1 -0
  35. package/es/_util/type.js +3 -0
  36. package/es/_util/type.js.map +1 -0
  37. package/es/_util/warning.js +5 -0
  38. package/es/_util/warning.js.map +1 -0
  39. package/es/_util/wave.js +228 -0
  40. package/es/_util/wave.js.map +1 -0
  41. package/es/affix/index.js +1 -2
  42. package/es/alert/index.js +1 -2
  43. package/es/anchor/index.js +1 -2
  44. package/es/array-input/icon.js +24 -6
  45. package/es/array-input/index.js +203 -119
  46. package/es/auth-context/index.js +1 -2
  47. package/es/auto-complete/index.js +1 -2
  48. package/es/avatar/index.js +1 -2
  49. package/es/back-top/index.js +1 -2
  50. package/es/badge/index.js +1 -2
  51. package/es/breadcrumb/index.js +1 -2
  52. package/es/button/index.js +1 -2
  53. package/es/calendar/index.js +1 -2
  54. package/es/card/index.js +1 -2
  55. package/es/carousel/index.js +1 -2
  56. package/es/cascader/index.js +6 -3
  57. package/es/cascader/index.js.map +1 -1
  58. package/es/checkbox/checkbox-group.js +5 -0
  59. package/es/checkbox/checkbox-group.js.map +1 -0
  60. package/es/checkbox/index.js +6 -2
  61. package/es/checkbox/index.js.map +1 -1
  62. package/es/col/index.js +1 -2
  63. package/es/collapse/index.js +1 -2
  64. package/es/color-picker/ColorPicker.js +126 -80
  65. package/es/color-picker/index.js +8 -5
  66. package/es/columns/index.js +66 -30
  67. package/es/columns/style/index.js +1 -2
  68. package/es/comment/index.js +1 -2
  69. package/es/config-provider/DisabledContext.js +12 -0
  70. package/es/config-provider/DisabledContext.js.map +1 -0
  71. package/es/config-provider/SizeContext.js +9 -0
  72. package/es/config-provider/SizeContext.js.map +1 -0
  73. package/es/config-provider/config-provider.js +1 -2
  74. package/es/config-provider/context.js +41 -0
  75. package/es/config-provider/context.js.map +1 -0
  76. package/es/config-provider/index.js +4 -0
  77. package/es/config-provider/index.js.map +1 -1
  78. package/es/connect/index.js +26 -0
  79. package/es/connect/index.js.map +1 -0
  80. package/es/date-picker/index.js +11 -1
  81. package/es/date-picker/index.js.map +1 -1
  82. package/es/input/input.js +37 -25
  83. package/es/input/input.js.map +1 -1
  84. package/es/input-number/index.js +3 -1
  85. package/es/input-number/index.js.map +1 -1
  86. package/es/preview-text/index.js +195 -0
  87. package/es/preview-text/index.js.map +1 -0
  88. package/es/preview-text/index.less +3 -0
  89. package/es/query-form/index.js.map +1 -1
  90. package/es/radio/index.js +3 -0
  91. package/es/radio/index.js.map +1 -1
  92. package/es/radio/radio-group.js +6 -0
  93. package/es/radio/radio-group.js.map +1 -0
  94. package/es/select/index.js.map +1 -1
  95. package/es/select/select.js +17 -5
  96. package/es/select/select.js.map +1 -1
  97. package/es/switch/index.js +2 -3
  98. package/es/switch/index.js.map +1 -1
  99. package/es/switch/switch.js +9 -0
  100. package/es/switch/switch.js.map +1 -0
  101. package/es/table/table.less +2 -0
  102. package/es/time-picker/index.js +3 -1
  103. package/es/time-picker/index.js.map +1 -1
  104. package/es/tntd-form/ErrorList.js +53 -0
  105. package/es/tntd-form/ErrorList.js.map +1 -0
  106. package/es/tntd-form/Form.js +101 -0
  107. package/es/tntd-form/Form.js.map +1 -0
  108. package/es/tntd-form/FormItem/ItemHolder.js +135 -0
  109. package/es/tntd-form/FormItem/ItemHolder.js.map +1 -0
  110. package/es/tntd-form/FormItem/index.js +238 -0
  111. package/es/tntd-form/FormItem/index.js.map +1 -0
  112. package/es/tntd-form/FormItemInput.js +38 -0
  113. package/es/tntd-form/FormItemInput.js.map +1 -0
  114. package/es/tntd-form/FormItemLabel.js +73 -0
  115. package/es/tntd-form/FormItemLabel.js.map +1 -0
  116. package/es/tntd-form/FormList.js +34 -0
  117. package/es/tntd-form/FormList.js.map +1 -0
  118. package/es/tntd-form/TntdForm/components/ItemComp.js +2 -2
  119. package/es/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  120. package/es/tntd-form/__tests__/demo-extend.test.js +3 -0
  121. package/es/tntd-form/__tests__/demo-extend.test.js.map +1 -0
  122. package/es/tntd-form/__tests__/demo.test.js +3 -0
  123. package/es/tntd-form/__tests__/demo.test.js.map +1 -0
  124. package/es/tntd-form/__tests__/image.test.js +5 -0
  125. package/es/tntd-form/__tests__/image.test.js.map +1 -0
  126. package/es/tntd-form/__tests__/index.test.js +957 -0
  127. package/es/tntd-form/__tests__/index.test.js.map +1 -0
  128. package/es/tntd-form/__tests__/list-noStyle.test.js +41 -0
  129. package/es/tntd-form/__tests__/list-noStyle.test.js.map +1 -0
  130. package/es/tntd-form/__tests__/list.test.js +164 -0
  131. package/es/tntd-form/__tests__/list.test.js.map +1 -0
  132. package/es/tntd-form/__tests__/ref.test.js +45 -0
  133. package/es/tntd-form/__tests__/ref.test.js.map +1 -0
  134. package/es/tntd-form/__tests__/type.test.js +74 -0
  135. package/es/tntd-form/__tests__/type.test.js.map +1 -0
  136. package/es/tntd-form/_util/motion.js +38 -0
  137. package/es/tntd-form/_util/motion.js.map +1 -0
  138. package/es/tntd-form/_util/reactNode.js +15 -0
  139. package/es/tntd-form/_util/reactNode.js.map +1 -0
  140. package/es/tntd-form/_util/scrollTo.js +35 -0
  141. package/es/tntd-form/_util/scrollTo.js.map +1 -0
  142. package/es/tntd-form/_util/type.js +4 -0
  143. package/es/tntd-form/_util/type.js.map +1 -0
  144. package/es/tntd-form/_util/warning.js +6 -0
  145. package/es/tntd-form/_util/warning.js.map +1 -0
  146. package/es/tntd-form/_util/wave.js +168 -0
  147. package/es/tntd-form/_util/wave.js.map +1 -0
  148. package/es/tntd-form/context.js +35 -0
  149. package/es/tntd-form/context.js.map +1 -0
  150. package/es/tntd-form/hooks/useDebounce.js +14 -0
  151. package/es/tntd-form/hooks/useDebounce.js.map +1 -0
  152. package/es/tntd-form/hooks/useForm.js +35 -0
  153. package/es/tntd-form/hooks/useForm.js.map +1 -0
  154. package/es/tntd-form/hooks/useFormInstance.js +7 -0
  155. package/es/tntd-form/hooks/useFormInstance.js.map +1 -0
  156. package/es/tntd-form/hooks/useFormItemStatus.js +10 -0
  157. package/es/tntd-form/hooks/useFormItemStatus.js.map +1 -0
  158. package/es/tntd-form/hooks/useFrameState.js +38 -0
  159. package/es/tntd-form/hooks/useFrameState.js.map +1 -0
  160. package/es/tntd-form/hooks/useItemRef.js +19 -0
  161. package/es/tntd-form/hooks/useItemRef.js.map +1 -0
  162. package/es/tntd-form/index.js +17 -1
  163. package/es/tntd-form/index.js.map +1 -1
  164. package/es/tntd-form/interface.js +3 -0
  165. package/es/tntd-form/interface.js.map +1 -0
  166. package/es/tntd-form/style/components.less +16 -0
  167. package/es/tntd-form/style/horizontal.less +26 -0
  168. package/es/tntd-form/style/index.js +6 -0
  169. package/es/tntd-form/style/index.js.map +1 -0
  170. package/es/tntd-form/style/index.less +342 -0
  171. package/es/tntd-form/style/inline.less +40 -0
  172. package/es/tntd-form/style/mixin.less +90 -0
  173. package/es/tntd-form/style/rtl.less +204 -0
  174. package/es/tntd-form/style/status.less +45 -0
  175. package/es/tntd-form/style/vertical.less +95 -0
  176. package/es/tntd-form/tntd-form.stories.js +426 -0
  177. package/es/tntd-form/tntd-form.stories.js.map +1 -0
  178. package/es/tntd-form/util.js +21 -0
  179. package/es/tntd-form/util.js.map +1 -0
  180. package/es/tntd-form/validateMessagesContext.js +6 -0
  181. package/es/tntd-form/validateMessagesContext.js.map +1 -0
  182. package/es/tree-select/index.js +4 -1
  183. package/es/tree-select/index.js.map +1 -1
  184. package/es/upload/index.js +6 -1
  185. package/es/upload/index.js.map +1 -1
  186. package/lib/_util/colors.d.ts +3 -0
  187. package/lib/_util/colors.d.ts.map +1 -0
  188. package/lib/_util/colors.js +7 -0
  189. package/lib/_util/colors.js.map +1 -0
  190. package/lib/_util/easings.d.ts +2 -0
  191. package/lib/_util/easings.d.ts.map +1 -0
  192. package/lib/_util/easings.js +14 -0
  193. package/lib/_util/easings.js.map +1 -0
  194. package/lib/_util/getDataOrAriaProps.d.ts +2 -0
  195. package/lib/_util/getDataOrAriaProps.d.ts.map +1 -0
  196. package/lib/_util/getDataOrAriaProps.js +13 -0
  197. package/lib/_util/getDataOrAriaProps.js.map +1 -0
  198. package/lib/_util/getScroll.d.ts +2 -0
  199. package/lib/_util/getScroll.d.ts.map +1 -0
  200. package/lib/_util/getScroll.js +18 -0
  201. package/lib/_util/getScroll.js.map +1 -0
  202. package/lib/_util/interopDefault.d.ts +2 -0
  203. package/lib/_util/interopDefault.d.ts.map +1 -0
  204. package/lib/_util/interopDefault.js +9 -0
  205. package/lib/_util/interopDefault.js.map +1 -0
  206. package/lib/_util/isNumeric.d.ts +3 -0
  207. package/lib/_util/isNumeric.d.ts.map +1 -0
  208. package/lib/_util/isNumeric.js +7 -0
  209. package/lib/_util/isNumeric.js.map +1 -0
  210. package/lib/_util/motion.d.ts +24 -0
  211. package/lib/_util/motion.d.ts.map +1 -0
  212. package/lib/_util/motion.js +17 -0
  213. package/lib/_util/motion.js.map +1 -0
  214. package/lib/_util/openAnimation.d.ts +7 -0
  215. package/lib/_util/openAnimation.d.ts.map +1 -0
  216. package/lib/_util/openAnimation.js +58 -0
  217. package/lib/_util/openAnimation.js.map +1 -0
  218. package/lib/_util/raf.d.ts +10 -0
  219. package/lib/_util/raf.d.ts.map +1 -0
  220. package/lib/_util/raf.js +34 -0
  221. package/lib/_util/raf.js.map +1 -0
  222. package/lib/_util/reactNode.d.ts +3 -0
  223. package/lib/_util/reactNode.d.ts.map +1 -0
  224. package/lib/_util/reactNode.js +31 -0
  225. package/lib/_util/reactNode.js.map +1 -0
  226. package/lib/_util/ref.d.ts +4 -0
  227. package/lib/_util/ref.d.ts.map +1 -0
  228. package/lib/_util/ref.js +22 -0
  229. package/lib/_util/ref.js.map +1 -0
  230. package/lib/_util/responsiveObserve.d.ts +14 -0
  231. package/lib/_util/responsiveObserve.d.ts.map +1 -0
  232. package/lib/_util/responsiveObserve.js +83 -0
  233. package/lib/_util/responsiveObserve.js.map +1 -0
  234. package/lib/_util/scrollTo.d.ts +11 -0
  235. package/lib/_util/scrollTo.d.ts.map +1 -0
  236. package/lib/_util/scrollTo.js +34 -0
  237. package/lib/_util/scrollTo.js.map +1 -0
  238. package/lib/_util/styleChecker.d.ts +4 -0
  239. package/lib/_util/styleChecker.d.ts.map +1 -0
  240. package/lib/_util/styleChecker.js +14 -0
  241. package/lib/_util/styleChecker.js.map +1 -0
  242. package/lib/_util/throttleByAnimationFrame.d.ts +6 -0
  243. package/lib/_util/throttleByAnimationFrame.d.ts.map +1 -0
  244. package/lib/_util/throttleByAnimationFrame.js +49 -0
  245. package/lib/_util/throttleByAnimationFrame.js.map +1 -0
  246. package/lib/_util/transButton.d.ts +21 -0
  247. package/lib/_util/transButton.d.ts.map +1 -0
  248. package/lib/_util/transButton.js +112 -0
  249. package/lib/_util/transButton.js.map +1 -0
  250. package/lib/_util/triggerEvent.d.ts +2 -0
  251. package/lib/_util/triggerEvent.d.ts.map +1 -0
  252. package/lib/_util/triggerEvent.js +12 -0
  253. package/lib/_util/triggerEvent.js.map +1 -0
  254. package/lib/_util/type.d.ts +4 -0
  255. package/lib/_util/type.d.ts.map +1 -0
  256. package/lib/_util/type.js +9 -0
  257. package/lib/_util/type.js.map +1 -0
  258. package/lib/_util/warning.d.ts +5 -0
  259. package/lib/_util/warning.d.ts.map +1 -0
  260. package/lib/_util/warning.js +28 -0
  261. package/lib/_util/warning.js.map +1 -0
  262. package/lib/_util/wave.d.ts +26 -0
  263. package/lib/_util/wave.d.ts.map +1 -0
  264. package/lib/_util/wave.js +249 -0
  265. package/lib/_util/wave.js.map +1 -0
  266. package/lib/affix/index.js +5 -1
  267. package/lib/affix/index.js.map +1 -1
  268. package/lib/alert/index.js +5 -1
  269. package/lib/alert/index.js.map +1 -1
  270. package/lib/anchor/index.js +5 -1
  271. package/lib/anchor/index.js.map +1 -1
  272. package/lib/array-input/index.js +5 -1
  273. package/lib/array-input/index.js.map +1 -1
  274. package/lib/auto-complete/index.js +5 -1
  275. package/lib/auto-complete/index.js.map +1 -1
  276. package/lib/avatar/index.js +5 -1
  277. package/lib/avatar/index.js.map +1 -1
  278. package/lib/back-top/index.js +5 -1
  279. package/lib/back-top/index.js.map +1 -1
  280. package/lib/badge/index.js +5 -1
  281. package/lib/badge/index.js.map +1 -1
  282. package/lib/breadcrumb/index.js +5 -1
  283. package/lib/breadcrumb/index.js.map +1 -1
  284. package/lib/button/index.js +5 -1
  285. package/lib/button/index.js.map +1 -1
  286. package/lib/calendar/index.js +5 -1
  287. package/lib/calendar/index.js.map +1 -1
  288. package/lib/card/index.js +5 -1
  289. package/lib/card/index.js.map +1 -1
  290. package/lib/carousel/index.js +5 -1
  291. package/lib/carousel/index.js.map +1 -1
  292. package/lib/cascader/index.d.ts +6 -1
  293. package/lib/cascader/index.d.ts.map +1 -1
  294. package/lib/cascader/index.js +11 -2
  295. package/lib/cascader/index.js.map +1 -1
  296. package/lib/checkbox/checkbox-group.d.ts +8 -0
  297. package/lib/checkbox/checkbox-group.d.ts.map +1 -0
  298. package/lib/checkbox/checkbox-group.js +11 -0
  299. package/lib/checkbox/checkbox-group.js.map +1 -0
  300. package/lib/checkbox/index.d.ts +1 -0
  301. package/lib/checkbox/index.d.ts.map +1 -1
  302. package/lib/checkbox/index.js +10 -1
  303. package/lib/checkbox/index.js.map +1 -1
  304. package/lib/col/index.js +5 -1
  305. package/lib/col/index.js.map +1 -1
  306. package/lib/collapse/index.js +5 -1
  307. package/lib/collapse/index.js.map +1 -1
  308. package/lib/color-picker/ColorPicker.js +5 -1
  309. package/lib/color-picker/ColorPicker.js.map +1 -1
  310. package/lib/comment/index.js +5 -1
  311. package/lib/comment/index.js.map +1 -1
  312. package/lib/config-provider/DisabledContext.d.ts +10 -0
  313. package/lib/config-provider/DisabledContext.d.ts.map +1 -0
  314. package/lib/config-provider/DisabledContext.js +35 -0
  315. package/lib/config-provider/DisabledContext.js.map +1 -0
  316. package/lib/config-provider/SizeContext.d.ts +10 -0
  317. package/lib/config-provider/SizeContext.d.ts.map +1 -0
  318. package/lib/config-provider/SizeContext.js +32 -0
  319. package/lib/config-provider/SizeContext.js.map +1 -0
  320. package/lib/config-provider/context.d.ts +61 -0
  321. package/lib/config-provider/context.d.ts.map +1 -0
  322. package/lib/config-provider/context.js +64 -0
  323. package/lib/config-provider/context.js.map +1 -0
  324. package/lib/config-provider/index.d.ts +1 -0
  325. package/lib/config-provider/index.d.ts.map +1 -1
  326. package/lib/config-provider/index.js +9 -1
  327. package/lib/config-provider/index.js.map +1 -1
  328. package/lib/connect/index.d.ts +12 -0
  329. package/lib/connect/index.d.ts.map +1 -0
  330. package/lib/connect/index.js +32 -0
  331. package/lib/connect/index.js.map +1 -0
  332. package/lib/date-picker/index.d.ts +6 -1
  333. package/lib/date-picker/index.d.ts.map +1 -1
  334. package/lib/date-picker/index.js +17 -2
  335. package/lib/date-picker/index.js.map +1 -1
  336. package/lib/descriptions/descriptions.d.ts +1 -1
  337. package/lib/descriptions/descriptions.d.ts.map +1 -1
  338. package/lib/descriptions/descriptions.js +5 -1
  339. package/lib/descriptions/descriptions.js.map +1 -1
  340. package/lib/descriptions/index.js +5 -1
  341. package/lib/descriptions/index.js.map +1 -1
  342. package/lib/development-login/LoginModal.js +5 -1
  343. package/lib/development-login/LoginModal.js.map +1 -1
  344. package/lib/development-login/index.js +5 -1
  345. package/lib/development-login/index.js.map +1 -1
  346. package/lib/divider/index.js +5 -1
  347. package/lib/divider/index.js.map +1 -1
  348. package/lib/drawer/index.js +5 -1
  349. package/lib/drawer/index.js.map +1 -1
  350. package/lib/dropdown/index.js +5 -1
  351. package/lib/dropdown/index.js.map +1 -1
  352. package/lib/ellipsis/index.js +5 -1
  353. package/lib/ellipsis/index.js.map +1 -1
  354. package/lib/empty/empty.js +5 -1
  355. package/lib/empty/empty.js.map +1 -1
  356. package/lib/empty/index.js +5 -1
  357. package/lib/empty/index.js.map +1 -1
  358. package/lib/exception/index.js +5 -1
  359. package/lib/exception/index.js.map +1 -1
  360. package/lib/form/index.js +5 -1
  361. package/lib/form/index.js.map +1 -1
  362. package/lib/handle/index.js +5 -1
  363. package/lib/handle/index.js.map +1 -1
  364. package/lib/icon/index.js +5 -1
  365. package/lib/icon/index.js.map +1 -1
  366. package/lib/img/index.js +5 -1
  367. package/lib/img/index.js.map +1 -1
  368. package/lib/input/index.js +5 -1
  369. package/lib/input/index.js.map +1 -1
  370. package/lib/input/input.d.ts +22 -8
  371. package/lib/input/input.d.ts.map +1 -1
  372. package/lib/input/input.js +61 -27
  373. package/lib/input/input.js.map +1 -1
  374. package/lib/input-number/index.d.ts +7 -2
  375. package/lib/input-number/index.d.ts.map +1 -1
  376. package/lib/input-number/index.js +8 -2
  377. package/lib/input-number/index.js.map +1 -1
  378. package/lib/label/index.js +5 -1
  379. package/lib/label/index.js.map +1 -1
  380. package/lib/layout/index.js +5 -1
  381. package/lib/layout/index.js.map +1 -1
  382. package/lib/list/index.js +5 -1
  383. package/lib/list/index.js.map +1 -1
  384. package/lib/loading-button/index.js +5 -1
  385. package/lib/loading-button/index.js.map +1 -1
  386. package/lib/locale/index.js +5 -1
  387. package/lib/locale/index.js.map +1 -1
  388. package/lib/locale-provider/index.js +5 -1
  389. package/lib/locale-provider/index.js.map +1 -1
  390. package/lib/mentions/index.js +5 -1
  391. package/lib/mentions/index.js.map +1 -1
  392. package/lib/menu/index.js +5 -1
  393. package/lib/menu/index.js.map +1 -1
  394. package/lib/message/index.js +5 -1
  395. package/lib/message/index.js.map +1 -1
  396. package/lib/modal/index.js +5 -1
  397. package/lib/modal/index.js.map +1 -1
  398. package/lib/modal/modal.js +5 -1
  399. package/lib/modal/modal.js.map +1 -1
  400. package/lib/notification/index.js +5 -1
  401. package/lib/notification/index.js.map +1 -1
  402. package/lib/page-header/index.js +5 -1
  403. package/lib/page-header/index.js.map +1 -1
  404. package/lib/pagination/index.js +5 -1
  405. package/lib/pagination/index.js.map +1 -1
  406. package/lib/popconfirm/index.js +5 -1
  407. package/lib/popconfirm/index.js.map +1 -1
  408. package/lib/popover/index.js +5 -1
  409. package/lib/popover/index.js.map +1 -1
  410. package/lib/preview-text/index.d.ts +20 -0
  411. package/lib/preview-text/index.d.ts.map +1 -0
  412. package/lib/preview-text/index.js +224 -0
  413. package/lib/preview-text/index.js.map +1 -0
  414. package/lib/preview-text/index.less +3 -0
  415. package/lib/progress/index.js +5 -1
  416. package/lib/progress/index.js.map +1 -1
  417. package/lib/query-form/Field/Select.js +5 -1
  418. package/lib/query-form/Field/Select.js.map +1 -1
  419. package/lib/query-form/Field/SelectInput.js +5 -1
  420. package/lib/query-form/Field/SelectInput.js.map +1 -1
  421. package/lib/query-form/Field/fieldsMap.d.ts +2 -2
  422. package/lib/query-form/Field/index.d.ts +6 -0
  423. package/lib/query-form/Field/index.d.ts.map +1 -1
  424. package/lib/query-form/Field/index.js +5 -1
  425. package/lib/query-form/Field/index.js.map +1 -1
  426. package/lib/query-form/index.d.ts +9 -0
  427. package/lib/query-form/index.d.ts.map +1 -1
  428. package/lib/query-form/index.js +5 -1
  429. package/lib/query-form/index.js.map +1 -1
  430. package/lib/query-list-scene/List.d.ts +13 -0
  431. package/lib/query-list-scene/List.d.ts.map +1 -1
  432. package/lib/query-list-scene/List.js +5 -1
  433. package/lib/query-list-scene/List.js.map +1 -1
  434. package/lib/query-list-scene/QueryForm.d.ts +3 -0
  435. package/lib/query-list-scene/QueryForm.d.ts.map +1 -1
  436. package/lib/query-list-scene/QueryListScene.d.ts +1 -0
  437. package/lib/query-list-scene/QueryListScene.d.ts.map +1 -1
  438. package/lib/radio/index.d.ts.map +1 -1
  439. package/lib/radio/index.js +8 -1
  440. package/lib/radio/index.js.map +1 -1
  441. package/lib/radio/radio-group.d.ts +8 -0
  442. package/lib/radio/radio-group.d.ts.map +1 -0
  443. package/lib/radio/radio-group.js +11 -0
  444. package/lib/radio/radio-group.js.map +1 -0
  445. package/lib/rate/index.js +5 -1
  446. package/lib/rate/index.js.map +1 -1
  447. package/lib/result/index.js +5 -1
  448. package/lib/result/index.js.map +1 -1
  449. package/lib/row/index.js +5 -1
  450. package/lib/row/index.js.map +1 -1
  451. package/lib/select/index.d.ts +2 -1
  452. package/lib/select/index.d.ts.map +1 -1
  453. package/lib/select/index.js +5 -1
  454. package/lib/select/index.js.map +1 -1
  455. package/lib/select/select.d.ts +20 -6
  456. package/lib/select/select.d.ts.map +1 -1
  457. package/lib/select/select.js +41 -7
  458. package/lib/select/select.js.map +1 -1
  459. package/lib/skeleton/index.js +5 -1
  460. package/lib/skeleton/index.js.map +1 -1
  461. package/lib/slider/index.js +5 -1
  462. package/lib/slider/index.js.map +1 -1
  463. package/lib/spin/index.js +5 -1
  464. package/lib/spin/index.js.map +1 -1
  465. package/lib/statistic/index.js +5 -1
  466. package/lib/statistic/index.js.map +1 -1
  467. package/lib/steps/index.js +5 -1
  468. package/lib/steps/index.js.map +1 -1
  469. package/lib/steps/steps.js +5 -1
  470. package/lib/steps/steps.js.map +1 -1
  471. package/lib/svg-components/illustration-403.d.ts +1 -1
  472. package/lib/svg-components/illustration-403.js +5 -1
  473. package/lib/svg-components/illustration-403.js.map +1 -1
  474. package/lib/svg-components/illustration-404.d.ts +1 -1
  475. package/lib/svg-components/illustration-404.js +5 -1
  476. package/lib/svg-components/illustration-404.js.map +1 -1
  477. package/lib/svg-components/illustration-500.d.ts +1 -1
  478. package/lib/svg-components/illustration-500.js +5 -1
  479. package/lib/svg-components/illustration-500.js.map +1 -1
  480. package/lib/svg-components/illustration-empty.d.ts +1 -1
  481. package/lib/svg-components/illustration-empty.js +5 -1
  482. package/lib/svg-components/illustration-empty.js.map +1 -1
  483. package/lib/svg-components/illustration-failure.d.ts +1 -1
  484. package/lib/svg-components/illustration-failure.js +5 -1
  485. package/lib/svg-components/illustration-failure.js.map +1 -1
  486. package/lib/svg-components/illustration-no-access.d.ts +1 -1
  487. package/lib/svg-components/illustration-no-access.js +5 -1
  488. package/lib/svg-components/illustration-no-access.js.map +1 -1
  489. package/lib/svg-components/illustration-no-chart.d.ts +1 -1
  490. package/lib/svg-components/illustration-no-chart.js +5 -1
  491. package/lib/svg-components/illustration-no-chart.js.map +1 -1
  492. package/lib/svg-components/illustration-no-result.d.ts +1 -1
  493. package/lib/svg-components/illustration-no-result.js +5 -1
  494. package/lib/svg-components/illustration-no-result.js.map +1 -1
  495. package/lib/svg-components/illustration-offline.d.ts +1 -1
  496. package/lib/svg-components/illustration-offline.js +5 -1
  497. package/lib/svg-components/illustration-offline.js.map +1 -1
  498. package/lib/svg-components/illustration-success.d.ts +1 -1
  499. package/lib/svg-components/illustration-success.js +5 -1
  500. package/lib/svg-components/illustration-success.js.map +1 -1
  501. package/lib/switch/index.d.ts +2 -3
  502. package/lib/switch/index.d.ts.map +1 -1
  503. package/lib/switch/index.js +7 -4
  504. package/lib/switch/index.js.map +1 -1
  505. package/lib/switch/switch.d.ts +10 -0
  506. package/lib/switch/switch.d.ts.map +1 -0
  507. package/lib/switch/switch.js +29 -0
  508. package/lib/switch/switch.js.map +1 -0
  509. package/lib/table/assets/image-loading-background.d.ts +1 -1
  510. package/lib/table/assets/image-loading-background.js +5 -1
  511. package/lib/table/assets/image-loading-background.js.map +1 -1
  512. package/lib/table/assets/image-loading.d.ts +1 -1
  513. package/lib/table/assets/image-loading.js +5 -1
  514. package/lib/table/assets/image-loading.js.map +1 -1
  515. package/lib/table/hooks/index.js +5 -1
  516. package/lib/table/hooks/index.js.map +1 -1
  517. package/lib/table/index.js +5 -1
  518. package/lib/table/index.js.map +1 -1
  519. package/lib/table/table.js +5 -1
  520. package/lib/table/table.js.map +1 -1
  521. package/lib/table/table.less +2 -0
  522. package/lib/tabs/index.js +5 -1
  523. package/lib/tabs/index.js.map +1 -1
  524. package/lib/tag/index.js +5 -1
  525. package/lib/tag/index.js.map +1 -1
  526. package/lib/time-picker/index.d.ts +7 -2
  527. package/lib/time-picker/index.d.ts.map +1 -1
  528. package/lib/time-picker/index.js +8 -2
  529. package/lib/time-picker/index.js.map +1 -1
  530. package/lib/timeline/index.js +5 -1
  531. package/lib/timeline/index.js.map +1 -1
  532. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +5 -1
  533. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -1
  534. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +5 -1
  535. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -1
  536. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +5 -1
  537. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -1
  538. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +5 -1
  539. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  540. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +5 -1
  541. package/lib/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -1
  542. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +5 -1
  543. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -1
  544. package/lib/tntd-cascader/AntdCascader/config/utils.d.ts +1 -1
  545. package/lib/tntd-cascader/AntdCascader/config/warning.js +5 -1
  546. package/lib/tntd-cascader/AntdCascader/config/warning.js.map +1 -1
  547. package/lib/tntd-cascader/AntdCascader/index.js +5 -1
  548. package/lib/tntd-cascader/AntdCascader/index.js.map +1 -1
  549. package/lib/tntd-cascader/rc-cascader/Cascader.js +5 -1
  550. package/lib/tntd-cascader/rc-cascader/Cascader.js.map +1 -1
  551. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +5 -1
  552. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -1
  553. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +5 -1
  554. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -1
  555. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +5 -1
  556. package/lib/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -1
  557. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +5 -1
  558. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -1
  559. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +5 -1
  560. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -1
  561. package/lib/tntd-cascader/rc-cascader/context.js +5 -1
  562. package/lib/tntd-cascader/rc-cascader/context.js.map +1 -1
  563. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +5 -1
  564. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -1
  565. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +5 -1
  566. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -1
  567. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +5 -1
  568. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -1
  569. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +5 -1
  570. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -1
  571. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +5 -1
  572. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -1
  573. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +5 -1
  574. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -1
  575. package/lib/tntd-form/ErrorList.d.ts +13 -0
  576. package/lib/tntd-form/ErrorList.d.ts.map +1 -0
  577. package/lib/tntd-form/ErrorList.js +82 -0
  578. package/lib/tntd-form/ErrorList.js.map +1 -0
  579. package/lib/tntd-form/Form.d.ts +36 -0
  580. package/lib/tntd-form/Form.d.ts.map +1 -0
  581. package/lib/tntd-form/Form.js +132 -0
  582. package/lib/tntd-form/Form.js.map +1 -0
  583. package/lib/tntd-form/FormItem/ItemHolder.d.ts +18 -0
  584. package/lib/tntd-form/FormItem/ItemHolder.d.ts.map +1 -0
  585. package/lib/tntd-form/FormItem/ItemHolder.js +164 -0
  586. package/lib/tntd-form/FormItem/ItemHolder.js.map +1 -0
  587. package/lib/tntd-form/FormItem/index.d.ts +36 -0
  588. package/lib/tntd-form/FormItem/index.d.ts.map +1 -0
  589. package/lib/tntd-form/FormItem/index.js +266 -0
  590. package/lib/tntd-form/FormItem/index.js.map +1 -0
  591. package/lib/tntd-form/FormItemInput.d.ts +30 -0
  592. package/lib/tntd-form/FormItemInput.d.ts.map +1 -0
  593. package/lib/tntd-form/FormItemInput.js +66 -0
  594. package/lib/tntd-form/FormItemInput.js.map +1 -0
  595. package/lib/tntd-form/FormItemLabel.d.ts +24 -0
  596. package/lib/tntd-form/FormItemLabel.d.ts.map +1 -0
  597. package/lib/tntd-form/FormItemLabel.js +101 -0
  598. package/lib/tntd-form/FormItemLabel.js.map +1 -0
  599. package/lib/tntd-form/FormList.d.ts +26 -0
  600. package/lib/tntd-form/FormList.d.ts.map +1 -0
  601. package/lib/tntd-form/FormList.js +62 -0
  602. package/lib/tntd-form/FormList.js.map +1 -0
  603. package/lib/tntd-form/TntdForm/components/Item.js +5 -1
  604. package/lib/tntd-form/TntdForm/components/Item.js.map +1 -1
  605. package/lib/tntd-form/TntdForm/components/ItemComp.js +7 -3
  606. package/lib/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  607. package/lib/tntd-form/TntdForm/components/List.js +5 -1
  608. package/lib/tntd-form/TntdForm/components/List.js.map +1 -1
  609. package/lib/tntd-form/TntdForm/index.js +5 -1
  610. package/lib/tntd-form/TntdForm/index.js.map +1 -1
  611. package/lib/tntd-form/__tests__/demo-extend.test.d.ts +2 -0
  612. package/lib/tntd-form/__tests__/demo-extend.test.d.ts.map +1 -0
  613. package/lib/tntd-form/__tests__/demo-extend.test.js +5 -0
  614. package/lib/tntd-form/__tests__/demo-extend.test.js.map +1 -0
  615. package/lib/tntd-form/__tests__/demo.test.d.ts +2 -0
  616. package/lib/tntd-form/__tests__/demo.test.d.ts.map +1 -0
  617. package/lib/tntd-form/__tests__/demo.test.js +8 -0
  618. package/lib/tntd-form/__tests__/demo.test.js.map +1 -0
  619. package/lib/tntd-form/__tests__/image.test.d.ts +2 -0
  620. package/lib/tntd-form/__tests__/image.test.d.ts.map +1 -0
  621. package/lib/tntd-form/__tests__/image.test.js +7 -0
  622. package/lib/tntd-form/__tests__/image.test.js.map +1 -0
  623. package/lib/tntd-form/__tests__/index.test.d.ts +2 -0
  624. package/lib/tntd-form/__tests__/index.test.d.ts.map +1 -0
  625. package/lib/tntd-form/__tests__/index.test.js +981 -0
  626. package/lib/tntd-form/__tests__/index.test.js.map +1 -0
  627. package/lib/tntd-form/__tests__/list-noStyle.test.d.ts +2 -0
  628. package/lib/tntd-form/__tests__/list-noStyle.test.d.ts.map +1 -0
  629. package/lib/tntd-form/__tests__/list-noStyle.test.js +46 -0
  630. package/lib/tntd-form/__tests__/list-noStyle.test.js.map +1 -0
  631. package/lib/tntd-form/__tests__/list.test.d.ts +2 -0
  632. package/lib/tntd-form/__tests__/list.test.d.ts.map +1 -0
  633. package/lib/tntd-form/__tests__/list.test.js +169 -0
  634. package/lib/tntd-form/__tests__/list.test.js.map +1 -0
  635. package/lib/tntd-form/__tests__/ref.test.d.ts +2 -0
  636. package/lib/tntd-form/__tests__/ref.test.d.ts.map +1 -0
  637. package/lib/tntd-form/__tests__/ref.test.js +50 -0
  638. package/lib/tntd-form/__tests__/ref.test.js.map +1 -0
  639. package/lib/tntd-form/__tests__/type.test.d.ts +2 -0
  640. package/lib/tntd-form/__tests__/type.test.d.ts.map +1 -0
  641. package/lib/tntd-form/__tests__/type.test.js +98 -0
  642. package/lib/tntd-form/__tests__/type.test.js.map +1 -0
  643. package/lib/tntd-form/_util/motion.d.ts +9 -0
  644. package/lib/tntd-form/_util/motion.d.ts.map +1 -0
  645. package/lib/tntd-form/_util/motion.js +42 -0
  646. package/lib/tntd-form/_util/motion.js.map +1 -0
  647. package/lib/tntd-form/_util/reactNode.d.ts +9 -0
  648. package/lib/tntd-form/_util/reactNode.d.ts.map +1 -0
  649. package/lib/tntd-form/_util/reactNode.js +44 -0
  650. package/lib/tntd-form/_util/reactNode.js.map +1 -0
  651. package/lib/tntd-form/_util/scrollTo.d.ts +1 -0
  652. package/lib/tntd-form/_util/scrollTo.d.ts.map +1 -0
  653. package/lib/tntd-form/_util/scrollTo.js +35 -0
  654. package/lib/tntd-form/_util/scrollTo.js.map +1 -0
  655. package/lib/tntd-form/_util/type.d.ts +4 -0
  656. package/lib/tntd-form/_util/type.d.ts.map +1 -0
  657. package/lib/tntd-form/_util/type.js +9 -0
  658. package/lib/tntd-form/_util/type.js.map +1 -0
  659. package/lib/tntd-form/_util/warning.d.ts +5 -0
  660. package/lib/tntd-form/_util/warning.d.ts.map +1 -0
  661. package/lib/tntd-form/_util/warning.js +32 -0
  662. package/lib/tntd-form/_util/warning.js.map +1 -0
  663. package/lib/tntd-form/_util/wave.d.ts +1 -0
  664. package/lib/tntd-form/_util/wave.d.ts.map +1 -0
  665. package/lib/tntd-form/_util/wave.js +168 -0
  666. package/lib/tntd-form/_util/wave.js.map +1 -0
  667. package/lib/tntd-form/context.d.ts +51 -0
  668. package/lib/tntd-form/context.d.ts.map +1 -0
  669. package/lib/tntd-form/context.js +66 -0
  670. package/lib/tntd-form/context.js.map +1 -0
  671. package/lib/tntd-form/hooks/useDebounce.d.ts +2 -0
  672. package/lib/tntd-form/hooks/useDebounce.d.ts.map +1 -0
  673. package/lib/tntd-form/hooks/useDebounce.js +40 -0
  674. package/lib/tntd-form/hooks/useDebounce.js.map +1 -0
  675. package/lib/tntd-form/hooks/useForm.d.ts +16 -0
  676. package/lib/tntd-form/hooks/useForm.d.ts.map +1 -0
  677. package/lib/tntd-form/hooks/useForm.js +64 -0
  678. package/lib/tntd-form/hooks/useForm.js.map +1 -0
  679. package/lib/tntd-form/hooks/useFormInstance.d.ts +3 -0
  680. package/lib/tntd-form/hooks/useFormInstance.d.ts.map +1 -0
  681. package/lib/tntd-form/hooks/useFormInstance.js +10 -0
  682. package/lib/tntd-form/hooks/useFormInstance.js.map +1 -0
  683. package/lib/tntd-form/hooks/useFormItemStatus.d.ts +7 -0
  684. package/lib/tntd-form/hooks/useFormItemStatus.d.ts.map +1 -0
  685. package/lib/tntd-form/hooks/useFormItemStatus.js +15 -0
  686. package/lib/tntd-form/hooks/useFormItemStatus.js.map +1 -0
  687. package/lib/tntd-form/hooks/useFrameState.d.ts +4 -0
  688. package/lib/tntd-form/hooks/useFrameState.d.ts.map +1 -0
  689. package/lib/tntd-form/hooks/useFrameState.js +67 -0
  690. package/lib/tntd-form/hooks/useFrameState.js.map +1 -0
  691. package/lib/tntd-form/hooks/useItemRef.d.ts +4 -0
  692. package/lib/tntd-form/hooks/useItemRef.d.ts.map +1 -0
  693. package/lib/tntd-form/hooks/useItemRef.js +45 -0
  694. package/lib/tntd-form/hooks/useItemRef.js.map +1 -0
  695. package/lib/tntd-form/index.d.ts +23 -1
  696. package/lib/tntd-form/index.d.ts.map +1 -1
  697. package/lib/tntd-form/index.js +40 -3
  698. package/lib/tntd-form/index.js.map +1 -1
  699. package/lib/tntd-form/interface.d.ts +4 -0
  700. package/lib/tntd-form/interface.d.ts.map +1 -0
  701. package/lib/tntd-form/interface.js +5 -0
  702. package/lib/tntd-form/interface.js.map +1 -0
  703. package/lib/tntd-form/style/components.less +16 -0
  704. package/lib/tntd-form/style/horizontal.less +26 -0
  705. package/lib/tntd-form/style/index.d.ts +5 -0
  706. package/lib/tntd-form/style/index.d.ts.map +1 -0
  707. package/lib/tntd-form/style/index.js +8 -0
  708. package/lib/tntd-form/style/index.js.map +1 -0
  709. package/lib/tntd-form/style/index.less +342 -0
  710. package/lib/tntd-form/style/inline.less +40 -0
  711. package/lib/tntd-form/style/mixin.less +90 -0
  712. package/lib/tntd-form/style/rtl.less +204 -0
  713. package/lib/tntd-form/style/status.less +45 -0
  714. package/lib/tntd-form/style/vertical.less +95 -0
  715. package/lib/tntd-form/tntd-form.stories.d.ts +33 -0
  716. package/lib/tntd-form/tntd-form.stories.d.ts.map +1 -0
  717. package/lib/tntd-form/tntd-form.stories.js +455 -0
  718. package/lib/tntd-form/tntd-form.stories.js.map +1 -0
  719. package/lib/tntd-form/util.d.ts +4 -0
  720. package/lib/tntd-form/util.d.ts.map +1 -0
  721. package/lib/tntd-form/util.js +26 -0
  722. package/lib/tntd-form/util.js.map +1 -0
  723. package/lib/tntd-form/validateMessagesContext.d.ts +5 -0
  724. package/lib/tntd-form/validateMessagesContext.d.ts.map +1 -0
  725. package/lib/tntd-form/validateMessagesContext.js +8 -0
  726. package/lib/tntd-form/validateMessagesContext.js.map +1 -0
  727. package/lib/tntd-layout/AppList.js +5 -1
  728. package/lib/tntd-layout/AppList.js.map +1 -1
  729. package/lib/tntd-layout/Application.js +5 -1
  730. package/lib/tntd-layout/Application.js.map +1 -1
  731. package/lib/tntd-layout/Avatar.js +5 -1
  732. package/lib/tntd-layout/Avatar.js.map +1 -1
  733. package/lib/tntd-layout/CompatibleLanguage.js +5 -1
  734. package/lib/tntd-layout/CompatibleLanguage.js.map +1 -1
  735. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +5 -1
  736. package/lib/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
  737. package/lib/tntd-layout/EnterpriseLayout/Language.js +5 -1
  738. package/lib/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
  739. package/lib/tntd-layout/EnterpriseLayout/Theme.js +5 -1
  740. package/lib/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
  741. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +5 -1
  742. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
  743. package/lib/tntd-layout/GlobalNavigation/index.js +5 -1
  744. package/lib/tntd-layout/GlobalNavigation/index.js.map +1 -1
  745. package/lib/tntd-layout/Header.js +5 -1
  746. package/lib/tntd-layout/Header.js.map +1 -1
  747. package/lib/tntd-layout/HeaderActions.js +5 -1
  748. package/lib/tntd-layout/HeaderActions.js.map +1 -1
  749. package/lib/tntd-layout/HeaderNavs.js +5 -1
  750. package/lib/tntd-layout/HeaderNavs.js.map +1 -1
  751. package/lib/tntd-layout/HeaderTabs.js +5 -1
  752. package/lib/tntd-layout/HeaderTabs.js.map +1 -1
  753. package/lib/tntd-layout/Language.js +5 -1
  754. package/lib/tntd-layout/Language.js.map +1 -1
  755. package/lib/tntd-layout/Layout.js +5 -1
  756. package/lib/tntd-layout/Layout.js.map +1 -1
  757. package/lib/tntd-layout/Logo.js +5 -1
  758. package/lib/tntd-layout/Logo.js.map +1 -1
  759. package/lib/tntd-layout/OrgAppList.js +5 -1
  760. package/lib/tntd-layout/OrgAppList.js.map +1 -1
  761. package/lib/tntd-layout/SideMenu.js +5 -1
  762. package/lib/tntd-layout/SideMenu.js.map +1 -1
  763. package/lib/tntd-layout/Theme.js +5 -1
  764. package/lib/tntd-layout/Theme.js.map +1 -1
  765. package/lib/tntd-layout/index.js +5 -1
  766. package/lib/tntd-layout/index.js.map +1 -1
  767. package/lib/tntd-layout/paaslayout/CompactSideMenu.js +5 -1
  768. package/lib/tntd-layout/paaslayout/CompactSideMenu.js.map +1 -1
  769. package/lib/tntd-layout/paaslayout/Header.js +5 -1
  770. package/lib/tntd-layout/paaslayout/Header.js.map +1 -1
  771. package/lib/tntd-layout/paaslayout/SideMenu.js +5 -1
  772. package/lib/tntd-layout/paaslayout/SideMenu.js.map +1 -1
  773. package/lib/tntd-layout/paaslayout/index.js +5 -1
  774. package/lib/tntd-layout/paaslayout/index.js.map +1 -1
  775. package/lib/tntd-modal/index.js +5 -1
  776. package/lib/tntd-modal/index.js.map +1 -1
  777. package/lib/tntd-select/DropDownWrap.d.ts +10 -0
  778. package/lib/tntd-select/DropDownWrap.d.ts.map +1 -1
  779. package/lib/tntd-select/DropDownWrap.js +5 -1
  780. package/lib/tntd-select/DropDownWrap.js.map +1 -1
  781. package/lib/tntd-select/index.d.ts +12 -1
  782. package/lib/tntd-select/index.d.ts.map +1 -1
  783. package/lib/tntd-select/index.js +5 -1
  784. package/lib/tntd-select/index.js.map +1 -1
  785. package/lib/tooltip/index.js +5 -1
  786. package/lib/tooltip/index.js.map +1 -1
  787. package/lib/transfer/index.js +5 -1
  788. package/lib/transfer/index.js.map +1 -1
  789. package/lib/tree/index.js +5 -1
  790. package/lib/tree/index.js.map +1 -1
  791. package/lib/tree-select/index.d.ts +7 -1
  792. package/lib/tree-select/index.d.ts.map +1 -1
  793. package/lib/tree-select/index.js +10 -2
  794. package/lib/tree-select/index.js.map +1 -1
  795. package/lib/typography/index.js +5 -1
  796. package/lib/typography/index.js.map +1 -1
  797. package/lib/upload/index.d.ts +6 -1
  798. package/lib/upload/index.d.ts.map +1 -1
  799. package/lib/upload/index.js +11 -2
  800. package/lib/upload/index.js.map +1 -1
  801. package/lib/utils/index.js +5 -1
  802. package/lib/utils/index.js.map +1 -1
  803. package/lib/version/index.js +5 -1
  804. package/lib/version/index.js.map +1 -1
  805. package/package.json +7 -4
  806. package/themes/default/variables.less +43 -0
  807. package/es/mention/index.js +0 -5
  808. package/es/mention/index.js.map +0 -1
  809. package/lib/mention/index.d.ts +0 -5
  810. package/lib/mention/index.d.ts.map +0 -1
  811. package/lib/mention/index.js +0 -20
  812. package/lib/mention/index.js.map +0 -1
@@ -0,0 +1,981 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __rest = (this && this.__rest) || function (s, e) {
22
+ var t = {};
23
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
24
+ t[p] = s[p];
25
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
26
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
27
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
28
+ t[p[i]] = s[p[i]];
29
+ }
30
+ return t;
31
+ };
32
+ var __importDefault = (this && this.__importDefault) || function (mod) {
33
+ return (mod && mod.__esModule) ? mod : { "default": mod };
34
+ };
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ const react_1 = __importStar(require("react"));
37
+ const scroll_into_view_if_needed_1 = __importDefault(require("scroll-into-view-if-needed"));
38
+ const classnames_1 = __importDefault(require("classnames"));
39
+ const __1 = __importDefault(require(".."));
40
+ const Util = __importStar(require("../util"));
41
+ const button_1 = __importDefault(require("../../button"));
42
+ const input_1 = __importDefault(require("../../input"));
43
+ const select_1 = __importDefault(require("../../select"));
44
+ const upload_1 = __importDefault(require("../../upload"));
45
+ const cascader_1 = __importDefault(require("../../cascader"));
46
+ const checkbox_1 = __importDefault(require("../../checkbox"));
47
+ const date_picker_1 = __importDefault(require("../../date-picker"));
48
+ const input_number_1 = __importDefault(require("../../input-number"));
49
+ const radio_1 = __importDefault(require("../../radio"));
50
+ const switch_1 = __importDefault(require("../../switch"));
51
+ const tree_select_1 = __importDefault(require("../../tree-select"));
52
+ const mountTest_1 = __importDefault(require("../../../tests/shared/mountTest"));
53
+ const rtlTest_1 = __importDefault(require("../../../tests/shared/rtlTest"));
54
+ const utils_1 = require("../../../tests/utils");
55
+ const config_provider_1 = __importDefault(require("../../config-provider"));
56
+ const drawer_1 = __importDefault(require("../../drawer"));
57
+ const zh_CN_1 = __importDefault(require("../../locale/zh_CN"));
58
+ const modal_1 = __importDefault(require("../../modal"));
59
+ const { RangePicker } = date_picker_1.default;
60
+ const { TextArea } = input_1.default;
61
+ jest.mock('scroll-into-view-if-needed');
62
+ describe('Form', () => {
63
+ (0, mountTest_1.default)(__1.default);
64
+ (0, mountTest_1.default)(__1.default.Item);
65
+ (0, rtlTest_1.default)(__1.default);
66
+ (0, rtlTest_1.default)(__1.default.Item);
67
+ scroll_into_view_if_needed_1.default.mockImplementation(() => { });
68
+ const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => { });
69
+ const warnSpy = jest.spyOn(console, 'warn').mockImplementation(() => { });
70
+ // const change = async (
71
+ // container: ReturnType<typeof render>['container'],
72
+ // index: number,
73
+ // value: string,
74
+ // executeMockTimer: boolean,
75
+ // ) => {
76
+ // fireEvent.change(container.querySelectorAll('input')?.[index], { target: { value } });
77
+ // await sleep(200);
78
+ // if (executeMockTimer) {
79
+ // for (let i = 0; i < 10; i += 1) {
80
+ // act(() => {
81
+ // jest.runAllTimers();
82
+ // });
83
+ // }
84
+ // await sleep(1);
85
+ // }
86
+ // };
87
+ const changeValue = async (input, value, advTimer = 1000) => {
88
+ let element;
89
+ if (typeof input === 'number') {
90
+ element = document.querySelectorAll('input')[input];
91
+ }
92
+ expect(element).toBeTruthy();
93
+ utils_1.fireEvent.change(element, {
94
+ target: {
95
+ value,
96
+ },
97
+ });
98
+ if (advTimer) {
99
+ await (0, utils_1.waitFakeTimer)(advTimer / 20, 20);
100
+ }
101
+ };
102
+ beforeEach(() => {
103
+ document.body.innerHTML = '';
104
+ jest.useFakeTimers();
105
+ scroll_into_view_if_needed_1.default.mockReset();
106
+ });
107
+ afterEach(() => {
108
+ errorSpy.mockReset();
109
+ });
110
+ afterAll(() => {
111
+ jest.clearAllTimers();
112
+ jest.useRealTimers();
113
+ errorSpy.mockRestore();
114
+ warnSpy.mockRestore();
115
+ scroll_into_view_if_needed_1.default.mockRestore();
116
+ });
117
+ describe('noStyle Form.Item', () => {
118
+ it('should show alert when form field is required but empty', async () => {
119
+ const onChange = jest.fn();
120
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
121
+ react_1.default.createElement(__1.default.Item, null,
122
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "test", initialValue: "bamboo", rules: [{ required: true }] },
123
+ react_1.default.createElement(input_1.default, { onChange: onChange })))));
124
+ // user type something and clear
125
+ await changeValue(0, 'test');
126
+ await changeValue(0, '');
127
+ // should show alert with correct message and show correct styles
128
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent("'test' is required");
129
+ expect(container.querySelector('.ant-input-status-error')).toBeTruthy();
130
+ expect(container.querySelector('.ant-form-item-has-error')).toBeTruthy();
131
+ expect(onChange).toHaveBeenCalled();
132
+ });
133
+ it('should clean up', async () => {
134
+ const Demo = () => {
135
+ const [form] = __1.default.useForm();
136
+ const onChange = async () => {
137
+ // Wait a while and then some logic to validate
138
+ await (0, utils_1.waitFakeTimer)();
139
+ try {
140
+ await form.validateFields();
141
+ }
142
+ catch (err) {
143
+ // do nothing
144
+ }
145
+ };
146
+ return (react_1.default.createElement(__1.default, { form: form, initialValues: { aaa: '2' } },
147
+ react_1.default.createElement(__1.default.Item, { name: "aaa" },
148
+ react_1.default.createElement(input_1.default, { onChange: onChange })),
149
+ react_1.default.createElement(__1.default.Item, { shouldUpdate: true, noStyle: true }, () => {
150
+ const aaa = form.getFieldValue('aaa');
151
+ if (aaa === '1') {
152
+ return (react_1.default.createElement(__1.default.Item, { name: "bbb", rules: [{ required: true, message: 'aaa' }] },
153
+ react_1.default.createElement(input_1.default, null)));
154
+ }
155
+ return (react_1.default.createElement(__1.default.Item, null,
156
+ react_1.default.createElement(__1.default.Item, { name: "ccc", rules: [{ required: true, message: 'ccc' }], noStyle: true },
157
+ react_1.default.createElement(input_1.default, null))));
158
+ })));
159
+ };
160
+ const { container } = (0, utils_1.render)(react_1.default.createElement(Demo, null));
161
+ await changeValue(0, '1');
162
+ await (0, utils_1.waitFakeTimer)(2000, 2000);
163
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('aaa');
164
+ await changeValue(0, '2');
165
+ await (0, utils_1.waitFakeTimer)(2000, 2000);
166
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('ccc');
167
+ await changeValue(0, '1');
168
+ await (0, utils_1.waitFakeTimer)(2000, 2000);
169
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('aaa');
170
+ });
171
+ });
172
+ it('render functions require either `shouldUpdate` or `dependencies`', () => {
173
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
174
+ react_1.default.createElement(__1.default.Item, null, () => null)));
175
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] A `Form.Item` with a render function must have either `shouldUpdate` or `dependencies`.');
176
+ });
177
+ it("`shouldUpdate` shouldn't work with `dependencies`", () => {
178
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
179
+ react_1.default.createElement(__1.default.Item, { shouldUpdate: true, dependencies: [] }, () => null)));
180
+ expect(errorSpy).toHaveBeenCalledWith("Warning: [antd: Form.Item] `shouldUpdate` and `dependencies` shouldn't be used together. See https://u.ant.design/form-deps.");
181
+ });
182
+ it('`name` should not work with render props', () => {
183
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
184
+ react_1.default.createElement(__1.default.Item, { name: "test", shouldUpdate: true }, () => null)));
185
+ expect(errorSpy).toHaveBeenCalledWith("Warning: [antd: Form.Item] A `Form.Item` with a render function cannot be a field, and thus cannot have a `name` prop.");
186
+ });
187
+ it('multiple children with a name prop', () => {
188
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
189
+ react_1.default.createElement(__1.default.Item, { name: "test" },
190
+ react_1.default.createElement("div", null, "one"),
191
+ react_1.default.createElement("div", null, "two"))));
192
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] A `Form.Item` with a `name` prop must have a single child element. For information on how to render more complex form items, see https://u.ant.design/complex-form-item.');
193
+ });
194
+ it('input element should have the prop aria-describedby pointing to the help id when there is a help message', () => {
195
+ var _a, _b;
196
+ const { container } = (0, utils_1.pureRender)(react_1.default.createElement(__1.default, null,
197
+ react_1.default.createElement(__1.default.Item, { name: "test", help: "This is a help" },
198
+ react_1.default.createElement("input", null))));
199
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBe('test_help');
200
+ expect((_b = container.querySelector('.ant-form-item-explain')) === null || _b === void 0 ? void 0 : _b.id).toBe('test_help');
201
+ });
202
+ it('input element should not have the prop aria-describedby pointing to the help id when there is a help message and name is not defined', () => {
203
+ var _a, _b;
204
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
205
+ react_1.default.createElement(__1.default.Item, { help: "This is a help" },
206
+ react_1.default.createElement("input", null))));
207
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBeFalsy();
208
+ expect((_b = container.querySelector('.ant-form-item-explain')) === null || _b === void 0 ? void 0 : _b.id).toBeFalsy();
209
+ });
210
+ it('input element should have the prop aria-describedby concatenated with the form name pointing to the help id when there is a help message', () => {
211
+ var _a, _b;
212
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, { name: "form" },
213
+ react_1.default.createElement(__1.default.Item, { name: "test", help: "This is a help" },
214
+ react_1.default.createElement("input", null))));
215
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBe('form_test_help');
216
+ expect((_b = container.querySelector('.ant-form-item-explain')) === null || _b === void 0 ? void 0 : _b.id).toBe('form_test_help');
217
+ });
218
+ it('input element should have the prop aria-describedby pointing to the help id when there are errors', async () => {
219
+ var _a, _b;
220
+ const { container } = (0, utils_1.pureRender)(react_1.default.createElement(__1.default, null,
221
+ react_1.default.createElement(__1.default.Item, { name: "test", rules: [{ len: 3 }, { type: 'number' }] },
222
+ react_1.default.createElement("input", null))));
223
+ await changeValue(0, 'Invalid number');
224
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBe('test_help');
225
+ expect((_b = container.querySelector('.ant-form-item-explain')) === null || _b === void 0 ? void 0 : _b.id).toBe('test_help');
226
+ });
227
+ it('input element should have the prop aria-invalid when there are errors', async () => {
228
+ var _a;
229
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
230
+ react_1.default.createElement(__1.default.Item, { name: "test", rules: [{ len: 3 }, { type: 'number' }] },
231
+ react_1.default.createElement("input", null))));
232
+ await changeValue(0, 'Invalid number');
233
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-invalid')).toBe('true');
234
+ });
235
+ it('input element should have the prop aria-required when the prop `required` is true', () => {
236
+ var _a;
237
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
238
+ react_1.default.createElement(__1.default.Item, { name: "test", required: true },
239
+ react_1.default.createElement("input", null))));
240
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-required')).toBe('true');
241
+ });
242
+ it('input element should have the prop aria-required when there is a rule with required', () => {
243
+ var _a;
244
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
245
+ react_1.default.createElement(__1.default.Item, { name: "test", rules: [{ required: true }] },
246
+ react_1.default.createElement("input", null))));
247
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-required')).toBe('true');
248
+ });
249
+ it('input element should have the prop aria-describedby pointing to the extra id when there is a extra message', () => {
250
+ var _a, _b;
251
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
252
+ react_1.default.createElement(__1.default.Item, { name: "test", extra: "This is a extra message" },
253
+ react_1.default.createElement("input", null))));
254
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBe('test_extra');
255
+ expect((_b = container.querySelector('.ant-form-item-extra')) === null || _b === void 0 ? void 0 : _b.id).toBe('test_extra');
256
+ });
257
+ it('input element should not have the prop aria-describedby pointing to the extra id when there is a extra message and name is not defined', () => {
258
+ var _a, _b;
259
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
260
+ react_1.default.createElement(__1.default.Item, { extra: "This is a extra message" },
261
+ react_1.default.createElement("input", null))));
262
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBeFalsy();
263
+ expect((_b = container.querySelector('.ant-form-item-extra')) === null || _b === void 0 ? void 0 : _b.id).toBeFalsy();
264
+ });
265
+ it('input element should have the prop aria-describedby pointing to the help and extra id when there is a help and extra message', () => {
266
+ var _a;
267
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
268
+ react_1.default.createElement(__1.default.Item, { name: "test", help: "This is a help", extra: "This is a extra message" },
269
+ react_1.default.createElement("input", null))));
270
+ expect((_a = container.querySelector('input')) === null || _a === void 0 ? void 0 : _a.getAttribute('aria-describedby')).toBe('test_help test_extra');
271
+ });
272
+ describe('scrollToField', () => {
273
+ const test = (name, genForm) => {
274
+ it(name, () => {
275
+ let callGetForm;
276
+ const Demo = () => {
277
+ const { props, getForm } = genForm();
278
+ callGetForm = getForm;
279
+ return (react_1.default.createElement(__1.default, Object.assign({ name: "scroll" }, props),
280
+ react_1.default.createElement(__1.default.Item, { name: "test" },
281
+ react_1.default.createElement(input_1.default, null))));
282
+ };
283
+ (0, utils_1.render)(react_1.default.createElement(Demo, null));
284
+ expect(scroll_into_view_if_needed_1.default).not.toHaveBeenCalled();
285
+ const form = callGetForm();
286
+ form.scrollToField('test', {
287
+ block: 'start',
288
+ });
289
+ const inputNode = document.getElementById('scroll_test');
290
+ expect(scroll_into_view_if_needed_1.default).toHaveBeenCalledWith(inputNode, {
291
+ block: 'start',
292
+ scrollMode: 'if-needed',
293
+ });
294
+ });
295
+ };
296
+ // hooks
297
+ test('useForm', () => {
298
+ const [form] = __1.default.useForm();
299
+ return {
300
+ props: { form },
301
+ getForm: () => form,
302
+ };
303
+ });
304
+ // ref
305
+ test('ref', () => {
306
+ let form;
307
+ return {
308
+ props: {
309
+ ref: (instance) => {
310
+ form = instance;
311
+ },
312
+ },
313
+ getForm: () => form,
314
+ };
315
+ });
316
+ });
317
+ it('scrollToFirstError', async () => {
318
+ const onFinishFailed = jest.fn();
319
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, { scrollToFirstError: { block: 'center' }, onFinishFailed: onFinishFailed },
320
+ react_1.default.createElement(__1.default.Item, { name: "test", rules: [{ required: true }] },
321
+ react_1.default.createElement("input", null)),
322
+ react_1.default.createElement(__1.default.Item, null,
323
+ react_1.default.createElement(button_1.default, { htmlType: "submit" }, "Submit"))));
324
+ expect(scroll_into_view_if_needed_1.default).not.toHaveBeenCalled();
325
+ utils_1.fireEvent.submit(container.querySelector('form'));
326
+ await (0, utils_1.waitFakeTimer)();
327
+ const inputNode = document.getElementById('test');
328
+ expect(scroll_into_view_if_needed_1.default).toHaveBeenCalledWith(inputNode, {
329
+ block: 'center',
330
+ scrollMode: 'if-needed',
331
+ });
332
+ expect(onFinishFailed).toHaveBeenCalled();
333
+ });
334
+ it('Form.Item should support data-*、aria-* and custom attribute', () => {
335
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
336
+ react_1.default.createElement(__1.default.Item, { "data-text": "123", "aria-hidden": "true", cccc: "bbbb" }, "text")));
337
+ expect(container.firstChild).toMatchSnapshot();
338
+ });
339
+ it('warning when use `name` but children is not validate element', () => {
340
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
341
+ react_1.default.createElement(__1.default.Item, { name: "warning" }, "text")));
342
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] `name` is only used for validate React element. If you are using Form.Item as layout display, please remove `name` instead.');
343
+ });
344
+ it('dynamic change required', async () => {
345
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
346
+ react_1.default.createElement(__1.default.Item, { label: "light", name: "light", valuePropName: "checked" },
347
+ react_1.default.createElement("input", { type: "checkbox" })),
348
+ react_1.default.createElement(__1.default.Item, { label: "bamboo", name: "bamboo", dependencies: ['light'], rules: [({ getFieldValue }) => ({ required: getFieldValue('light') })] },
349
+ react_1.default.createElement("input", null))));
350
+ // should not show alert by default
351
+ expect(container.querySelector('.ant-form-item-explain')).toBeFalsy();
352
+ // click to change the light field value to true
353
+ utils_1.fireEvent.click(container.querySelector('input'));
354
+ await (0, utils_1.waitFakeTimer)();
355
+ // user input something and clear
356
+ await changeValue(1, '1');
357
+ await changeValue(1, '');
358
+ // should show alert says that the field is required
359
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent("'bamboo' is required");
360
+ });
361
+ describe('should show related className when customize help', () => {
362
+ it('normal', async () => {
363
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
364
+ react_1.default.createElement(__1.default.Item, { help: "good" },
365
+ react_1.default.createElement("input", null))));
366
+ await (0, utils_1.waitFakeTimer)();
367
+ expect(container.querySelector('.ant-form-item-explain')).toHaveTextContent('good');
368
+ expect(container.querySelector('.ant-form-item-with-help')).toBeTruthy();
369
+ });
370
+ it('empty string', async () => {
371
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
372
+ react_1.default.createElement(__1.default.Item, { help: "" },
373
+ react_1.default.createElement("input", null))));
374
+ await (0, utils_1.waitFakeTimer)();
375
+ expect(container.querySelector('.ant-form-item-explain')).toHaveTextContent('');
376
+ expect(container.querySelector('.ant-form-item-with-help')).toBeTruthy();
377
+ });
378
+ });
379
+ it('warning when use v3 function', () => {
380
+ __1.default.create();
381
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form] antd v4 removed `Form.create`. Please remove or use `@ant-design/compatible` instead.');
382
+ });
383
+ // https://github.com/ant-design/ant-design/issues/20706
384
+ it('Error change should work', async () => {
385
+ var _a, _b;
386
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
387
+ react_1.default.createElement(__1.default.Item, { name: "name", label: "test", rules: [
388
+ { required: true },
389
+ {
390
+ validator: (_, value) => {
391
+ if (value === 'p') {
392
+ return Promise.reject(new Error('not a p'));
393
+ }
394
+ return Promise.resolve();
395
+ },
396
+ },
397
+ ] },
398
+ react_1.default.createElement(input_1.default, null))));
399
+ /* eslint-disable no-await-in-loop */
400
+ for (let i = 0; i < 3; i += 1) {
401
+ await changeValue(0, 'bamboo');
402
+ await changeValue(0, '');
403
+ expect((_a = container.querySelector('.ant-form-item-explain')) === null || _a === void 0 ? void 0 : _a.textContent).toEqual("'name' is required");
404
+ await changeValue(0, 'p');
405
+ expect((_b = container.querySelector('.ant-form-item-explain')) === null || _b === void 0 ? void 0 : _b.textContent).toEqual('not a p');
406
+ }
407
+ /* eslint-enable */
408
+ });
409
+ // https://github.com/ant-design/ant-design/issues/20813
410
+ it('should update help directly when provided', async () => {
411
+ const App = () => {
412
+ const [message, updateMessage] = react_1.default.useState('');
413
+ return (react_1.default.createElement(__1.default, null,
414
+ react_1.default.createElement(__1.default.Item, { label: "hello", help: message },
415
+ react_1.default.createElement(input_1.default, null)),
416
+ react_1.default.createElement(button_1.default, { onClick: () => updateMessage('bamboo') })));
417
+ };
418
+ const { container } = (0, utils_1.render)(react_1.default.createElement(App, null));
419
+ // should show initial text
420
+ await (0, utils_1.waitFakeTimer)();
421
+ expect(container.querySelector('.ant-form-item-explain')).toHaveTextContent('');
422
+ utils_1.fireEvent.click(container.querySelector('button'));
423
+ // should show bamboo alert without opacity and hide first alert with opacity: 0
424
+ await (0, utils_1.waitFakeTimer)();
425
+ expect(container.querySelector('.ant-form-item-explain')).toHaveTextContent('bamboo');
426
+ });
427
+ it('warning when use `dependencies` but `name` is empty & children is not a render props', () => {
428
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
429
+ react_1.default.createElement(__1.default.Item, { dependencies: [] }, "text")));
430
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] Must set `name` or use a render function when `dependencies` is set.');
431
+ });
432
+ // https://github.com/ant-design/ant-design/issues/20948
433
+ it('not repeat render when Form.Item is not a real Field', async () => {
434
+ const shouldNotRender = jest.fn();
435
+ const StaticInput = ({ id, value = '', }) => {
436
+ shouldNotRender();
437
+ return react_1.default.createElement("input", { id: id, value: value });
438
+ };
439
+ const shouldRender = jest.fn();
440
+ const DynamicInput = ({ value = '', id, }) => {
441
+ shouldRender();
442
+ return react_1.default.createElement("input", { id: id, value: value });
443
+ };
444
+ const formRef = react_1.default.createRef();
445
+ const { container } = (0, utils_1.pureRender)(react_1.default.createElement(__1.default, { ref: formRef },
446
+ react_1.default.createElement(__1.default.Item, null,
447
+ react_1.default.createElement(StaticInput, null)),
448
+ react_1.default.createElement(__1.default.Item, { name: "light" },
449
+ react_1.default.createElement(DynamicInput, { id: "changed" }))));
450
+ await (0, utils_1.waitFakeTimer)();
451
+ expect(container.querySelector('#changed').value).toEqual('');
452
+ expect(shouldNotRender).toHaveBeenCalledTimes(1);
453
+ expect(shouldRender).toHaveBeenCalledTimes(1);
454
+ formRef.current.setFieldsValue({ light: 'bamboo' });
455
+ await (0, utils_1.waitFakeTimer)(100, 100);
456
+ expect(formRef.current.getFieldsValue()).toEqual({ light: 'bamboo' });
457
+ expect(container.querySelector('#changed').value).toEqual('bamboo');
458
+ expect(shouldNotRender).toHaveBeenCalledTimes(1);
459
+ expect(shouldRender).toHaveBeenCalledTimes(2);
460
+ });
461
+ it('empty help should also render', () => {
462
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default.Item, { help: "" },
463
+ react_1.default.createElement("input", null)));
464
+ expect(container.querySelectorAll('.ant-form-item-explain').length).toBeTruthy();
465
+ });
466
+ it('Form.Item with `help` should display error style when validate failed', async () => {
467
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
468
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "test", help: "help", initialValue: "bamboo", rules: [{ required: true, message: 'message' }] },
469
+ react_1.default.createElement(input_1.default, null))));
470
+ await changeValue(0, '');
471
+ expect(container.querySelector('.ant-form-item')).toHaveClass('ant-form-item-has-error');
472
+ expect(container.querySelector('.ant-form-item-explain').textContent).toEqual('help');
473
+ });
474
+ it('clear validation message when', async () => {
475
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
476
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "test", rules: [{ required: true, message: 'message' }] },
477
+ react_1.default.createElement(input_1.default, null))));
478
+ await changeValue(0, '1');
479
+ expect(container.querySelectorAll('.ant-form-item-explain').length).toBeFalsy();
480
+ await changeValue(0, '');
481
+ expect(container.querySelectorAll('.ant-form-item-explain').length).toBeTruthy();
482
+ await changeValue(0, '123');
483
+ expect(container.querySelectorAll('.ant-form-item-explain').length).toBeFalsy();
484
+ });
485
+ // https://github.com/ant-design/ant-design/issues/21167
486
+ it('`require` without `name`', () => {
487
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default.Item, { label: "test", name: "test", required: true },
488
+ react_1.default.createElement("input", null)));
489
+ // expect(screen.getByTitle('test')).toHaveClass('ant-form-item-required');
490
+ expect(container.querySelector('.ant-form-item-required')).toBeTruthy();
491
+ });
492
+ it('0 is a validate Field', () => {
493
+ (0, utils_1.render)(react_1.default.createElement(__1.default.Item, { name: 0, label: "0" },
494
+ react_1.default.createElement("input", null)));
495
+ // if getByLabelText can get element, then it is a validate field with form control and label
496
+ expect(utils_1.screen.getByLabelText('0')).toBeInTheDocument();
497
+ });
498
+ it('`null` triggers warning and is treated as `undefined`', () => {
499
+ (0, utils_1.render)(react_1.default.createElement(__1.default.Item, { name: null, label: "test" },
500
+ react_1.default.createElement("input", null)));
501
+ // if getByLabelText can get element, then it is a validate field with form control and label
502
+ expect(utils_1.screen.queryByLabelText('test')).not.toBeInTheDocument();
503
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] `null` is passed as `name` property');
504
+ });
505
+ // https://github.com/ant-design/ant-design/issues/21415
506
+ it('should not throw error when Component.props.onChange is null', async () => {
507
+ const CustomComponent = () => (react_1.default.createElement("input", { onChange: null }));
508
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
509
+ react_1.default.createElement(__1.default.Item, { name: "custom" },
510
+ react_1.default.createElement(CustomComponent, null))));
511
+ await changeValue(0, 'aaa');
512
+ });
513
+ it('change `help` should not warning', async () => {
514
+ const Demo = () => {
515
+ const [error, setError] = react_1.default.useState(false);
516
+ return (react_1.default.createElement(__1.default, null,
517
+ react_1.default.createElement(__1.default.Item, { help: error ? 'This is an error msg' : undefined, validateStatus: error ? 'error' : '', label: "Username", name: "username" },
518
+ react_1.default.createElement("input", null)),
519
+ react_1.default.createElement(__1.default.Item, null,
520
+ react_1.default.createElement("button", { type: "button", onClick: () => setError(!error) }, "Trigger"))));
521
+ };
522
+ const { container } = (0, utils_1.render)(react_1.default.createElement(Demo, null));
523
+ utils_1.fireEvent.click(container.querySelector('button'));
524
+ expect(errorSpy).not.toHaveBeenCalled();
525
+ });
526
+ it('`label` support template', async () => {
527
+ const { container } = (0, utils_1.render)(
528
+ // eslint-disable-next-line no-template-curly-in-string
529
+ react_1.default.createElement(__1.default, { validateMessages: { required: '${label} is good!' } },
530
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "Bamboo", rules: [{ required: true }] },
531
+ react_1.default.createElement("input", null))));
532
+ utils_1.fireEvent.submit(container.querySelector('form'));
533
+ await (0, utils_1.waitFakeTimer)();
534
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('Bamboo is good!');
535
+ });
536
+ // https://github.com/ant-design/ant-design/issues/33691
537
+ it('should keep upper locale in nested ConfigProvider', async () => {
538
+ const { container } = (0, utils_1.render)(react_1.default.createElement(config_provider_1.default, { locale: zh_CN_1.default },
539
+ react_1.default.createElement(config_provider_1.default, null,
540
+ react_1.default.createElement(__1.default, null,
541
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "Bamboo", rules: [{ required: true }] },
542
+ react_1.default.createElement("input", null))))));
543
+ utils_1.fireEvent.submit(container.querySelector('form'));
544
+ await (0, utils_1.waitFakeTimer)();
545
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('请输入Bamboo');
546
+ });
547
+ it('`name` support template when label is not provided', async () => {
548
+ const { container } = (0, utils_1.render)(
549
+ // eslint-disable-next-line no-template-curly-in-string
550
+ react_1.default.createElement(__1.default, { validateMessages: { required: '${label} is good!' } },
551
+ react_1.default.createElement(__1.default.Item, { name: "Bamboo", rules: [{ required: true }] },
552
+ react_1.default.createElement("input", null))));
553
+ utils_1.fireEvent.submit(container.querySelector('form'));
554
+ await (0, utils_1.waitFakeTimer)();
555
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('Bamboo is good!');
556
+ });
557
+ it('`messageVariables` support validate', async () => {
558
+ const { container } = (0, utils_1.render)(
559
+ // eslint-disable-next-line no-template-curly-in-string
560
+ react_1.default.createElement(__1.default, { validateMessages: { required: '${label} is good!' } },
561
+ react_1.default.createElement(__1.default.Item, { name: "test", messageVariables: { label: 'Bamboo' }, rules: [{ required: true }] },
562
+ react_1.default.createElement("input", null))));
563
+ utils_1.fireEvent.submit(container.querySelector('form'));
564
+ await (0, utils_1.waitFakeTimer)();
565
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('Bamboo is good!');
566
+ });
567
+ it('validation message should has alert role', async () => {
568
+ // https://github.com/ant-design/ant-design/issues/25711
569
+ const { container } = (0, utils_1.render)(
570
+ // eslint-disable-next-line no-template-curly-in-string
571
+ react_1.default.createElement(__1.default, { validateMessages: { required: 'name is good!' } },
572
+ react_1.default.createElement(__1.default.Item, { name: "test", rules: [{ required: true }] },
573
+ react_1.default.createElement("input", null)),
574
+ react_1.default.createElement(__1.default.Item, null,
575
+ react_1.default.createElement(button_1.default, { htmlType: "submit" }, "Submit"))));
576
+ utils_1.fireEvent.submit(container.querySelector('form'));
577
+ await (0, utils_1.waitFakeTimer)();
578
+ expect(container.querySelector('.ant-form-item-explain-error')).toHaveTextContent('name is good!');
579
+ });
580
+ it('return same form instance', async () => {
581
+ const instances = new Set();
582
+ const App = () => {
583
+ const [form] = __1.default.useForm();
584
+ instances.add(form);
585
+ const [, forceUpdate] = react_1.default.useState({});
586
+ return (react_1.default.createElement("button", { type: "button", onClick: () => {
587
+ forceUpdate({});
588
+ } }, "Refresh"));
589
+ };
590
+ const { container } = (0, utils_1.pureRender)(react_1.default.createElement(App, null));
591
+ for (let i = 0; i < 5; i += 1) {
592
+ utils_1.fireEvent.click(container.querySelector('button'));
593
+ // eslint-disable-next-line no-await-in-loop
594
+ await (0, utils_1.waitFakeTimer)();
595
+ }
596
+ expect(instances.size).toBe(1);
597
+ });
598
+ it('should avoid re-render', async () => {
599
+ let renderTimes = 0;
600
+ const MyInput = (_a) => {
601
+ var { value = '' } = _a, props = __rest(_a, ["value"]);
602
+ renderTimes += 1;
603
+ return react_1.default.createElement("input", Object.assign({ value: value }, props));
604
+ };
605
+ const Demo = () => (react_1.default.createElement(__1.default, null,
606
+ react_1.default.createElement(__1.default.Item, { name: "username", label: "username", rules: [{ required: true }] },
607
+ react_1.default.createElement(MyInput, null))));
608
+ const { container } = (0, utils_1.pureRender)(react_1.default.createElement(Demo, null));
609
+ renderTimes = 0;
610
+ await changeValue(0, 'a');
611
+ expect(renderTimes).toEqual(1);
612
+ expect(container.querySelector('input')).toHaveValue('a');
613
+ });
614
+ it('should warning with `defaultValue`', () => {
615
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
616
+ react_1.default.createElement(__1.default.Item, { name: "light" },
617
+ react_1.default.createElement("input", { defaultValue: "should warning" }))));
618
+ expect(errorSpy).toHaveBeenCalledWith('Warning: [antd: Form.Item] `defaultValue` will not work on controlled Field. You should use `initialValues` of Form instead.');
619
+ });
620
+ it('should remove Field and also reset error', async () => {
621
+ const Demo = ({ showA }) => (react_1.default.createElement(__1.default, null, showA ? (react_1.default.createElement(__1.default.Item, { name: "a", help: "error" },
622
+ react_1.default.createElement("input", null))) : (react_1.default.createElement(__1.default.Item, { name: "b" },
623
+ react_1.default.createElement("input", null)))));
624
+ const { container, rerender } = (0, utils_1.render)(react_1.default.createElement(Demo, { showA: true }));
625
+ await (0, utils_1.waitFakeTimer)();
626
+ expect(container.querySelector('.ant-form-item-explain')).toBeTruthy();
627
+ rerender(react_1.default.createElement(Demo, { showA: false }));
628
+ await (0, utils_1.waitFakeTimer)();
629
+ expect(container.querySelector('.ant-form-item-explain')).toBeFalsy();
630
+ });
631
+ it('no warning of initialValue & getValueProps & preserve', () => {
632
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
633
+ react_1.default.createElement(__1.default.Item, { initialValue: "bamboo", getValueProps: () => ({}), preserve: false },
634
+ react_1.default.createElement(input_1.default, null))));
635
+ expect(errorSpy).not.toHaveBeenCalled();
636
+ });
637
+ it('should customize id when pass with id', () => {
638
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
639
+ react_1.default.createElement(__1.default.Item, { name: "light" },
640
+ react_1.default.createElement(input_1.default, { id: "bamboo" }))));
641
+ expect(container.querySelector('input').id).toEqual('bamboo');
642
+ });
643
+ it('should trigger validate when onBlur when pass validateTrigger onBlur', async () => {
644
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, { validateTrigger: "onBlur" },
645
+ react_1.default.createElement(__1.default.Item, { name: "light", label: "light", rules: [{ len: 3 }] },
646
+ react_1.default.createElement(input_1.default, null))));
647
+ // type a invalidate value, not trigger validation
648
+ await changeValue(0, '7777');
649
+ expect(container.querySelector('.ant-form-item-explain')).toBeFalsy();
650
+ // tab(onBlur) the input field, trigger and see the alert
651
+ utils_1.fireEvent.blur(container.querySelector('input'));
652
+ await (0, utils_1.waitFakeTimer)();
653
+ expect(container.querySelector('.ant-form-item-explain')).toBeTruthy();
654
+ });
655
+ describe('Form item hidden', () => {
656
+ it('should work', () => {
657
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
658
+ react_1.default.createElement(__1.default.Item, { name: "light", hidden: true },
659
+ react_1.default.createElement(input_1.default, null))));
660
+ expect(container.firstChild).toMatchSnapshot();
661
+ });
662
+ it('noStyle should not work when hidden', () => {
663
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
664
+ react_1.default.createElement(__1.default.Item, { name: "light", hidden: true, noStyle: true },
665
+ react_1.default.createElement(input_1.default, null))));
666
+ expect(container.firstChild).toMatchSnapshot();
667
+ });
668
+ });
669
+ it('legacy hideRequiredMark', () => {
670
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, { hideRequiredMark: true, role: "form" },
671
+ react_1.default.createElement(__1.default.Item, { name: "light", label: "light", required: true },
672
+ react_1.default.createElement(input_1.default, null))));
673
+ expect(container.querySelector('form')).toHaveClass('ant-form-hide-required-mark');
674
+ });
675
+ it('form should support disabled', () => {
676
+ const App = () => (react_1.default.createElement(__1.default, { labelCol: { span: 4 }, wrapperCol: { span: 14 }, layout: "horizontal", disabled: true },
677
+ react_1.default.createElement(__1.default.Item, { label: "Form disabled", name: "disabled", valuePropName: "checked" },
678
+ react_1.default.createElement(checkbox_1.default, null, "disabled")),
679
+ react_1.default.createElement(__1.default.Item, { label: "Radio" },
680
+ react_1.default.createElement(radio_1.default.Group, null,
681
+ react_1.default.createElement(radio_1.default, { value: "apple" }, "Apple"),
682
+ react_1.default.createElement(radio_1.default, { value: "pear" }, "Pear"))),
683
+ react_1.default.createElement(__1.default.Item, { label: "Input" },
684
+ react_1.default.createElement(input_1.default, null)),
685
+ react_1.default.createElement(__1.default.Item, { label: "Select" },
686
+ react_1.default.createElement(select_1.default, null,
687
+ react_1.default.createElement(select_1.default.Option, { value: "demo" }, "Demo"))),
688
+ react_1.default.createElement(__1.default.Item, { label: "TreeSelect" },
689
+ react_1.default.createElement(tree_select_1.default, { treeData: [
690
+ {
691
+ title: 'Light',
692
+ value: 'light',
693
+ children: [{ title: 'Bamboo', value: 'bamboo' }],
694
+ },
695
+ ] })),
696
+ react_1.default.createElement(__1.default.Item, { label: "Cascader" },
697
+ react_1.default.createElement(cascader_1.default, { options: [
698
+ {
699
+ value: 'zhejiang',
700
+ label: 'Zhejiang',
701
+ children: [{ value: 'hangzhou', label: 'Hangzhou' }],
702
+ },
703
+ ] })),
704
+ react_1.default.createElement(__1.default.Item, { label: "DatePicker" },
705
+ react_1.default.createElement(date_picker_1.default, null)),
706
+ react_1.default.createElement(__1.default.Item, { label: "RangePicker" },
707
+ react_1.default.createElement(RangePicker, null)),
708
+ react_1.default.createElement(__1.default.Item, { label: "InputNumber" },
709
+ react_1.default.createElement(input_number_1.default, null)),
710
+ react_1.default.createElement(__1.default.Item, { label: "TextArea" },
711
+ react_1.default.createElement(TextArea, { rows: 4 })),
712
+ react_1.default.createElement(__1.default.Item, { label: "Switch", valuePropName: "checked" },
713
+ react_1.default.createElement(switch_1.default, null)),
714
+ react_1.default.createElement(__1.default.Item, { label: "Upload", valuePropName: "fileList" },
715
+ react_1.default.createElement(upload_1.default, null)),
716
+ react_1.default.createElement(__1.default.Item, { label: "Button" },
717
+ react_1.default.createElement(button_1.default, null, "Button"))));
718
+ const { container } = (0, utils_1.render)(react_1.default.createElement(App, null));
719
+ expect(container.firstChild).toMatchSnapshot();
720
+ });
721
+ it('_internalItemRender api test', () => {
722
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
723
+ react_1.default.createElement(__1.default.Item, { name: "light",
724
+ // @ts-ignore
725
+ _internalItemRender: {
726
+ mark: 'pro_table_render',
727
+ render: (_, doms) => (react_1.default.createElement("div", null,
728
+ react_1.default.createElement("h1", null, "warning title"),
729
+ doms.input,
730
+ doms.errorList,
731
+ doms.extra)),
732
+ } },
733
+ react_1.default.createElement("input", { defaultValue: "should warning" }))));
734
+ expect(container.querySelector('h1')).toHaveTextContent(/warning title/i);
735
+ });
736
+ it('Form Item element id will auto add form_item prefix if form name is empty and item name is in the black list', async () => {
737
+ const mockFn = jest.spyOn(Util, 'getFieldId');
738
+ const itemName = 'parentNode';
739
+ // mock getFieldId old logic,if form name is empty ,and item name is parentNode,will get parentNode
740
+ mockFn.mockImplementation(() => itemName);
741
+ const { Option } = select_1.default;
742
+ const Demo = () => {
743
+ const [open, setOpen] = (0, react_1.useState)(false);
744
+ return (react_1.default.createElement(react_1.default.Fragment, null,
745
+ react_1.default.createElement(__1.default, null,
746
+ react_1.default.createElement(__1.default.Item, { name: itemName, label: itemName },
747
+ react_1.default.createElement(select_1.default, { className: "form_item_parentNode", defaultValue: "lucy", open: open, style: { width: 120 } },
748
+ react_1.default.createElement(Option, { value: "jack" }, "Jack"),
749
+ react_1.default.createElement(Option, { value: "lucy" }, "Lucy"),
750
+ react_1.default.createElement(Option, { value: "Yiminghe" }, "yiminghe")))),
751
+ react_1.default.createElement("button", { type: "button", onClick: () => {
752
+ setOpen(true);
753
+ } }, open ? 'show' : 'hidden')));
754
+ };
755
+ const { container, rerender } = (0, utils_1.render)(react_1.default.createElement(Demo, null));
756
+ expect(mockFn).toHaveBeenCalled();
757
+ expect(Util.getFieldId()).toBe(itemName);
758
+ // make sure input id is parentNode
759
+ expect(utils_1.screen.getByLabelText(itemName)).toHaveAccessibleName(itemName);
760
+ utils_1.fireEvent.click(container.querySelector('button'));
761
+ await (0, utils_1.waitFakeTimer)();
762
+ expect(container.querySelector('button')).toHaveTextContent('show');
763
+ mockFn.mockRestore();
764
+ rerender(react_1.default.createElement(Demo, null));
765
+ expect(utils_1.screen.getByLabelText(itemName)).toBeInTheDocument();
766
+ });
767
+ describe('tooltip', () => {
768
+ it('ReactNode', async () => {
769
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
770
+ react_1.default.createElement(__1.default.Item, { label: "light", tooltip: react_1.default.createElement("span", null, "Bamboo") },
771
+ react_1.default.createElement(input_1.default, null))));
772
+ utils_1.fireEvent.mouseEnter(container.querySelector('.anticon-question-circle'));
773
+ await (0, utils_1.waitFakeTimer)();
774
+ expect(container.querySelector('.ant-tooltip-inner')).toHaveTextContent('Bamboo');
775
+ });
776
+ it('config tooltip should show when hover on icon', async () => {
777
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
778
+ react_1.default.createElement(__1.default.Item, { label: "light", tooltip: { title: 'Bamboo' } },
779
+ react_1.default.createElement(input_1.default, null))));
780
+ utils_1.fireEvent.mouseEnter(container.querySelector('.anticon-question-circle'));
781
+ await (0, utils_1.waitFakeTimer)();
782
+ expect(container.querySelector('.ant-tooltip-inner')).toHaveTextContent('Bamboo');
783
+ });
784
+ });
785
+ it('warningOnly validate', async () => {
786
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
787
+ react_1.default.createElement(__1.default.Item, null,
788
+ react_1.default.createElement(__1.default.Item, { name: "test", label: "test", initialValue: "bamboo", rules: [{ required: true, warningOnly: true }] },
789
+ react_1.default.createElement(input_1.default, null)))));
790
+ await changeValue(0, 'test');
791
+ await changeValue(0, '');
792
+ expect(container.querySelector('.ant-form-item-with-help')).toBeTruthy();
793
+ expect(container.querySelector('.ant-form-item-has-warning')).toBeTruthy();
794
+ });
795
+ it('not warning when remove on validate', async () => {
796
+ let rejectFn = jest.fn();
797
+ const { unmount } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
798
+ react_1.default.createElement(__1.default.Item, null,
799
+ react_1.default.createElement(__1.default.Item, { noStyle: true, name: "test", initialValue: "bamboo", rules: [
800
+ {
801
+ validator: () => new Promise((_, reject) => {
802
+ rejectFn = reject;
803
+ }),
804
+ },
805
+ ] },
806
+ react_1.default.createElement(input_1.default, null)))));
807
+ await changeValue(0, '');
808
+ unmount();
809
+ // Delay validate failed
810
+ rejectFn(new Error('delay failed'));
811
+ expect(errorSpy).not.toHaveBeenCalled();
812
+ });
813
+ describe('form colon', () => {
814
+ it('default colon', () => {
815
+ (0, utils_1.render)(react_1.default.createElement(__1.default, null,
816
+ react_1.default.createElement(__1.default.Item, { label: "\u59D3\u540D", name: "\u59D3\u540D" },
817
+ react_1.default.createElement("input", null))));
818
+ expect(utils_1.screen.getByText('姓名')).not.toHaveClass('ant-form-item-no-colon');
819
+ });
820
+ it('set Form.Item colon false', () => {
821
+ (0, utils_1.render)(react_1.default.createElement(__1.default, { colon: true },
822
+ react_1.default.createElement(__1.default.Item, { colon: false, label: "\u59D3\u540D", name: "\u59D3\u540D" },
823
+ react_1.default.createElement(input_1.default, null))));
824
+ expect(utils_1.screen.getByText('姓名')).toHaveClass('ant-form-item-no-colon');
825
+ });
826
+ it('set Form colon false', () => {
827
+ (0, utils_1.render)(react_1.default.createElement(__1.default, { colon: false },
828
+ react_1.default.createElement(__1.default.Item, { label: "\u59D3\u540D", name: "\u59D3\u540D" },
829
+ react_1.default.createElement(input_1.default, null))));
830
+ expect(utils_1.screen.getByText('姓名')).toHaveClass('ant-form-item-no-colon');
831
+ });
832
+ });
833
+ it('useFormInstance', () => {
834
+ let formInstance;
835
+ let subFormInstance;
836
+ const Sub = () => {
837
+ const formSub = __1.default.useFormInstance();
838
+ subFormInstance = formSub;
839
+ return null;
840
+ };
841
+ const Demo = () => {
842
+ const [form] = __1.default.useForm();
843
+ formInstance = form;
844
+ return (react_1.default.createElement(__1.default, { form: form },
845
+ react_1.default.createElement(Sub, null)));
846
+ };
847
+ (0, utils_1.render)(react_1.default.createElement(Demo, null));
848
+ expect(subFormInstance).toBe(formInstance);
849
+ });
850
+ it('noStyle should not affect status', () => {
851
+ var _a, _b, _c, _d, _e, _f, _g, _h;
852
+ const Demo = () => (react_1.default.createElement(__1.default, null,
853
+ react_1.default.createElement(__1.default.Item, { validateStatus: "error", noStyle: true },
854
+ react_1.default.createElement(select_1.default, { className: "custom-select" })),
855
+ react_1.default.createElement(__1.default.Item, { validateStatus: "error" },
856
+ react_1.default.createElement(__1.default.Item, { noStyle: true },
857
+ react_1.default.createElement(select_1.default, { className: "custom-select-b" }))),
858
+ react_1.default.createElement(__1.default.Item, { validateStatus: "error" },
859
+ react_1.default.createElement(__1.default.Item, { noStyle: true, validateStatus: "warning" },
860
+ react_1.default.createElement(select_1.default, { className: "custom-select-c" }))),
861
+ react_1.default.createElement(__1.default.Item, { noStyle: true },
862
+ react_1.default.createElement(__1.default.Item, { validateStatus: "warning" },
863
+ react_1.default.createElement(select_1.default, { className: "custom-select-d" })))));
864
+ const { container } = (0, utils_1.render)(react_1.default.createElement(Demo, null));
865
+ expect((_a = container.querySelector('.custom-select')) === null || _a === void 0 ? void 0 : _a.className).not.toContain('status-error');
866
+ expect((_b = container.querySelector('.custom-select')) === null || _b === void 0 ? void 0 : _b.className).not.toContain('in-form-item');
867
+ expect((_c = container.querySelector('.custom-select-b')) === null || _c === void 0 ? void 0 : _c.className).toContain('status-error');
868
+ expect((_d = container.querySelector('.custom-select-b')) === null || _d === void 0 ? void 0 : _d.className).toContain('in-form-item');
869
+ expect((_e = container.querySelector('.custom-select-c')) === null || _e === void 0 ? void 0 : _e.className).toContain('status-error');
870
+ expect((_f = container.querySelector('.custom-select-c')) === null || _f === void 0 ? void 0 : _f.className).toContain('in-form-item');
871
+ expect((_g = container.querySelector('.custom-select-d')) === null || _g === void 0 ? void 0 : _g.className).toContain('status-warning');
872
+ expect((_h = container.querySelector('.custom-select-d')) === null || _h === void 0 ? void 0 : _h.className).toContain('in-form-item');
873
+ });
874
+ it('should not affect Popup children style', () => {
875
+ var _a, _b, _c, _d;
876
+ const Demo = () => (react_1.default.createElement(__1.default, null,
877
+ react_1.default.createElement(__1.default.Item, { labelCol: 4, validateStatus: "error" },
878
+ react_1.default.createElement(modal_1.default, { visible: true },
879
+ react_1.default.createElement(select_1.default, { className: "modal-select" }))),
880
+ react_1.default.createElement(__1.default.Item, { validateStatus: "error" },
881
+ react_1.default.createElement(drawer_1.default, { visible: true },
882
+ react_1.default.createElement(select_1.default, { className: "drawer-select" })))));
883
+ const { container } = (0, utils_1.render)(react_1.default.createElement(Demo, null), { container: document.body });
884
+ expect((_a = container.querySelector('.modal-select')) === null || _a === void 0 ? void 0 : _a.className).not.toContain('in-form-item');
885
+ expect((_b = container.querySelector('.modal-select')) === null || _b === void 0 ? void 0 : _b.className).not.toContain('status-error');
886
+ expect((_c = container.querySelector('.drawer-select')) === null || _c === void 0 ? void 0 : _c.className).not.toContain('in-form-item');
887
+ expect((_d = container.querySelector('.drawer-select')) === null || _d === void 0 ? void 0 : _d.className).not.toContain('status-error');
888
+ });
889
+ it('Form.Item.useStatus should work', async () => {
890
+ var _a, _b, _c, _d, _e;
891
+ const { Item: { useStatus }, } = __1.default;
892
+ const CustomInput = ({ className, value, }) => {
893
+ const { status } = useStatus();
894
+ return react_1.default.createElement("div", { className: (0, classnames_1.default)(className, `custom-input-status-${status}`) }, value);
895
+ };
896
+ const Demo = () => {
897
+ const [form] = __1.default.useForm();
898
+ return (react_1.default.createElement(__1.default, { form: form, name: "my-form" },
899
+ react_1.default.createElement(__1.default.Item, { name: "required", rules: [{ required: true }] },
900
+ react_1.default.createElement(CustomInput, { className: "custom-input-required", value: "" })),
901
+ react_1.default.createElement(__1.default.Item, { name: "warning", validateStatus: "warning" },
902
+ react_1.default.createElement(CustomInput, { className: "custom-input-warning" })),
903
+ react_1.default.createElement(__1.default.Item, { name: "normal" },
904
+ react_1.default.createElement(CustomInput, { className: "custom-input" })),
905
+ react_1.default.createElement(CustomInput, { className: "custom-input-wrong" }),
906
+ react_1.default.createElement(button_1.default, { onClick: () => form.submit(), className: "submit-button" }, "Submit")));
907
+ };
908
+ const { container } = (0, utils_1.render)(react_1.default.createElement(Demo, null));
909
+ expect((_a = container.querySelector('.custom-input-required')) === null || _a === void 0 ? void 0 : _a.classList).toContain('custom-input-status-');
910
+ expect((_b = container.querySelector('.custom-input-warning')) === null || _b === void 0 ? void 0 : _b.classList).toContain('custom-input-status-warning');
911
+ expect((_c = container.querySelector('.custom-input')) === null || _c === void 0 ? void 0 : _c.classList).toContain('custom-input-status-');
912
+ expect((_d = container.querySelector('.custom-input-wrong')) === null || _d === void 0 ? void 0 : _d.classList).toContain('custom-input-status-undefined');
913
+ expect(errorSpy).toHaveBeenCalledWith(expect.stringContaining('Form.Item.useStatus should be used under Form.Item component.'));
914
+ utils_1.fireEvent.click(container.querySelector('.submit-button'));
915
+ await (0, utils_1.waitFakeTimer)();
916
+ expect((_e = container.querySelector('.custom-input-required')) === null || _e === void 0 ? void 0 : _e.classList).toContain('custom-input-status-error');
917
+ });
918
+ it('item customize margin', async () => {
919
+ const computeSpy = jest
920
+ .spyOn(window, 'getComputedStyle')
921
+ .mockImplementation(() => ({ marginBottom: 24 }));
922
+ const { container } = (0, utils_1.render)(react_1.default.createElement(__1.default, null,
923
+ react_1.default.createElement(__1.default.Item, { name: "required", initialValue: "bamboo", rules: [{ required: true }] },
924
+ react_1.default.createElement(input_1.default, null))));
925
+ await changeValue(0, '');
926
+ computeSpy.mockRestore();
927
+ expect(container.querySelector('.ant-form-item-margin-offset')).toHaveStyle({
928
+ marginBottom: -24,
929
+ });
930
+ });
931
+ it('form child components should be given priority to own disabled props when it in a disabled form', () => {
932
+ const props = {
933
+ name: 'file',
934
+ action: 'https://www.mocky.io/v2/5cc8019d300000980a055e76',
935
+ headers: {
936
+ authorization: 'authorization-text',
937
+ },
938
+ capture: true,
939
+ };
940
+ const renderComps = (disabled) => [
941
+ react_1.default.createElement(button_1.default, { key: "Button", disabled: disabled, type: "primary", htmlType: "submit" }, "test"),
942
+ react_1.default.createElement(cascader_1.default, { key: "Cascader", disabled: disabled, options: [] }),
943
+ react_1.default.createElement(checkbox_1.default, { key: "Checkbox", disabled: disabled }),
944
+ react_1.default.createElement(checkbox_1.default.Group, { key: "CheckboxGroup", disabled: disabled, options: [
945
+ { label: 'male', value: 0 },
946
+ { label: 'female', value: 1 },
947
+ ] }),
948
+ react_1.default.createElement(input_number_1.default, { key: "InputNumber", disabled: disabled }),
949
+ react_1.default.createElement(input_1.default, { key: "Input", disabled: disabled }),
950
+ react_1.default.createElement(select_1.default, { key: "Select", disabled: disabled }),
951
+ react_1.default.createElement(switch_1.default, { key: "Switch", disabled: disabled }),
952
+ react_1.default.createElement(tree_select_1.default, { key: "TreeSelect", disabled: disabled }),
953
+ react_1.default.createElement(upload_1.default, Object.assign({ key: "Upload" }, props, { disabled: disabled }),
954
+ react_1.default.createElement(button_1.default, { disabled: disabled }, "Click to Upload")),
955
+ react_1.default.createElement(date_picker_1.default, { key: "DatePicker", disabled: disabled }),
956
+ react_1.default.createElement(date_picker_1.default.RangePicker, { key: "DatePicker.RangePicker", disabled: disabled }),
957
+ react_1.default.createElement(date_picker_1.default.MonthPicker, { key: "DatePicker.MonthPicker", disabled: disabled }),
958
+ react_1.default.createElement(date_picker_1.default.QuarterPicker, { key: "DatePicker.QuarterPicker", disabled: disabled }),
959
+ react_1.default.createElement(date_picker_1.default.WeekPicker, { key: "DatePicker.WeekPicker", disabled: disabled }),
960
+ react_1.default.createElement(date_picker_1.default.YearPicker, { key: "DatePicker.YearPicker", disabled: disabled }),
961
+ react_1.default.createElement(date_picker_1.default.TimePicker, { key: "DatePicker.TimePicker", disabled: disabled }),
962
+ ];
963
+ const App = () => react_1.default.createElement(__1.default, { disabled: true }, renderComps(false));
964
+ const wrapper = (0, utils_1.render)(react_1.default.createElement(App, null));
965
+ expect(wrapper.container.querySelectorAll('[disabled]').length).toBe(0);
966
+ const App2 = () => react_1.default.createElement(__1.default, { disabled: true }, renderComps());
967
+ const wrapper2 = (0, utils_1.render)(react_1.default.createElement(App2, null));
968
+ // 时间范围组件中会有两个 input 框,因此虽然上述只有 18 个组件,但,实际有 19 个 带有 disabled 属性的表单组件
969
+ expect(wrapper2.container.querySelectorAll('[disabled]').length).toBe(19);
970
+ const App3 = () => react_1.default.createElement(__1.default, { disabled: true }, renderComps(true));
971
+ const wrapper3 = (0, utils_1.render)(react_1.default.createElement(App3, null));
972
+ expect(wrapper3.container.querySelectorAll('[disabled]').length).toBe(19);
973
+ const App4 = () => react_1.default.createElement(__1.default, null, renderComps(true));
974
+ const wrapper4 = (0, utils_1.render)(react_1.default.createElement(App4, null));
975
+ expect(wrapper4.container.querySelectorAll('[disabled]').length).toBe(19);
976
+ const App5 = () => react_1.default.createElement(__1.default, null, renderComps());
977
+ const wrapper5 = (0, utils_1.render)(react_1.default.createElement(App5, null));
978
+ expect(wrapper5.container.querySelectorAll('[disabled]').length).toBe(0);
979
+ });
980
+ });
981
+ //# sourceMappingURL=index.test.js.map