tntd 2.7.22 → 2.7.24

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 (427) hide show
  1. package/es/_util/motion.js +16 -0
  2. package/es/_util/motion.js.map +1 -0
  3. package/es/_util/type.js +4 -0
  4. package/es/_util/type.js.map +1 -0
  5. package/es/_util/warning.js +6 -0
  6. package/es/_util/warning.js.map +1 -0
  7. package/es/button/button.js +8 -0
  8. package/es/button/button.js.map +1 -1
  9. package/es/handle/handle.js +102 -0
  10. package/es/handle/handle.js.map +1 -0
  11. package/es/index.js +1 -0
  12. package/es/index.js.map +1 -1
  13. package/es/locale/en_US.js +6 -3
  14. package/es/locale/en_US.js.map +1 -1
  15. package/es/locale/zh_CN.js +4 -1
  16. package/es/locale/zh_CN.js.map +1 -1
  17. package/es/mention/index.js +4 -0
  18. package/es/mention/index.js.map +1 -0
  19. package/es/prev-locale.js +1 -1
  20. package/es/prev-locale.js.map +1 -1
  21. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
  22. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  23. package/es/tntd-form/TntdForm/components/Item.js +55 -0
  24. package/es/tntd-form/TntdForm/components/Item.js.map +1 -0
  25. package/es/tntd-form/TntdForm/components/ItemComp.js +186 -0
  26. package/es/tntd-form/TntdForm/components/ItemComp.js.map +1 -0
  27. package/es/tntd-form/TntdForm/components/List.js +102 -0
  28. package/es/tntd-form/TntdForm/components/List.js.map +1 -0
  29. package/es/tntd-form/TntdForm/index.js +55 -0
  30. package/es/tntd-form/TntdForm/index.js.map +1 -0
  31. package/es/tntd-form/TntdForm/interface.js +1 -0
  32. package/es/tntd-form/TntdForm/interface.js.map +1 -0
  33. package/es/tntd-form/TntdForm/store.js +2 -0
  34. package/es/tntd-form/TntdForm/store.js.map +1 -0
  35. package/es/tntd-form/TntdForm/utils.js +219 -0
  36. package/es/tntd-form/TntdForm/utils.js.map +1 -0
  37. package/es/tntd-rc-select/_util/DisabledContext.js +8 -0
  38. package/es/tntd-rc-select/_util/DisabledContext.js.map +1 -0
  39. package/es/tntd-rc-select/_util/FormItemInputContext.js +3 -0
  40. package/es/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
  41. package/es/tntd-rc-select/_util/PurePanel.js +55 -0
  42. package/es/tntd-rc-select/_util/PurePanel.js.map +1 -0
  43. package/es/tntd-rc-select/_util/SizeContext.js +3 -0
  44. package/es/tntd-rc-select/_util/SizeContext.js.map +1 -0
  45. package/es/tntd-rc-select/_util/context.js +14 -0
  46. package/es/tntd-rc-select/_util/context.js.map +1 -0
  47. package/es/tntd-rc-select/_util/defaultRenderEmpty.js +20 -0
  48. package/es/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
  49. package/es/tntd-rc-select/_util/getIcons.js +52 -0
  50. package/es/tntd-rc-select/_util/getIcons.js.map +1 -0
  51. package/es/tntd-rc-select/_util/interface.js +5 -0
  52. package/es/tntd-rc-select/_util/interface.js.map +1 -0
  53. package/es/tntd-rc-select/_util/motion.js +38 -0
  54. package/es/tntd-rc-select/_util/motion.js.map +1 -0
  55. package/es/tntd-rc-select/_util/type.js +4 -0
  56. package/es/tntd-rc-select/_util/type.js.map +1 -0
  57. package/es/tntd-rc-select/_util/useCompactItemContext.js +24 -0
  58. package/es/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
  59. package/es/tntd-rc-select/_util/warning.js +15 -0
  60. package/es/tntd-rc-select/_util/warning.js.map +1 -0
  61. package/es/tntd-rc-select/img/no-data-s.png +0 -0
  62. package/es/tntd-rc-select/index.js +103 -0
  63. package/es/tntd-rc-select/index.js.map +1 -0
  64. package/es/tntd-rc-select/style/index.less +1657 -0
  65. package/es/tntd-select/_util/DisabledContext.js +8 -0
  66. package/es/tntd-select/_util/DisabledContext.js.map +1 -0
  67. package/es/tntd-select/_util/FormItemInputContext.js +3 -0
  68. package/es/tntd-select/_util/FormItemInputContext.js.map +1 -0
  69. package/es/tntd-select/_util/PurePanel.js +55 -0
  70. package/es/tntd-select/_util/PurePanel.js.map +1 -0
  71. package/es/tntd-select/_util/SizeContext.js +3 -0
  72. package/es/tntd-select/_util/SizeContext.js.map +1 -0
  73. package/es/tntd-select/_util/context.js +14 -0
  74. package/es/tntd-select/_util/context.js.map +1 -0
  75. package/es/tntd-select/_util/defaultRenderEmpty.js +20 -0
  76. package/es/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
  77. package/es/tntd-select/_util/getIcons.js +52 -0
  78. package/es/tntd-select/_util/getIcons.js.map +1 -0
  79. package/es/tntd-select/_util/interface.js +5 -0
  80. package/es/tntd-select/_util/interface.js.map +1 -0
  81. package/es/tntd-select/_util/motion.js +38 -0
  82. package/es/tntd-select/_util/motion.js.map +1 -0
  83. package/es/tntd-select/_util/type.js +4 -0
  84. package/es/tntd-select/_util/type.js.map +1 -0
  85. package/es/tntd-select/_util/useCompactItemContext.js +24 -0
  86. package/es/tntd-select/_util/useCompactItemContext.js.map +1 -0
  87. package/es/tntd-select/_util/warning.js +15 -0
  88. package/es/tntd-select/_util/warning.js.map +1 -0
  89. package/es/tntd-select/index.js +7 -1
  90. package/es/tntd-select/index.js.map +1 -1
  91. package/es/tntd-select/rc-select/BaseSelect.js +429 -0
  92. package/es/tntd-select/rc-select/BaseSelect.js.map +1 -0
  93. package/es/tntd-select/rc-select/OptGroup.js +5 -0
  94. package/es/tntd-select/rc-select/OptGroup.js.map +1 -0
  95. package/es/tntd-select/rc-select/Option.js +5 -0
  96. package/es/tntd-select/rc-select/Option.js.map +1 -0
  97. package/es/tntd-select/rc-select/OptionList.js +257 -0
  98. package/es/tntd-select/rc-select/OptionList.js.map +1 -0
  99. package/es/tntd-select/rc-select/Select.js +428 -0
  100. package/es/tntd-select/rc-select/Select.js.map +1 -0
  101. package/es/tntd-select/rc-select/SelectContext.js +4 -0
  102. package/es/tntd-select/rc-select/SelectContext.js.map +1 -0
  103. package/es/tntd-select/rc-select/SelectTrigger.js +91 -0
  104. package/es/tntd-select/rc-select/SelectTrigger.js.map +1 -0
  105. package/es/tntd-select/rc-select/Selector/Input.js +47 -0
  106. package/es/tntd-select/rc-select/Selector/Input.js.map +1 -0
  107. package/es/tntd-select/rc-select/Selector/MultipleSelector.js +97 -0
  108. package/es/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
  109. package/es/tntd-select/rc-select/Selector/SingleSelector.js +45 -0
  110. package/es/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
  111. package/es/tntd-select/rc-select/Selector/index.js +136 -0
  112. package/es/tntd-select/rc-select/Selector/index.js.map +1 -0
  113. package/es/tntd-select/rc-select/TransBtn.js +22 -0
  114. package/es/tntd-select/rc-select/TransBtn.js.map +1 -0
  115. package/es/tntd-select/rc-select/hooks/useAllowClear.js +25 -0
  116. package/es/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
  117. package/es/tntd-select/rc-select/hooks/useBaseProps.js +10 -0
  118. package/es/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
  119. package/es/tntd-select/rc-select/hooks/useCache.js +34 -0
  120. package/es/tntd-select/rc-select/hooks/useCache.js.map +1 -0
  121. package/es/tntd-select/rc-select/hooks/useDelayReset.js +24 -0
  122. package/es/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
  123. package/es/tntd-select/rc-select/hooks/useFilterOptions.js +55 -0
  124. package/es/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
  125. package/es/tntd-select/rc-select/hooks/useId.js +28 -0
  126. package/es/tntd-select/rc-select/hooks/useId.js.map +1 -0
  127. package/es/tntd-select/rc-select/hooks/useLayoutEffect.js +18 -0
  128. package/es/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
  129. package/es/tntd-select/rc-select/hooks/useLock.js +26 -0
  130. package/es/tntd-select/rc-select/hooks/useLock.js.map +1 -0
  131. package/es/tntd-select/rc-select/hooks/useOptions.js +45 -0
  132. package/es/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
  133. package/es/tntd-select/rc-select/hooks/useRefFunc.js +14 -0
  134. package/es/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
  135. package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js +32 -0
  136. package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
  137. package/es/tntd-select/rc-select/index.js +8 -0
  138. package/es/tntd-select/rc-select/index.js.map +1 -0
  139. package/es/tntd-select/rc-select/interface.js +2 -0
  140. package/es/tntd-select/rc-select/interface.js.map +1 -0
  141. package/es/tntd-select/rc-select/utils/commonUtil.js +32 -0
  142. package/es/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
  143. package/es/tntd-select/rc-select/utils/keyUtil.js +34 -0
  144. package/es/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
  145. package/es/tntd-select/rc-select/utils/legacyUtil.js +32 -0
  146. package/es/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
  147. package/es/tntd-select/rc-select/utils/platformUtil.js +5 -0
  148. package/es/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
  149. package/es/tntd-select/rc-select/utils/valueUtil.js +99 -0
  150. package/es/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
  151. package/es/tntd-select/rc-select/utils/warningPropsUtil.js +100 -0
  152. package/es/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
  153. package/lib/_util/motion.d.ts +6 -0
  154. package/lib/_util/motion.d.ts.map +1 -0
  155. package/lib/_util/motion.js +20 -0
  156. package/lib/_util/motion.js.map +1 -0
  157. package/lib/_util/type.d.ts +4 -0
  158. package/lib/_util/type.d.ts.map +1 -0
  159. package/lib/_util/type.js +9 -0
  160. package/lib/_util/type.js.map +1 -0
  161. package/lib/_util/warning.d.ts +5 -0
  162. package/lib/_util/warning.d.ts.map +1 -0
  163. package/lib/_util/warning.js +32 -0
  164. package/lib/_util/warning.js.map +1 -0
  165. package/lib/button/button.d.ts.map +1 -1
  166. package/lib/button/button.js +8 -0
  167. package/lib/button/button.js.map +1 -1
  168. package/lib/handle/handle.d.ts +3 -0
  169. package/lib/handle/handle.d.ts.map +1 -0
  170. package/lib/handle/handle.js +130 -0
  171. package/lib/handle/handle.js.map +1 -0
  172. package/lib/index.d.ts +1 -0
  173. package/lib/index.d.ts.map +1 -1
  174. package/lib/index.js +3 -1
  175. package/lib/index.js.map +1 -1
  176. package/lib/locale/default.d.ts +4 -1
  177. package/lib/locale/default.d.ts.map +1 -1
  178. package/lib/locale/en_US.d.ts +4 -1
  179. package/lib/locale/en_US.d.ts.map +1 -1
  180. package/lib/locale/en_US.js +6 -3
  181. package/lib/locale/en_US.js.map +1 -1
  182. package/lib/locale/zh_CN.d.ts +4 -1
  183. package/lib/locale/zh_CN.d.ts.map +1 -1
  184. package/lib/locale/zh_CN.js +4 -1
  185. package/lib/locale/zh_CN.js.map +1 -1
  186. package/lib/mention/index.js +25 -0
  187. package/lib/prev-locale.js +1 -1
  188. package/lib/prev-locale.js.map +1 -1
  189. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
  190. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  191. package/lib/tntd-form/TntdForm/components/Item.js +65 -0
  192. package/lib/tntd-form/TntdForm/components/ItemComp.js +215 -0
  193. package/lib/tntd-form/TntdForm/components/List.js +123 -0
  194. package/lib/tntd-form/TntdForm/index.js +72 -0
  195. package/lib/tntd-form/TntdForm/interface.js +5 -0
  196. package/lib/tntd-form/TntdForm/store.js +10 -0
  197. package/lib/tntd-form/TntdForm/utils.js +239 -0
  198. package/lib/tntd-rc-select/_util/DisabledContext.d.ts +10 -0
  199. package/lib/tntd-rc-select/_util/DisabledContext.d.ts.map +1 -0
  200. package/lib/tntd-rc-select/_util/DisabledContext.js +35 -0
  201. package/lib/tntd-rc-select/_util/DisabledContext.js.map +1 -0
  202. package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts +4 -0
  203. package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts.map +1 -0
  204. package/lib/tntd-rc-select/_util/FormItemInputContext.js +29 -0
  205. package/lib/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
  206. package/lib/tntd-rc-select/_util/PurePanel.d.ts +9 -0
  207. package/lib/tntd-rc-select/_util/PurePanel.d.ts.map +1 -0
  208. package/lib/tntd-rc-select/_util/PurePanel.js +84 -0
  209. package/lib/tntd-rc-select/_util/PurePanel.js.map +1 -0
  210. package/lib/tntd-rc-select/_util/SizeContext.d.ts +4 -0
  211. package/lib/tntd-rc-select/_util/SizeContext.d.ts.map +1 -0
  212. package/lib/tntd-rc-select/_util/SizeContext.js +29 -0
  213. package/lib/tntd-rc-select/_util/SizeContext.js.map +1 -0
  214. package/lib/tntd-rc-select/_util/context.d.ts +42 -0
  215. package/lib/tntd-rc-select/_util/context.d.ts.map +1 -0
  216. package/lib/tntd-rc-select/_util/context.js +20 -0
  217. package/lib/tntd-rc-select/_util/context.js.map +1 -0
  218. package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts +5 -0
  219. package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts.map +1 -0
  220. package/lib/tntd-rc-select/_util/defaultRenderEmpty.js +48 -0
  221. package/lib/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
  222. package/lib/tntd-rc-select/_util/getIcons.d.ts +25 -0
  223. package/lib/tntd-rc-select/_util/getIcons.d.ts.map +1 -0
  224. package/lib/tntd-rc-select/_util/getIcons.js +78 -0
  225. package/lib/tntd-rc-select/_util/getIcons.js.map +1 -0
  226. package/lib/tntd-rc-select/_util/interface.d.ts +25 -0
  227. package/lib/tntd-rc-select/_util/interface.d.ts.map +1 -0
  228. package/lib/tntd-rc-select/_util/interface.js +9 -0
  229. package/lib/tntd-rc-select/_util/interface.js.map +1 -0
  230. package/lib/tntd-rc-select/_util/motion.d.ts +9 -0
  231. package/lib/tntd-rc-select/_util/motion.d.ts.map +1 -0
  232. package/lib/tntd-rc-select/_util/motion.js +42 -0
  233. package/lib/tntd-rc-select/_util/motion.js.map +1 -0
  234. package/lib/tntd-rc-select/_util/type.d.ts +10 -0
  235. package/lib/tntd-rc-select/_util/type.d.ts.map +1 -0
  236. package/lib/tntd-rc-select/_util/type.js +9 -0
  237. package/lib/tntd-rc-select/_util/type.js.map +1 -0
  238. package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts +9 -0
  239. package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts.map +1 -0
  240. package/lib/tntd-rc-select/_util/useCompactItemContext.js +54 -0
  241. package/lib/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
  242. package/lib/tntd-rc-select/_util/warning.d.ts +4 -0
  243. package/lib/tntd-rc-select/_util/warning.d.ts.map +1 -0
  244. package/lib/tntd-rc-select/_util/warning.js +40 -0
  245. package/lib/tntd-rc-select/_util/warning.js.map +1 -0
  246. package/lib/tntd-rc-select/img/no-data-s.png +0 -0
  247. package/lib/tntd-rc-select/index.d.ts +44 -0
  248. package/lib/tntd-rc-select/index.d.ts.map +1 -0
  249. package/lib/tntd-rc-select/index.js +131 -0
  250. package/lib/tntd-rc-select/index.js.map +1 -0
  251. package/lib/tntd-rc-select/style/index.less +1657 -0
  252. package/lib/tntd-select/_util/DisabledContext.d.ts +10 -0
  253. package/lib/tntd-select/_util/DisabledContext.d.ts.map +1 -0
  254. package/lib/tntd-select/_util/DisabledContext.js +35 -0
  255. package/lib/tntd-select/_util/DisabledContext.js.map +1 -0
  256. package/lib/tntd-select/_util/FormItemInputContext.d.ts +4 -0
  257. package/lib/tntd-select/_util/FormItemInputContext.d.ts.map +1 -0
  258. package/lib/tntd-select/_util/FormItemInputContext.js +29 -0
  259. package/lib/tntd-select/_util/FormItemInputContext.js.map +1 -0
  260. package/lib/tntd-select/_util/PurePanel.d.ts +9 -0
  261. package/lib/tntd-select/_util/PurePanel.d.ts.map +1 -0
  262. package/lib/tntd-select/_util/PurePanel.js +84 -0
  263. package/lib/tntd-select/_util/PurePanel.js.map +1 -0
  264. package/lib/tntd-select/_util/SizeContext.d.ts +4 -0
  265. package/lib/tntd-select/_util/SizeContext.d.ts.map +1 -0
  266. package/lib/tntd-select/_util/SizeContext.js +29 -0
  267. package/lib/tntd-select/_util/SizeContext.js.map +1 -0
  268. package/lib/tntd-select/_util/context.d.ts +42 -0
  269. package/lib/tntd-select/_util/context.d.ts.map +1 -0
  270. package/lib/tntd-select/_util/context.js +20 -0
  271. package/lib/tntd-select/_util/context.js.map +1 -0
  272. package/lib/tntd-select/_util/defaultRenderEmpty.d.ts +5 -0
  273. package/lib/tntd-select/_util/defaultRenderEmpty.d.ts.map +1 -0
  274. package/lib/tntd-select/_util/defaultRenderEmpty.js +48 -0
  275. package/lib/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
  276. package/lib/tntd-select/_util/getIcons.d.ts +25 -0
  277. package/lib/tntd-select/_util/getIcons.d.ts.map +1 -0
  278. package/lib/tntd-select/_util/getIcons.js +78 -0
  279. package/lib/tntd-select/_util/getIcons.js.map +1 -0
  280. package/lib/tntd-select/_util/interface.d.ts +25 -0
  281. package/lib/tntd-select/_util/interface.d.ts.map +1 -0
  282. package/lib/tntd-select/_util/interface.js +9 -0
  283. package/lib/tntd-select/_util/interface.js.map +1 -0
  284. package/lib/tntd-select/_util/motion.d.ts +9 -0
  285. package/lib/tntd-select/_util/motion.d.ts.map +1 -0
  286. package/lib/tntd-select/_util/motion.js +42 -0
  287. package/lib/tntd-select/_util/motion.js.map +1 -0
  288. package/lib/tntd-select/_util/type.d.ts +10 -0
  289. package/lib/tntd-select/_util/type.d.ts.map +1 -0
  290. package/lib/tntd-select/_util/type.js +9 -0
  291. package/lib/tntd-select/_util/type.js.map +1 -0
  292. package/lib/tntd-select/_util/useCompactItemContext.d.ts +9 -0
  293. package/lib/tntd-select/_util/useCompactItemContext.d.ts.map +1 -0
  294. package/lib/tntd-select/_util/useCompactItemContext.js +54 -0
  295. package/lib/tntd-select/_util/useCompactItemContext.js.map +1 -0
  296. package/lib/tntd-select/_util/warning.d.ts +4 -0
  297. package/lib/tntd-select/_util/warning.d.ts.map +1 -0
  298. package/lib/tntd-select/_util/warning.js +40 -0
  299. package/lib/tntd-select/_util/warning.js.map +1 -0
  300. package/lib/tntd-select/index.d.ts.map +1 -1
  301. package/lib/tntd-select/index.js +7 -1
  302. package/lib/tntd-select/index.js.map +1 -1
  303. package/lib/tntd-select/rc-select/BaseSelect.d.ts +114 -0
  304. package/lib/tntd-select/rc-select/BaseSelect.d.ts.map +1 -0
  305. package/lib/tntd-select/rc-select/BaseSelect.js +459 -0
  306. package/lib/tntd-select/rc-select/BaseSelect.js.map +1 -0
  307. package/lib/tntd-select/rc-select/OptGroup.d.ts +13 -0
  308. package/lib/tntd-select/rc-select/OptGroup.d.ts.map +1 -0
  309. package/lib/tntd-select/rc-select/OptGroup.js +7 -0
  310. package/lib/tntd-select/rc-select/OptGroup.js.map +1 -0
  311. package/lib/tntd-select/rc-select/Option.d.ts +15 -0
  312. package/lib/tntd-select/rc-select/Option.d.ts.map +1 -0
  313. package/lib/tntd-select/rc-select/Option.js +7 -0
  314. package/lib/tntd-select/rc-select/Option.js.map +1 -0
  315. package/lib/tntd-select/rc-select/OptionList.d.ts +11 -0
  316. package/lib/tntd-select/rc-select/OptionList.d.ts.map +1 -0
  317. package/lib/tntd-select/rc-select/OptionList.js +285 -0
  318. package/lib/tntd-select/rc-select/OptionList.js.map +1 -0
  319. package/lib/tntd-select/rc-select/Select.d.ts +115 -0
  320. package/lib/tntd-select/rc-select/Select.d.ts.map +1 -0
  321. package/lib/tntd-select/rc-select/Select.js +456 -0
  322. package/lib/tntd-select/rc-select/Select.js.map +1 -0
  323. package/lib/tntd-select/rc-select/SelectContext.d.ts +23 -0
  324. package/lib/tntd-select/rc-select/SelectContext.d.ts.map +1 -0
  325. package/lib/tntd-select/rc-select/SelectContext.js +29 -0
  326. package/lib/tntd-select/rc-select/SelectContext.js.map +1 -0
  327. package/lib/tntd-select/rc-select/SelectTrigger.d.ts +31 -0
  328. package/lib/tntd-select/rc-select/SelectTrigger.d.ts.map +1 -0
  329. package/lib/tntd-select/rc-select/SelectTrigger.js +119 -0
  330. package/lib/tntd-select/rc-select/SelectTrigger.js.map +1 -0
  331. package/lib/tntd-select/rc-select/Selector/Input.d.ts +27 -0
  332. package/lib/tntd-select/rc-select/Selector/Input.d.ts.map +1 -0
  333. package/lib/tntd-select/rc-select/Selector/Input.js +75 -0
  334. package/lib/tntd-select/rc-select/Selector/Input.js.map +1 -0
  335. package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts +17 -0
  336. package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts.map +1 -0
  337. package/lib/tntd-select/rc-select/Selector/MultipleSelector.js +125 -0
  338. package/lib/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
  339. package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts +9 -0
  340. package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts.map +1 -0
  341. package/lib/tntd-select/rc-select/Selector/SingleSelector.js +73 -0
  342. package/lib/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
  343. package/lib/tntd-select/rc-select/Selector/index.d.ts +83 -0
  344. package/lib/tntd-select/rc-select/Selector/index.d.ts.map +1 -0
  345. package/lib/tntd-select/rc-select/Selector/index.js +164 -0
  346. package/lib/tntd-select/rc-select/Selector/index.js.map +1 -0
  347. package/lib/tntd-select/rc-select/TransBtn.d.ts +13 -0
  348. package/lib/tntd-select/rc-select/TransBtn.d.ts.map +1 -0
  349. package/lib/tntd-select/rc-select/TransBtn.js +50 -0
  350. package/lib/tntd-select/rc-select/TransBtn.js.map +1 -0
  351. package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts +9 -0
  352. package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts.map +1 -0
  353. package/lib/tntd-select/rc-select/hooks/useAllowClear.js +32 -0
  354. package/lib/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
  355. package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts +14 -0
  356. package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts.map +1 -0
  357. package/lib/tntd-select/rc-select/hooks/useBaseProps.js +37 -0
  358. package/lib/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
  359. package/lib/tntd-select/rc-select/hooks/useCache.d.ts +8 -0
  360. package/lib/tntd-select/rc-select/hooks/useCache.d.ts.map +1 -0
  361. package/lib/tntd-select/rc-select/hooks/useCache.js +59 -0
  362. package/lib/tntd-select/rc-select/hooks/useCache.js.map +1 -0
  363. package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts +6 -0
  364. package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts.map +1 -0
  365. package/lib/tntd-select/rc-select/hooks/useDelayReset.js +50 -0
  366. package/lib/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
  367. package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts +4 -0
  368. package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts.map +1 -0
  369. package/lib/tntd-select/rc-select/hooks/useFilterOptions.js +80 -0
  370. package/lib/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
  371. package/lib/tntd-select/rc-select/hooks/useId.d.ts +6 -0
  372. package/lib/tntd-select/rc-select/hooks/useId.d.ts.map +1 -0
  373. package/lib/tntd-select/rc-select/hooks/useId.js +59 -0
  374. package/lib/tntd-select/rc-select/hooks/useId.js.map +1 -0
  375. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts +6 -0
  376. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts.map +1 -0
  377. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js +44 -0
  378. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
  379. package/lib/tntd-select/rc-select/hooks/useLock.d.ts +8 -0
  380. package/lib/tntd-select/rc-select/hooks/useLock.d.ts.map +1 -0
  381. package/lib/tntd-select/rc-select/hooks/useLock.js +52 -0
  382. package/lib/tntd-select/rc-select/hooks/useLock.js.map +1 -0
  383. package/lib/tntd-select/rc-select/hooks/useOptions.d.ts +12 -0
  384. package/lib/tntd-select/rc-select/hooks/useOptions.d.ts.map +1 -0
  385. package/lib/tntd-select/rc-select/hooks/useOptions.js +71 -0
  386. package/lib/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
  387. package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts +6 -0
  388. package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts.map +1 -0
  389. package/lib/tntd-select/rc-select/hooks/useRefFunc.js +40 -0
  390. package/lib/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
  391. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts +2 -0
  392. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts.map +1 -0
  393. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js +58 -0
  394. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
  395. package/lib/tntd-select/rc-select/index.d.ts +11 -0
  396. package/lib/tntd-select/rc-select/index.d.ts.map +1 -0
  397. package/lib/tntd-select/rc-select/index.js +17 -0
  398. package/lib/tntd-select/rc-select/index.js.map +1 -0
  399. package/lib/tntd-select/rc-select/interface.d.ts +23 -0
  400. package/lib/tntd-select/rc-select/interface.d.ts.map +1 -0
  401. package/lib/tntd-select/rc-select/interface.js +3 -0
  402. package/lib/tntd-select/rc-select/interface.js.map +1 -0
  403. package/lib/tntd-select/rc-select/utils/commonUtil.d.ts +10 -0
  404. package/lib/tntd-select/rc-select/utils/commonUtil.d.ts.map +1 -0
  405. package/lib/tntd-select/rc-select/utils/commonUtil.js +39 -0
  406. package/lib/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
  407. package/lib/tntd-select/rc-select/utils/keyUtil.d.ts +3 -0
  408. package/lib/tntd-select/rc-select/utils/keyUtil.d.ts.map +1 -0
  409. package/lib/tntd-select/rc-select/utils/keyUtil.js +41 -0
  410. package/lib/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
  411. package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts +4 -0
  412. package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts.map +1 -0
  413. package/lib/tntd-select/rc-select/utils/legacyUtil.js +62 -0
  414. package/lib/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
  415. package/lib/tntd-select/rc-select/utils/platformUtil.d.ts +2 -0
  416. package/lib/tntd-select/rc-select/utils/platformUtil.d.ts.map +1 -0
  417. package/lib/tntd-select/rc-select/utils/platformUtil.js +9 -0
  418. package/lib/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
  419. package/lib/tntd-select/rc-select/utils/valueUtil.d.ts +24 -0
  420. package/lib/tntd-select/rc-select/utils/valueUtil.d.ts.map +1 -0
  421. package/lib/tntd-select/rc-select/utils/valueUtil.js +109 -0
  422. package/lib/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
  423. package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts +5 -0
  424. package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts.map +1 -0
  425. package/lib/tntd-select/rc-select/utils/warningPropsUtil.js +130 -0
  426. package/lib/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
  427. package/package.json +1 -1
@@ -0,0 +1,186 @@
1
+ /*
2
+ * @Descripttion: TntdForm.Item进行性能优化
3
+ * @Author: 郑泳健
4
+ * @Date: 2023-02-23 12:47:28
5
+ * @LastEditors: 郑泳健
6
+ * @LastEditTime: 2023-04-06 17:45:35
7
+ */
8
+ import React, { useState, memo, useEffect, useImperativeHandle } from 'react';
9
+ import { getNames, handleCheckItem, getInitValue } from '../utils';
10
+ const ItemComp = React.forwardRef(({
11
+ name,
12
+ children,
13
+ style,
14
+ initialValue,
15
+ rules,
16
+ shouldUpdate,
17
+ dependencies,
18
+ form,
19
+ updateRefs,
20
+ initialValues,
21
+ compsRefs
22
+ }, ref) => {
23
+ const [value, setValue] = useState(undefined);
24
+ const [errorMsg, setErrorMsg] = useState(undefined);
25
+ const [refresh, setRefresh] = useState(false);
26
+ useImperativeHandle(ref, () => ({
27
+ onRefresh: () => {
28
+ setRefresh(!refresh);
29
+ }
30
+ }));
31
+ /** 根据shouldUpdate 和 dependencies收集修改某个字段后需要同步更新的字段 */
32
+ useEffect(() => {
33
+ var _a;
34
+ const nameStr = (_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.');
35
+ if (shouldUpdate) {
36
+ updateRefs.current.shouldUpdateList.push(nameStr);
37
+ }
38
+ if (Array.isArray(dependencies)) {
39
+ const arr = dependencies.map(i => getNames(i).join('.'));
40
+ if (Array.isArray(arr)) {
41
+ arr.forEach(i => {
42
+ if (Array.isArray(updateRefs.current.dependencies[i])) {
43
+ updateRefs.current.dependencies[i] = [...updateRefs.current.dependencies[i], getNames(name).join('.')];
44
+ } else {
45
+ updateRefs.current.dependencies[i] = [getNames(name).join('.')];
46
+ }
47
+ });
48
+ }
49
+ }
50
+ }, [shouldUpdate, dependencies, name, updateRefs]);
51
+ const updateRender = () => {
52
+ if (Array.isArray(updateRefs.current.shouldUpdateList)) {
53
+ updateRefs.current.shouldUpdateList.forEach(i => {
54
+ var _a, _b;
55
+ (_b = (_a = compsRefs === null || compsRefs === void 0 ? void 0 : compsRefs.current) === null || _a === void 0 ? void 0 : _a[i]) === null || _b === void 0 ? void 0 : _b.call(_a);
56
+ });
57
+ }
58
+ const list = updateRefs.current.dependencies[getNames(name).join('.')];
59
+ if (Array.isArray(list)) {
60
+ list.forEach(i => {
61
+ var _a, _b;
62
+ (_b = (_a = compsRefs === null || compsRefs === void 0 ? void 0 : compsRefs.current) === null || _a === void 0 ? void 0 : _a[i]) === null || _b === void 0 ? void 0 : _b.call(_a);
63
+ });
64
+ }
65
+ };
66
+ /**
67
+ * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的
68
+ * @param name
69
+ * @param value
70
+ * @returns
71
+ */
72
+ const generateFormData = (name, value) => {
73
+ if (!name || !form || typeof name !== 'object') return;
74
+ const [str, ...rest] = name;
75
+ rest.forEach(i => {
76
+ if (form.formData[str]) {
77
+ form.formData[str][i].value = value;
78
+ form.formData[str][i].checkItem = () => {
79
+ const error = handleCheckItem(value, rules);
80
+ setErrorMsg(error);
81
+ return error;
82
+ };
83
+ } else {
84
+ form.formData[str] = {
85
+ [i]: {
86
+ value,
87
+ checkItem: () => {
88
+ const error = handleCheckItem(value, rules);
89
+ setErrorMsg(error);
90
+ return error;
91
+ },
92
+ setItemValue: () => {},
93
+ errorMsg: undefined
94
+ }
95
+ };
96
+ }
97
+ });
98
+ };
99
+ // 为了给最外层提供方法去校验,比如保存的时候.
100
+ // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的
101
+ useEffect(() => {
102
+ if (!name || !form || typeof name !== 'object') return;
103
+ const [str, ...rest] = name;
104
+ const addItem = {
105
+ setItemValue: (_val, callback) => {
106
+ const error = handleCheckItem(_val, rules);
107
+ setValue(_val);
108
+ setErrorMsg(error);
109
+ callback === null || callback === void 0 ? void 0 : callback();
110
+ updateRender();
111
+ },
112
+ checkItem: () => {
113
+ const error = handleCheckItem(value, rules);
114
+ setErrorMsg(error);
115
+ return error;
116
+ },
117
+ value,
118
+ errorMsg
119
+ };
120
+ rest.forEach(i => {
121
+ if (form.formData[str]) {
122
+ form.formData[str][i] = addItem;
123
+ } else {
124
+ form.formData[str] = {
125
+ [i]: addItem
126
+ };
127
+ }
128
+ });
129
+ }, [rules, name, errorMsg, form]);
130
+ /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */
131
+ useEffect(() => {
132
+ if (initialValue) {
133
+ setValue(initialValue);
134
+ generateFormData(name, initialValue);
135
+ updateRender();
136
+ }
137
+ }, [initialValue]);
138
+ // 初始化设置默认值,
139
+ useEffect(() => {
140
+ const initValue = getInitValue(initialValues, name);
141
+ // @ts-ignore
142
+ const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue;
143
+ setValue(_value);
144
+ generateFormData(name, _value);
145
+ updateRender();
146
+ }, []);
147
+ // 默认方法
148
+ const handleChange = e => {
149
+ var _a;
150
+ let val;
151
+ if (typeof e === 'object') {
152
+ val = (_a = e === null || e === void 0 ? void 0 : e.target) === null || _a === void 0 ? void 0 : _a.value;
153
+ } else {
154
+ val = e;
155
+ }
156
+ setValue(val);
157
+ generateFormData(name, val);
158
+ const error = handleCheckItem(val, rules);
159
+ setErrorMsg(error);
160
+ updateRender();
161
+ };
162
+ return React.createElement("div", {
163
+ className: errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper',
164
+ style: style
165
+ }, React.Children.map(children, child => {
166
+ var _a;
167
+ if (React.isValidElement(child)) {
168
+ return React.cloneElement(child, Object.assign({
169
+ value,
170
+ form,
171
+ onChange: handleChange,
172
+ 'data-key': (_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.')
173
+ }, child.props));
174
+ }
175
+ return null;
176
+ }), errorMsg && React.createElement("div", {
177
+ className: "ant-form-explain ant-form-item-explain-error"
178
+ }, errorMsg));
179
+ });
180
+ function arePropsEqual(prevProps, nextProps) {
181
+ if (!nextProps.shouldUpdate && Array.isArray(nextProps.dependencies)) {
182
+ return true;
183
+ }
184
+ return false;
185
+ }
186
+ export default memo(ItemComp);
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ItemComp.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/ItemComp.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: TntdForm.Item进行性能优化\n * @Author: 郑泳健\n * @Date: 2023-02-23 12:47:28\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 17:45:35\n */\n\nimport React, { useState, memo, useEffect, useImperativeHandle } from 'react'\nimport { getNames, handleCheckItem, getInitValue } from '../utils'\nimport type { IFormItem, IFormItemData, TinitialValueType, IChildrenCompFun } from '../interface'\n\nconst ItemComp: React.FC<IFormItem> = React.forwardRef<IChildrenCompFun, IFormItem>(\n (\n {\n name,\n children,\n style,\n initialValue,\n rules,\n shouldUpdate,\n dependencies,\n form,\n updateRefs,\n initialValues,\n compsRefs,\n },\n ref\n ) => {\n const [value, setValue] = useState<TinitialValueType>(undefined)\n const [errorMsg, setErrorMsg] = useState<string | undefined>(undefined)\n const [refresh, setRefresh] = useState<boolean>(false)\n\n useImperativeHandle(ref, () => ({\n onRefresh: () => {\n setRefresh(!refresh)\n },\n }))\n\n /** 根据shouldUpdate 和 dependencies收集修改某个字段后需要同步更新的字段 */\n useEffect(() => {\n const nameStr = getNames(name)?.join('.')\n if (shouldUpdate) {\n updateRefs.current.shouldUpdateList.push(nameStr)\n }\n\n if (Array.isArray(dependencies)) {\n const arr = dependencies.map((i) => getNames(i).join('.'))\n if (Array.isArray(arr)) {\n arr.forEach((i) => {\n if (Array.isArray(updateRefs.current.dependencies[i])) {\n updateRefs.current.dependencies[i] = [\n ...updateRefs.current.dependencies[i],\n getNames(name).join('.'),\n ]\n } else {\n updateRefs.current.dependencies[i] = [getNames(name).join('.')]\n }\n })\n }\n }\n }, [shouldUpdate, dependencies, name, updateRefs])\n\n const updateRender = () => {\n if (Array.isArray(updateRefs.current.shouldUpdateList)) {\n updateRefs.current.shouldUpdateList.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n const list = updateRefs.current.dependencies[getNames(name).join('.')]\n\n if (Array.isArray(list)) {\n list.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n }\n\n /**\n * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的\n * @param name\n * @param value\n * @returns\n */\n const generateFormData = (name: string[] | string, value: TinitialValueType) => {\n if (!name || !form || typeof name !== 'object') return\n const [str, ...rest] = name\n\n rest.forEach((i) => {\n if (form.formData[str]) {\n form.formData[str][i].value = value\n form.formData[str][i].checkItem = () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n }\n } else {\n form.formData[str] = {\n [i]: {\n value,\n checkItem: () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n },\n setItemValue: () => {},\n errorMsg: undefined,\n },\n }\n }\n })\n }\n\n // 为了给最外层提供方法去校验,比如保存的时候.\n // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的\n useEffect(() => {\n if (!name || !form || typeof name !== 'object') return\n const [str, ...rest] = name\n\n const addItem: IFormItemData = {\n setItemValue: (_val, callback) => {\n const error = handleCheckItem(_val, rules)\n setValue(_val)\n setErrorMsg(error)\n callback?.()\n updateRender()\n },\n checkItem: () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n },\n value,\n errorMsg,\n }\n rest.forEach((i) => {\n if (form.formData[str]) {\n form.formData[str][i] = addItem\n } else {\n form.formData[str] = {\n [i]: addItem,\n }\n }\n })\n }, [rules, name, errorMsg, form])\n\n /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */\n useEffect(() => {\n if (initialValue) {\n setValue(initialValue)\n generateFormData(name, initialValue)\n updateRender()\n }\n }, [initialValue])\n\n // 初始化设置默认值,\n useEffect(() => {\n const initValue = getInitValue(initialValues, name)\n // @ts-ignore\n const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue\n\n setValue(_value)\n generateFormData(name, _value)\n updateRender()\n }, [])\n\n // 默认方法\n const handleChange = (\n e:\n | React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement>\n | string\n | number\n | undefined\n ) => {\n let val\n if (typeof e === 'object') {\n val = (e as React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement>)\n ?.target?.value\n } else {\n val = e\n }\n setValue(val)\n generateFormData(name, val)\n const error = handleCheckItem(val, rules)\n setErrorMsg(error)\n updateRender()\n }\n\n return (\n <div\n className={errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper'}\n style={style}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n form,\n onChange: handleChange,\n 'data-key': getNames(name)?.join('.'),\n ...child.props,\n })\n }\n return null\n })}\n {errorMsg && <div className=\"ant-form-explain ant-form-item-explain-error\">{errorMsg}</div>}\n </div>\n )\n }\n)\n\nfunction arePropsEqual(prevProps: IFormItem, nextProps: IFormItem) {\n if (!nextProps.shouldUpdate && Array.isArray(nextProps.dependencies)) {\n return true\n }\n\n return false\n}\n\nexport default memo(ItemComp)\n"]}
@@ -0,0 +1,102 @@
1
+ import _isEqual from "lodash/isEqual";
2
+ import _cloneDeep from "lodash/cloneDeep";
3
+ /*
4
+ * @Descripttion: FormList
5
+ * @Author: 郑泳健
6
+ * @Date: 2023-03-06 18:42:08
7
+ * @LastEditors: 郑泳健
8
+ * @LastEditTime: 2023-04-06 17:42:31
9
+ */
10
+ import React, { useState, useEffect, useRef, useContext, memo } from 'react';
11
+ import { getNames } from '../utils';
12
+ import { FormContext } from '../store';
13
+ const List = ({
14
+ name,
15
+ children
16
+ }) => {
17
+ const maxRef = useRef(-1);
18
+ const {
19
+ form,
20
+ initialValues,
21
+ compsRefs,
22
+ updateRefs
23
+ } = useContext(FormContext);
24
+ const [dataLevel, setDataLevel] = useState([]);
25
+ /** 根据一开始记录的渲染shouldUpdate 和 dependencies组件 */
26
+ const updateRender = () => {
27
+ if (Array.isArray(updateRefs.current.shouldUpdateList)) {
28
+ updateRefs.current.shouldUpdateList.forEach(i => {
29
+ var _a, _b;
30
+ (_b = (_a = compsRefs === null || compsRefs === void 0 ? void 0 : compsRefs.current) === null || _a === void 0 ? void 0 : _a[i]) === null || _b === void 0 ? void 0 : _b.call(_a);
31
+ });
32
+ }
33
+ const list = updateRefs.current.dependencies[getNames(name).join('.')];
34
+ if (Array.isArray(list)) {
35
+ list.forEach(i => {
36
+ var _a, _b;
37
+ (_b = (_a = compsRefs === null || compsRefs === void 0 ? void 0 : compsRefs.current) === null || _a === void 0 ? void 0 : _a[i]) === null || _b === void 0 ? void 0 : _b.call(_a);
38
+ });
39
+ }
40
+ };
41
+ /** 根据默认数值自动生成dataLevel */
42
+ useEffect(() => {
43
+ let dataSource = initialValues;
44
+ const attrs = getNames(name);
45
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
46
+ for (const key of attrs) {
47
+ dataSource = (dataSource === null || dataSource === void 0 ? void 0 : dataSource[key]) || [{}];
48
+ }
49
+ if (Array.isArray(dataSource)) {
50
+ const _level = dataSource.map((i, index) => {
51
+ return {
52
+ key: index,
53
+ name: `${attrs.join('.')}.${index}`
54
+ };
55
+ });
56
+ setDataLevel(_level);
57
+ maxRef.current = dataSource.length - 1;
58
+ if (form) {
59
+ form.dataLevel[key] = _level;
60
+ }
61
+ updateRender();
62
+ }
63
+ }, [form, initialValues, name]);
64
+ /** 新增一列 */
65
+ const handleAdd = index => {
66
+ const tempDataLevel = _cloneDeep(dataLevel);
67
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
68
+ maxRef.current++;
69
+ const attrs = getNames(name);
70
+ tempDataLevel.splice(index + 1, 0, {
71
+ key: maxRef.current,
72
+ name: `${attrs === null || attrs === void 0 ? void 0 : attrs.join('.')}.${maxRef.current}`
73
+ });
74
+ setDataLevel(tempDataLevel);
75
+ if (form) {
76
+ form.dataLevel[key] = tempDataLevel;
77
+ }
78
+ updateRender();
79
+ };
80
+ /** 删除一列 */
81
+ const handleDel = index => {
82
+ const temp = _cloneDeep(dataLevel);
83
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
84
+ temp.splice(index, 1);
85
+ setDataLevel(temp);
86
+ if (form) {
87
+ form.dataLevel[key] = temp;
88
+ }
89
+ updateRender();
90
+ };
91
+ return React.createElement(React.Fragment, null, children === null || children === void 0 ? void 0 : children(dataLevel, {
92
+ add: handleAdd,
93
+ remove: handleDel
94
+ }));
95
+ };
96
+ // name 没有改变就不需要重复render
97
+ export default memo(List, (nextProps, prevProps) => {
98
+ if (_isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {
99
+ return true;
100
+ }
101
+ return false;
102
+ });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"List.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/List.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: FormList\n * @Author: 郑泳健\n * @Date: 2023-03-06 18:42:08\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 17:42:31\n */\n\nimport React, { useState, useEffect, useRef, useContext, memo } from 'react'\nimport { cloneDeep, isEqual } from 'lodash'\nimport { getNames } from '../utils'\nimport { FormContext } from '../store'\nimport type { IFormListProps, IFormContext, ILevel, TAddOrRemove, IObject } from '../interface'\n\nconst List: React.FC<IFormListProps> = ({ name, children }) => {\n const maxRef = useRef(-1)\n const { form, initialValues, compsRefs, updateRefs } = useContext<IFormContext>(FormContext)\n const [dataLevel, setDataLevel] = useState<ILevel[]>([])\n\n /** 根据一开始记录的渲染shouldUpdate 和 dependencies组件 */\n const updateRender = () => {\n if (Array.isArray(updateRefs.current.shouldUpdateList)) {\n updateRefs.current.shouldUpdateList.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n\n const list = updateRefs.current.dependencies[getNames(name).join('.')]\n\n if (Array.isArray(list)) {\n list.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n }\n\n /** 根据默认数值自动生成dataLevel */\n useEffect(() => {\n let dataSource = initialValues\n const attrs = getNames(name)\n const key: string = Array.isArray(name) ? name?.[0] : name\n\n for (const key of attrs) {\n dataSource = dataSource?.[key] || [{}]\n }\n\n if (Array.isArray(dataSource)) {\n const _level = dataSource.map((i, index) => {\n return {\n key: index,\n name: `${attrs.join('.')}.${index}`,\n }\n })\n setDataLevel(_level)\n maxRef.current = dataSource.length - 1\n if (form) {\n form.dataLevel[key] = _level\n }\n updateRender()\n }\n }, [form, initialValues, name])\n\n /** 新增一列 */\n const handleAdd: TAddOrRemove = (index) => {\n const tempDataLevel = cloneDeep(dataLevel)\n const key: string = Array.isArray(name) ? name?.[0] : name\n maxRef.current++\n const attrs = getNames(name)\n tempDataLevel.splice(index + 1, 0, {\n key: maxRef.current,\n name: `${attrs?.join('.')}.${maxRef.current}`,\n })\n setDataLevel(tempDataLevel)\n if (form) {\n form.dataLevel[key] = tempDataLevel\n }\n updateRender()\n }\n\n /** 删除一列 */\n const handleDel: TAddOrRemove = (index) => {\n const temp = cloneDeep(dataLevel)\n const key: string = Array.isArray(name) ? name?.[0] : name\n temp.splice(index, 1)\n setDataLevel(temp)\n if (form) {\n form.dataLevel[key] = temp\n }\n updateRender()\n }\n\n return <>{children?.(dataLevel, { add: handleAdd, remove: handleDel })}</>\n}\n\n// name 没有改变就不需要重复render\nexport default memo(List, (nextProps, prevProps) => {\n if (isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {\n return true\n }\n return false\n})\n"]}
@@ -0,0 +1,55 @@
1
+ /*
2
+ * @Descripttion: 高性能动态增删form表单
3
+ * @Author: 郑泳健
4
+ * @Date: 2023-02-16 10:43:03
5
+ * @LastEditors: 郑泳健
6
+ * @LastEditTime: 2023-04-06 15:32:07
7
+ */
8
+ import React, { useRef } from 'react';
9
+ import { validateFields, getFieldsValue, getFieldValue } from './utils';
10
+ import { FormContext } from './store';
11
+ import List from './components/List';
12
+ import Item from './components/Item';
13
+ const TntdForm = ({
14
+ form,
15
+ initialValues,
16
+ children
17
+ }) => {
18
+ const updateRefs = useRef({
19
+ shouldUpdateList: [],
20
+ dependencies: {}
21
+ });
22
+ const compsRefs = useRef({});
23
+ return React.createElement(FormContext.Provider, {
24
+ value: {
25
+ form,
26
+ initialValues,
27
+ updateRefs,
28
+ compsRefs
29
+ }
30
+ }, children);
31
+ };
32
+ TntdForm.useForm = () => {
33
+ const form = useRef({
34
+ dataLevel: {},
35
+ formData: {},
36
+ validateFields: () => validateFields(form.current),
37
+ getFieldsValue: () => getFieldsValue(form.current),
38
+ getFieldValue: field => getFieldValue(form.current, field),
39
+ setFieldsValue: obj => {
40
+ for (const i in obj) {
41
+ if (Object.prototype.hasOwnProperty.call(obj, i)) {
42
+ const prefix = (i === null || i === void 0 ? void 0 : i.split('.')) || [];
43
+ const attr = prefix.pop();
44
+ if (attr && form.current.formData[prefix.join('.')][attr]) {
45
+ form.current.formData[prefix.join('.')][attr].setItemValue(obj[i]);
46
+ }
47
+ }
48
+ }
49
+ }
50
+ });
51
+ return [form.current];
52
+ };
53
+ TntdForm.List = List;
54
+ TntdForm.Item = Item;
55
+ export default TntdForm;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/index.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,OAAO,KAAK,EAAE,EAAY,MAAM,EAAE,MAAM,OAAO,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAErC,OAAO,IAAI,MAAM,mBAAmB,CAAA;AACpC,OAAO,IAAI,MAAM,mBAAmB,CAAA;AAEpC,MAAM,QAAQ,GAAG,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAkB,EAAE,EAAE;IACrE,MAAM,UAAU,GAAG,MAAM,CAAa;QACpC,gBAAgB,EAAE,EAAE;QACpB,YAAY,EAAE,EAAE;KACjB,CAAC,CAAA;IAEF,MAAM,SAAS,GAAG,MAAM,CAAC,EAAE,CAAC,CAAA;IAE5B,OAAO,CACL,oBAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,IAAI;YACJ,aAAa;YACb,UAAU;YACV,SAAS;SACV,IAEA,QAAQ,CACY,CACxB,CAAA;AACH,CAAC,CAAA;AAED,QAAQ,CAAC,OAAO,GAAG,GAAG,EAAE;IACtB,MAAM,IAAI,GAAuB,MAAM,CAAQ;QAC7C,SAAS,EAAE,EAAE;QACb,QAAQ,EAAE,EAAE;QACZ,cAAc,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC;QAClD,cAAc,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC;QAClD,aAAa,EAAE,CAAC,KAAoB,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;QAC3E,cAAc,EAAE,CAAC,GAA+B,EAAE,EAAE;YAClD,KAAK,MAAM,CAAC,IAAI,GAAG,EAAE;gBACnB,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE;oBAChD,MAAM,MAAM,GAAG,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,KAAK,CAAC,GAAG,CAAC,KAAI,EAAE,CAAA;oBAClC,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,EAAE,CAAA;oBACzB,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;wBACzD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;qBACnE;iBACF;aACF;QACH,CAAC;KACF,CAAC,CAAA;IAEF,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;AACvB,CAAC,CAAA;AAED,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAA;AACpB,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAA;AAEpB,eAAe,QAAQ,CAAA","sourcesContent":["/*\n * @Descripttion: 高性能动态增删form表单\n * @Author: 郑泳健\n * @Date: 2023-02-16 10:43:03\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 15:32:07\n */\nimport React, { useState, useRef } from 'react'\nimport { validateFields, getFieldsValue, getFieldValue } from './utils'\nimport { FormContext } from './store'\nimport type { IForm, ITntdFormProps, IObject, TinitialValueType, IUpdateObj } from './interface'\nimport List from './components/List'\nimport Item from './components/Item'\n\nconst TntdForm = ({ form, initialValues, children }: ITntdFormProps) => {\n const updateRefs = useRef<IUpdateObj>({\n shouldUpdateList: [],\n dependencies: {},\n })\n\n const compsRefs = useRef({})\n\n return (\n <FormContext.Provider\n value={{\n form,\n initialValues,\n updateRefs,\n compsRefs,\n }}\n >\n {children}\n </FormContext.Provider>\n )\n}\n\nTntdForm.useForm = () => {\n const form: { current: IForm } = useRef<IForm>({\n dataLevel: {},\n formData: {},\n validateFields: () => validateFields(form.current),\n getFieldsValue: () => getFieldsValue(form.current),\n getFieldValue: (field: Array<string>) => getFieldValue(form.current, field),\n setFieldsValue: (obj: IObject<TinitialValueType>) => {\n for (const i in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, i)) {\n const prefix = i?.split('.') || []\n const attr = prefix.pop()\n if (attr && form.current.formData[prefix.join('.')][attr]) {\n form.current.formData[prefix.join('.')][attr].setItemValue(obj[i])\n }\n }\n }\n },\n })\n\n return [form.current]\n}\n\nTntdForm.List = List\nTntdForm.Item = Item\n\nexport default TntdForm\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/interface.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * 层级\n */\nexport interface ILevel {\n key?: number\n name?: string\n}\n\nexport interface IObject<T> {\n [key: string]: T\n}\n\nexport type TinitialValueType = null | undefined | string | number | boolean\n\n/**\n * 每一个单元格的信息\n */\nexport interface IFormItemData {\n /** 每个formItem的值 */\n value: TinitialValueType\n /** 每个formItem的错误信息 */\n errorMsg: string | undefined\n /** 每个formItem的校验方法, 返回值为该formItem的错误信息,同时会在formItem下面显示错误信息 */\n checkItem: () => string | undefined\n /** 给某个formItem设置值 */\n setItemValue: (value: TinitialValueType, callback?: () => void) => void\n}\n\nexport interface IForm {\n /** 记录每一层级的顺序 */\n dataLevel: IObject<ILevel[]>\n /** 整个form的数据,{content.0: { id: IFormItemData, value: IFormItemData }} */\n formData: IFormData\n /** 先校验,并将结果返回 */\n validateFields: () => Promise<any>\n /** 获取form表单的数据 */\n getFieldsValue: () => object\n /** 获取formItem的数据 */\n getFieldValue: (field: Array<string>) => any\n /** 给某些formItem设置数据 */\n setFieldsValue: (fileds: IObject<TinitialValueType>) => void\n}\n\n/**\n * TntdForm的props\n */\nexport interface ITntdFormProps {\n form: IForm\n initialValues: object\n children: React.ReactNode\n}\n\nexport interface IUpdateObj {\n shouldUpdateList: Array<string>\n dependencies: IObject<string[] | string>\n}\n\nexport interface IFormContext {\n form?: IForm\n initialValues?: IObject<any>\n updateRefs: React.MutableRefObject<IUpdateObj>\n compsRefs: React.MutableRefObject<IObject<() => void>>\n}\n\n/** formList的props */\nexport interface IFormListProps {\n name: string[] | string\n children: (\n dataLevel: ILevel[],\n { add, remove }: { add: TAddOrRemove; remove: TAddOrRemove }\n ) => void\n}\n\n/** 增删事件 */\nexport type TAddOrRemove = (index: number) => void\n\nexport type IFormItem = {\n name: string[] | string\n children: React.ReactChild | React.ReactChild[]\n style: React.CSSProperties\n rules: ValidationRule\n shouldUpdate: boolean\n initialValue: TinitialValueType\n dependencies?: Array<string[] | string>\n} & IFormContext\n\n/** 将某个不可选属性变成必选 */\ntype CustomRequired<T, K extends keyof T> = {\n [P in K]-?: T[P]\n} & Omit<T, K>\n\nexport interface ValidationRule {\n /** validation error message */\n message?: React.ReactNode\n /** indicates whether field is required */\n required?: boolean\n /** custom validate function (Note: callback must be called) */\n validator?: (rule: any, value: any, callback: any) => any\n}\n\nexport interface IFormData {\n [name: string]: {\n [attr: string]: IFormItemData\n }\n}\n\nexport interface IChildrenCompFun {\n onRefresh: () => void\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import React from 'react';
2
+ export const FormContext = React.createContext({});
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAe,EAAkB,CAAC,CAAA","sourcesContent":["import React from 'react'\nimport type { IFormContext } from './interface'\n\nexport const FormContext = React.createContext<IFormContext>({} as IFormContext)\n"]}
@@ -0,0 +1,219 @@
1
+ export const isValidKey = (key, object) => {
2
+ return key in object;
3
+ };
4
+ /**
5
+ * 将xx.xx.xx 转换为数组
6
+ * @param {*} name
7
+ * @returns
8
+ */
9
+ export const getNames = name => {
10
+ let attrs = [];
11
+ if (Array.isArray(name)) {
12
+ const [str, ...rest] = name;
13
+ attrs = str.split('.').concat(rest);
14
+ } else {
15
+ attrs = typeof name === 'string' ? name.split('.') : [];
16
+ }
17
+ return attrs;
18
+ };
19
+ /**
20
+ * 对数据进行校验
21
+ * @param {*} list
22
+ * @param {*} dataLevel
23
+ * @param {*} formData
24
+ * @returns
25
+ */
26
+ export const recursionCheck = (list, dataLevel, formData, errorList = []) => {
27
+ try {
28
+ if (Array.isArray(list)) {
29
+ list.forEach(item => {
30
+ const key = item.name;
31
+ const attrs = Object.keys(formData[key]);
32
+ attrs.forEach(attr => {
33
+ var _a;
34
+ const error = (_a = formData[item.name][attr]) === null || _a === void 0 ? void 0 : _a.checkItem();
35
+ if (error) {
36
+ errorList.push(`${[item.name + '.' + attr]}:`, error);
37
+ }
38
+ });
39
+ if (dataLevel[key]) {
40
+ recursionCheck(dataLevel[key], dataLevel, formData, errorList);
41
+ }
42
+ });
43
+ }
44
+ return errorList;
45
+ } catch (e) {
46
+ if (typeof e === 'string') {
47
+ throw e.toUpperCase();
48
+ } else if (e instanceof Error) {
49
+ throw e.message;
50
+ }
51
+ throw e;
52
+ }
53
+ };
54
+ /**
55
+ * 将数据进行排序
56
+ * @param {*} list
57
+ * @param {*} dataLevel
58
+ * @param {*} formData
59
+ * @param {*} errorList
60
+ * @returns
61
+ */
62
+ export const recursionSort = (list, dataLevel, formData) => {
63
+ try {
64
+ if (Array.isArray(list)) {
65
+ const values = list.reduce((total, item, index) => {
66
+ const attrObj = {};
67
+ const key = item.name;
68
+ const prefixs = key.split('.');
69
+ const attrs = formData[key] ? Object.keys(formData[key]) : [];
70
+ attrs.forEach(attr => {
71
+ var _a;
72
+ attrObj[attr] = (_a = formData[key][attr]) === null || _a === void 0 ? void 0 : _a.value;
73
+ });
74
+ let children = [];
75
+ if (dataLevel[key]) {
76
+ children = recursionSort(dataLevel[key], dataLevel, formData);
77
+ }
78
+ const len = prefixs.length - 2;
79
+ if (total[prefixs[len]]) {
80
+ total[prefixs[len]][index] = Object.assign(Object.assign({}, attrObj), children || []);
81
+ } else {
82
+ total[prefixs[len]] = [Object.assign(Object.assign({}, attrObj), children || [])];
83
+ }
84
+ return total;
85
+ }, {});
86
+ return values;
87
+ }
88
+ } catch (e) {
89
+ if (typeof e === 'string') {
90
+ console.error(e.toUpperCase());
91
+ throw e.toUpperCase();
92
+ } else if (e instanceof Error) {
93
+ console.error(e.message);
94
+ throw e.message;
95
+ }
96
+ throw e;
97
+ }
98
+ };
99
+ /**
100
+ * 获取form表单的value
101
+ * @param {*} formCurrent
102
+ * @returns
103
+ */
104
+ export const getFieldsValue = formCurrent => {
105
+ try {
106
+ const {
107
+ formData,
108
+ dataLevel
109
+ } = formCurrent;
110
+ let firstKey = '';
111
+ // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序
112
+ for (const i in dataLevel) {
113
+ if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {
114
+ firstKey = i;
115
+ break;
116
+ }
117
+ }
118
+ const recursionStart = dataLevel[firstKey];
119
+ const values = recursionSort(recursionStart, dataLevel, formData);
120
+ return values;
121
+ } catch (e) {
122
+ if (typeof e === 'string') {
123
+ console.error(e.toUpperCase());
124
+ return e.toUpperCase();
125
+ } else if (e instanceof Error) {
126
+ console.error(e.message);
127
+ return e.message;
128
+ }
129
+ return e;
130
+ }
131
+ };
132
+ /**
133
+ * 获取form表单的value
134
+ * @param {*} formCurrent
135
+ * @returns
136
+ */
137
+ export const getFieldValue = (formCurrent, field) => {
138
+ var _a, _b;
139
+ try {
140
+ const {
141
+ formData
142
+ } = formCurrent;
143
+ return formData && ((_b = (_a = formData === null || formData === void 0 ? void 0 : formData[field[0]]) === null || _a === void 0 ? void 0 : _a[field[1]]) === null || _b === void 0 ? void 0 : _b.value);
144
+ } catch (e) {
145
+ if (typeof e === 'string') {
146
+ return e.toUpperCase();
147
+ } else if (e instanceof Error) {
148
+ return e.message;
149
+ }
150
+ return e;
151
+ }
152
+ };
153
+ /**
154
+ * 提交时候校验的方法
155
+ * @param {*} formCurrent
156
+ * @returns
157
+ */
158
+ export const validateFields = formCurrent => {
159
+ return new Promise(resolve => {
160
+ const {
161
+ formData,
162
+ dataLevel
163
+ } = formCurrent;
164
+ let firstKey = '';
165
+ // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序
166
+ for (const i in dataLevel) {
167
+ if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {
168
+ firstKey = i;
169
+ break;
170
+ }
171
+ }
172
+ const recursionStart = dataLevel[firstKey];
173
+ const errorList = recursionCheck(recursionStart, dataLevel, formData);
174
+ if (Array.isArray(errorList) && errorList.length) {
175
+ console.error(JSON.stringify(errorList));
176
+ } else {
177
+ resolve(recursionSort(recursionStart, dataLevel, formData));
178
+ }
179
+ });
180
+ };
181
+ /** 获取初始化的值 */
182
+ export const getInitValue = (initialValues, names) => {
183
+ let keys = [];
184
+ if (Array.isArray(names)) {
185
+ const [str, ...rest] = names;
186
+ keys = str.split('.').concat(rest);
187
+ }
188
+ if (Array.isArray(keys) && !!keys.length) {
189
+ keys.forEach(i => {
190
+ initialValues = ['', null, undefined].includes(initialValues === null || initialValues === void 0 ? void 0 : initialValues[i]) ? undefined : initialValues === null || initialValues === void 0 ? void 0 : initialValues[i];
191
+ });
192
+ }
193
+ return initialValues;
194
+ };
195
+ /** 校验表单是否正确的方法 */
196
+ export const handleCheckItem = (value, rules) => {
197
+ try {
198
+ if (Array.isArray(rules)) {
199
+ rules.forEach(i => {
200
+ // @ts-ignore
201
+ if (i.required && ['', null, undefined].includes(value)) {
202
+ throw new Error((i === null || i === void 0 ? void 0 : i.message) || 'error');
203
+ }
204
+ if (i === null || i === void 0 ? void 0 : i.validator) {
205
+ i.validator(rules, value, function (_errorMsg) {
206
+ throw new Error(_errorMsg);
207
+ });
208
+ }
209
+ });
210
+ }
211
+ return;
212
+ } catch (e) {
213
+ if (typeof e === 'string') {
214
+ return e.toUpperCase();
215
+ } else if (e instanceof Error) {
216
+ return e.message;
217
+ }
218
+ }
219
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n TinitialValueType,\n ValidationRule,\n IForm,\n IObject,\n ILevel,\n IFormData,\n} from './interface'\n\nexport const isValidKey = (\n key: string | number | symbol,\n object: object\n): key is keyof typeof object => {\n return key in object\n}\n\n/**\n * 将xx.xx.xx 转换为数组\n * @param {*} name\n * @returns\n */\nexport const getNames = (name: string[] | string) => {\n let attrs = []\n if (Array.isArray(name)) {\n const [str, ...rest] = name\n attrs = str.split('.').concat(rest)\n } else {\n attrs = typeof name === 'string' ? name.split('.') : []\n }\n return attrs\n}\n\n/**\n * 对数据进行校验\n * @param {*} list\n * @param {*} dataLevel\n * @param {*} formData\n * @returns\n */\nexport const recursionCheck = (\n list: any,\n dataLevel: IObject<ILevel[]>,\n formData: IFormData,\n errorList: string[] = []\n) => {\n try {\n if (Array.isArray(list)) {\n list.forEach((item) => {\n const key = item.name\n const attrs = Object.keys(formData[key])\n\n attrs.forEach((attr) => {\n const error = formData[item.name][attr]?.checkItem()\n if (error) {\n errorList.push(`${[item.name + '.' + attr]}:`, error)\n }\n })\n if (dataLevel[key]) {\n recursionCheck(dataLevel[key], dataLevel, formData, errorList)\n }\n })\n }\n return errorList\n } catch (e) {\n if (typeof e === 'string') {\n throw e.toUpperCase()\n } else if (e instanceof Error) {\n throw e.message\n }\n throw e\n }\n}\n\n/**\n * 将数据进行排序\n * @param {*} list\n * @param {*} dataLevel\n * @param {*} formData\n * @param {*} errorList\n * @returns\n */\nexport const recursionSort = (list: any, dataLevel: IObject<ILevel[]>, formData: IFormData) => {\n try {\n if (Array.isArray(list)) {\n const values = list.reduce((total, item, index) => {\n const attrObj: IObject<TinitialValueType> = {}\n const key = item.name\n const prefixs = key.split('.')\n const attrs = formData[key] ? Object.keys(formData[key]) : []\n\n attrs.forEach((attr) => {\n attrObj[attr] = formData[key][attr]?.value\n })\n let children = []\n if (dataLevel[key]) {\n children = recursionSort(dataLevel[key], dataLevel, formData)\n }\n\n const len = prefixs.length - 2\n if (total[prefixs[len]]) {\n total[prefixs[len]][index] = {\n ...attrObj,\n ...(children || []),\n }\n } else {\n total[prefixs[len]] = [\n {\n ...attrObj,\n ...(children || []),\n },\n ]\n }\n return total\n }, {})\n return values\n }\n } catch (e) {\n if (typeof e === 'string') {\n console.error(e.toUpperCase())\n throw e.toUpperCase()\n } else if (e instanceof Error) {\n console.error(e.message)\n throw e.message\n }\n throw e\n }\n}\n\n/**\n * 获取form表单的value\n * @param {*} formCurrent\n * @returns\n */\nexport const getFieldsValue = (formCurrent: IForm) => {\n try {\n const { formData, dataLevel } = formCurrent\n let firstKey = ''\n // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序\n for (const i in dataLevel) {\n if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {\n firstKey = i\n break\n }\n }\n const recursionStart = dataLevel[firstKey]\n const values = recursionSort(recursionStart, dataLevel, formData)\n return values\n } catch (e) {\n if (typeof e === 'string') {\n console.error(e.toUpperCase())\n return e.toUpperCase()\n } else if (e instanceof Error) {\n console.error(e.message)\n return e.message\n }\n return e\n }\n}\n\n/**\n * 获取form表单的value\n * @param {*} formCurrent\n * @returns\n */\nexport const getFieldValue = (formCurrent: IForm, field: string[]) => {\n try {\n const { formData } = formCurrent\n return formData && formData?.[field[0]]?.[field[1]]?.value\n } catch (e) {\n if (typeof e === 'string') {\n return e.toUpperCase()\n } else if (e instanceof Error) {\n return e.message\n }\n return e\n }\n}\n\n/**\n * 提交时候校验的方法\n * @param {*} formCurrent\n * @returns\n */\nexport const validateFields = (formCurrent: IForm) => {\n return new Promise((resolve) => {\n const { formData, dataLevel } = formCurrent\n let firstKey = ''\n // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序\n for (const i in dataLevel) {\n if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {\n firstKey = i\n break\n }\n }\n const recursionStart = dataLevel[firstKey]\n const errorList = recursionCheck(recursionStart, dataLevel, formData)\n if (Array.isArray(errorList) && errorList.length) {\n console.error(JSON.stringify(errorList))\n } else {\n resolve(recursionSort(recursionStart, dataLevel, formData))\n }\n })\n}\n\n/** 获取初始化的值 */\nexport const getInitValue = (\n initialValues: IObject<any> | undefined,\n names: string[] | string\n): TinitialValueType => {\n let keys: string[] = []\n if (Array.isArray(names)) {\n const [str, ...rest] = names\n keys = str.split('.').concat(rest)\n }\n\n if (Array.isArray(keys) && !!keys.length) {\n keys.forEach((i) => {\n initialValues = ['', null, undefined].includes(initialValues?.[i])\n ? undefined\n : initialValues?.[i]\n })\n }\n\n return initialValues as TinitialValueType\n}\n\n/** 校验表单是否正确的方法 */\nexport const handleCheckItem = (value: TinitialValueType, rules: ValidationRule) => {\n try {\n if (Array.isArray(rules)) {\n rules.forEach((i) => {\n // @ts-ignore\n if (i.required && ['', null, undefined].includes(value)) {\n throw new Error(i?.message || 'error')\n }\n if (i?.validator) {\n i.validator(rules, value, function (_errorMsg: string) {\n throw new Error(_errorMsg)\n })\n }\n })\n }\n return\n } catch (e) {\n if (typeof e === 'string') {\n return e.toUpperCase()\n } else if (e instanceof Error) {\n return e.message\n }\n }\n}\n"]}