tntd 2.0.19 → 2.0.22

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 (684) hide show
  1. package/es/affix/index.js +2 -1
  2. package/es/alert/index.js +2 -1
  3. package/es/anchor/index.js +2 -1
  4. package/es/array-input/icon.js +6 -24
  5. package/es/array-input/index.js +119 -203
  6. package/es/auth-context/index.js +2 -1
  7. package/es/auto-complete/index.js +2 -1
  8. package/es/avatar/index.js +2 -1
  9. package/es/back-top/index.js +2 -1
  10. package/es/badge/index.js +2 -1
  11. package/es/breadcrumb/index.js +2 -1
  12. package/es/button/index.js +2 -1
  13. package/es/calendar/index.js +2 -1
  14. package/es/card/index.js +2 -1
  15. package/es/carousel/index.js +2 -1
  16. package/es/cascader/index.js +2 -1
  17. package/es/checkbox/index.js +2 -1
  18. package/es/col/index.js +2 -1
  19. package/es/collapse/index.js +2 -1
  20. package/es/columns/index.js +30 -66
  21. package/es/columns/style/index.js +2 -1
  22. package/es/comment/index.js +2 -1
  23. package/es/config-provider/config-provider.js +2 -1
  24. package/es/config-provider/index.js +2 -1
  25. package/es/date-picker/index.js +2 -1
  26. package/es/descriptions/index.js +2 -1
  27. package/es/development-login/LoginModal.js +46 -81
  28. package/es/development-login/index.js +8 -17
  29. package/es/divider/index.js +2 -1
  30. package/es/drawer/drawer.js +20 -27
  31. package/es/drawer/index.js +2 -1
  32. package/es/dropdown/index.js +2 -1
  33. package/es/ellipsis/Svg/CopySVG.js +17 -63
  34. package/es/ellipsis/Svg/TickSVG.js +12 -41
  35. package/es/ellipsis/index.js +68 -100
  36. package/es/empty/empty.js +48 -58
  37. package/es/empty/empty.stories.js +6 -5
  38. package/es/empty/index.js +2 -1
  39. package/es/exception/exception.js +19 -32
  40. package/es/exception/index.js +2 -1
  41. package/es/form/index.js +2 -1
  42. package/es/handle/index.js +71 -110
  43. package/es/icon/index.js +2 -1
  44. package/es/icon-list/index.js +120 -1
  45. package/es/img/Contain.js +39 -60
  46. package/es/img/Cover.js +72 -98
  47. package/es/img/index.js +32 -48
  48. package/es/index.js +2 -1
  49. package/es/input/index.js +2 -1
  50. package/es/input-number/index.js +2 -1
  51. package/es/layout/index.js +2 -1
  52. package/es/list/index.js +2 -1
  53. package/es/loading-button/index.js +28 -33
  54. package/es/locale/default.js +4 -3
  55. package/es/locale/en_US.js +30 -29
  56. package/es/locale/index.js +2 -1
  57. package/es/locale/zh_CN.js +30 -29
  58. package/es/locale-provider/index.js +2 -1
  59. package/es/mention/index.js +2 -1
  60. package/es/mentions/index.js +2 -1
  61. package/es/menu/index.js +2 -1
  62. package/es/message/index.js +2 -1
  63. package/es/modal/index.js +2 -1
  64. package/es/modal/modal.js +17 -20
  65. package/es/notification/index.js +2 -1
  66. package/es/page/Box.js +33 -49
  67. package/es/page/index.js +88 -123
  68. package/es/page/utils.js +14 -12
  69. package/es/page-header/index.js +2 -1
  70. package/es/pagination/index.js +2 -1
  71. package/es/popconfirm/index.js +2 -1
  72. package/es/popover/index.js +2 -1
  73. package/es/prev-locale.js +47 -49
  74. package/es/progress/index.js +2 -1
  75. package/es/query-form/Field/Checkbox.js +17 -20
  76. package/es/query-form/Field/Select.js +39 -54
  77. package/es/query-form/Field/SelectInput.js +45 -63
  78. package/es/query-form/Field/fieldsMap.js +20 -19
  79. package/es/query-form/Field/index.js +66 -104
  80. package/es/query-form/createActions.js +46 -46
  81. package/es/query-form/index.js +247 -327
  82. package/es/query-form/useForm.js +4 -3
  83. package/es/query-list-scene/List.js +257 -321
  84. package/es/query-list-scene/QueryForm.js +94 -131
  85. package/es/query-list-scene/QueryListScene.js +21 -29
  86. package/es/query-list-scene/Title.js +4 -6
  87. package/es/query-list-scene/Toolbar.js +15 -21
  88. package/es/query-list-scene/createActions.js +60 -60
  89. package/es/query-list-scene/index.js +2 -1
  90. package/es/query-list-scene/useActions.js +4 -3
  91. package/es/radio/index.js +2 -1
  92. package/es/rate/index.js +2 -1
  93. package/es/render-empty/index.js +2 -1
  94. package/es/render-empty/render-empty.js +16 -19
  95. package/es/result/index.js +2 -1
  96. package/es/row/index.js +2 -1
  97. package/es/select/index.js +2 -1
  98. package/es/skeleton/index.js +2 -1
  99. package/es/slider/index.js +2 -1
  100. package/es/spin/index.js +2 -1
  101. package/es/statistic/index.js +2 -1
  102. package/es/steps/index.js +2 -1
  103. package/es/steps/steps.js +35 -51
  104. package/es/svg-components/illustration-403.js +58 -206
  105. package/es/svg-components/illustration-404.js +75 -290
  106. package/es/svg-components/illustration-500.js +83 -321
  107. package/es/svg-components/illustration-empty.js +15 -54
  108. package/es/svg-components/illustration-failure.js +36 -112
  109. package/es/svg-components/illustration-no-access.js +35 -114
  110. package/es/svg-components/illustration-no-chart.js +37 -134
  111. package/es/svg-components/illustration-no-result.js +32 -92
  112. package/es/svg-components/illustration-offline.js +43 -131
  113. package/es/svg-components/illustration-success.js +43 -137
  114. package/es/svg-components/index.js +2 -1
  115. package/es/switch/index.js +2 -1
  116. package/es/table/assets/image-loading-background.js +17 -45
  117. package/es/table/assets/image-loading.js +5 -26
  118. package/es/table/constants.js +2 -1
  119. package/es/table/context.js +2 -1
  120. package/es/table/hooks/index.js +2 -1
  121. package/es/table/hooks/use-column-setting.js +16 -13
  122. package/es/table/index.js +2 -1
  123. package/es/table/table.js +51 -73
  124. package/es/table/table.stories.js +139 -148
  125. package/es/table/utils.js +18 -17
  126. package/es/tabs/index.js +2 -1
  127. package/es/tag/index.js +2 -1
  128. package/es/time-picker/index.js +2 -1
  129. package/es/timeline/index.js +2 -1
  130. package/es/title/index.js +20 -34
  131. package/es/tnt-second-page/index.js +27 -0
  132. package/es/tnt-second-page/index.js.map +1 -0
  133. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +5 -9
  134. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +2 -1
  135. package/es/tntd-cascader/AntdCascader/component/SizeContext.js +2 -1
  136. package/es/tntd-cascader/AntdCascader/component/context.js +7 -5
  137. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +10 -22
  138. package/es/tntd-cascader/AntdCascader/component/getIcons.js +50 -72
  139. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +20 -22
  140. package/es/tntd-cascader/AntdCascader/config/utils.js +18 -17
  141. package/es/tntd-cascader/AntdCascader/config/warning.js +10 -9
  142. package/es/tntd-cascader/AntdCascader/index.js +118 -189
  143. package/es/tntd-cascader/AntdCascader/interface.js +2 -1
  144. package/es/tntd-cascader/index.js +2 -1
  145. package/es/tntd-cascader/rc-cascader/Cascader.js +239 -256
  146. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +11 -21
  147. package/es/tntd-cascader/rc-cascader/OptionList/Column.js +116 -175
  148. package/es/tntd-cascader/rc-cascader/OptionList/index.js +128 -180
  149. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +19 -22
  150. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +137 -144
  151. package/es/tntd-cascader/rc-cascader/context.js +2 -1
  152. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +37 -44
  153. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +24 -25
  154. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +17 -15
  155. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +8 -7
  156. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +21 -20
  157. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +41 -51
  158. package/es/tntd-cascader/rc-cascader/index.js +2 -1
  159. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +27 -33
  160. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +32 -29
  161. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +23 -26
  162. package/es/tntd-form/TntdForm/components/Item.js +34 -31
  163. package/es/tntd-form/TntdForm/components/Item.js.map +1 -1
  164. package/es/tntd-form/TntdForm/components/ItemComp.js +163 -135
  165. package/es/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  166. package/es/tntd-form/TntdForm/components/List.js +79 -63
  167. package/es/tntd-form/TntdForm/components/List.js.map +1 -1
  168. package/es/tntd-form/TntdForm/index.js +35 -37
  169. package/es/tntd-form/TntdForm/index.js.map +1 -1
  170. package/es/tntd-form/TntdForm/interface.js +2 -1
  171. package/es/tntd-form/TntdForm/interface.js.map +1 -1
  172. package/es/tntd-form/TntdForm/store.js +2 -1
  173. package/es/tntd-form/TntdForm/utils.js +168 -158
  174. package/es/tntd-form/index.js +2 -1
  175. package/es/tntd-icon/fonts/iconfont.js +53 -36
  176. package/es/tntd-icon/index.js +17 -23
  177. package/es/tntd-layout/ActionsContext.js +2 -1
  178. package/es/tntd-layout/AppList.js +77 -135
  179. package/es/tntd-layout/Application.js +29 -42
  180. package/es/tntd-layout/Avatar.js +42 -80
  181. package/es/tntd-layout/CompatibleLanguage.js +56 -93
  182. package/es/tntd-layout/EnterpriseLayout/Avatar.js +47 -93
  183. package/es/tntd-layout/EnterpriseLayout/Language.js +34 -56
  184. package/es/tntd-layout/EnterpriseLayout/Theme.js +24 -45
  185. package/es/tntd-layout/EnterpriseLayout/index.js +9 -17
  186. package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +154 -213
  187. package/es/tntd-layout/GlobalNavigation/index.js +50 -84
  188. package/es/tntd-layout/Header.js +26 -59
  189. package/es/tntd-layout/HeaderActions.js +34 -83
  190. package/es/tntd-layout/HeaderNavs.js +35 -46
  191. package/es/tntd-layout/HeaderTabs.js +140 -176
  192. package/es/tntd-layout/Iconfont.js +2 -1
  193. package/es/tntd-layout/Language.js +33 -55
  194. package/es/tntd-layout/Layout.js +78 -176
  195. package/es/tntd-layout/Logo.js +40 -52
  196. package/es/tntd-layout/OrgAppList.js +139 -208
  197. package/es/tntd-layout/SideMenu.js +160 -230
  198. package/es/tntd-layout/Theme.js +29 -47
  199. package/es/tntd-layout/createActions.js +29 -28
  200. package/es/tntd-layout/images/index.js +32 -31
  201. package/es/tntd-layout/index.js +60 -92
  202. package/es/tntd-layout/paaslayout/CompactSideMenu.js +65 -109
  203. package/es/tntd-layout/paaslayout/Header.js +14 -37
  204. package/es/tntd-layout/paaslayout/Logo.js +3 -2
  205. package/es/tntd-layout/paaslayout/SideMenu.js +63 -109
  206. package/es/tntd-layout/paaslayout/index.js +79 -159
  207. package/es/tntd-layout/storage.js +11 -18
  208. package/es/tntd-layout/tntdLayout.stories.js +275 -0
  209. package/es/tntd-layout/tntdLayout.stories.js.map +1 -0
  210. package/es/tntd-modal/index.js +32 -73
  211. package/es/tntd-second-page/index.js +24 -47
  212. package/es/tntd-second-page/index.less +2 -2
  213. package/es/tntd-select/DropDownWrap.js +52 -73
  214. package/es/tntd-select/index.js +482 -564
  215. package/es/tooltip/index.js +2 -1
  216. package/es/transfer/index.js +2 -1
  217. package/es/tree/index.js +2 -1
  218. package/es/tree-select/index.js +2 -1
  219. package/es/typography/index.js +2 -1
  220. package/es/upload/index.js +2 -1
  221. package/es/utils/checkAuth.js +21 -24
  222. package/es/utils/findMenuInfoByPath.js +30 -33
  223. package/es/utils/index.js +59 -65
  224. package/es/version/index.js +2 -1
  225. package/lib/affix/index.d.ts +3 -3
  226. package/lib/affix/index.js +22 -23
  227. package/lib/affix/index.js.map +1 -1
  228. package/lib/alert/index.d.ts +3 -3
  229. package/lib/alert/index.js +22 -23
  230. package/lib/alert/index.js.map +1 -1
  231. package/lib/anchor/index.d.ts +3 -3
  232. package/lib/anchor/index.js +22 -23
  233. package/lib/anchor/index.js.map +1 -1
  234. package/lib/array-input/icon.js +12 -33
  235. package/lib/array-input/index.js +150 -254
  236. package/lib/auth-context/index.js +4 -10
  237. package/lib/auto-complete/index.d.ts +3 -3
  238. package/lib/auto-complete/index.js +22 -23
  239. package/lib/auto-complete/index.js.map +1 -1
  240. package/lib/avatar/index.d.ts +3 -3
  241. package/lib/avatar/index.js +22 -23
  242. package/lib/avatar/index.js.map +1 -1
  243. package/lib/back-top/index.d.ts +3 -3
  244. package/lib/back-top/index.js +22 -23
  245. package/lib/back-top/index.js.map +1 -1
  246. package/lib/badge/index.d.ts +3 -3
  247. package/lib/badge/index.js +22 -23
  248. package/lib/badge/index.js.map +1 -1
  249. package/lib/breadcrumb/index.d.ts +3 -3
  250. package/lib/breadcrumb/index.js +22 -23
  251. package/lib/breadcrumb/index.js.map +1 -1
  252. package/lib/button/index.d.ts +3 -3
  253. package/lib/button/index.js +22 -23
  254. package/lib/button/index.js.map +1 -1
  255. package/lib/calendar/index.d.ts +3 -3
  256. package/lib/calendar/index.js +22 -23
  257. package/lib/calendar/index.js.map +1 -1
  258. package/lib/card/index.d.ts +3 -3
  259. package/lib/card/index.js +22 -23
  260. package/lib/card/index.js.map +1 -1
  261. package/lib/carousel/index.d.ts +3 -3
  262. package/lib/carousel/index.js +22 -23
  263. package/lib/carousel/index.js.map +1 -1
  264. package/lib/cascader/index.d.ts +3 -3
  265. package/lib/cascader/index.js +22 -23
  266. package/lib/cascader/index.js.map +1 -1
  267. package/lib/checkbox/index.d.ts +3 -3
  268. package/lib/checkbox/index.js +22 -23
  269. package/lib/checkbox/index.js.map +1 -1
  270. package/lib/col/index.d.ts +3 -3
  271. package/lib/col/index.js +22 -23
  272. package/lib/col/index.js.map +1 -1
  273. package/lib/collapse/index.d.ts +3 -3
  274. package/lib/collapse/index.js +23 -24
  275. package/lib/collapse/index.js.map +1 -1
  276. package/lib/columns/index.js +41 -81
  277. package/lib/columns/style/index.js +2 -1
  278. package/lib/comment/index.d.ts +3 -3
  279. package/lib/comment/index.js +22 -23
  280. package/lib/comment/index.js.map +1 -1
  281. package/lib/config-provider/config-provider.d.ts +1 -1
  282. package/lib/config-provider/config-provider.js +8 -12
  283. package/lib/config-provider/config-provider.js.map +1 -1
  284. package/lib/config-provider/index.d.ts +3 -3
  285. package/lib/config-provider/index.js +22 -23
  286. package/lib/config-provider/index.js.map +1 -1
  287. package/lib/date-picker/index.d.ts +3 -3
  288. package/lib/date-picker/index.js +22 -23
  289. package/lib/date-picker/index.js.map +1 -1
  290. package/lib/descriptions/index.d.ts +3 -3
  291. package/lib/descriptions/index.js +22 -23
  292. package/lib/descriptions/index.js.map +1 -1
  293. package/lib/development-login/LoginModal.js +79 -110
  294. package/lib/development-login/index.js +35 -42
  295. package/lib/divider/index.d.ts +3 -3
  296. package/lib/divider/index.js +22 -23
  297. package/lib/divider/index.js.map +1 -1
  298. package/lib/drawer/drawer.d.ts +1 -1
  299. package/lib/drawer/drawer.js +30 -41
  300. package/lib/drawer/drawer.js.map +1 -1
  301. package/lib/drawer/index.d.ts +2 -2
  302. package/lib/drawer/index.js +20 -22
  303. package/lib/drawer/index.js.map +1 -1
  304. package/lib/dropdown/index.d.ts +3 -3
  305. package/lib/dropdown/index.js +22 -23
  306. package/lib/dropdown/index.js.map +1 -1
  307. package/lib/ellipsis/Svg/CopySVG.js +21 -70
  308. package/lib/ellipsis/Svg/TickSVG.js +16 -48
  309. package/lib/ellipsis/index.js +105 -128
  310. package/lib/empty/empty.d.ts +2 -2
  311. package/lib/empty/empty.js +75 -90
  312. package/lib/empty/empty.js.map +1 -1
  313. package/lib/empty/empty.stories.js +18 -19
  314. package/lib/empty/index.d.ts +1 -1
  315. package/lib/empty/index.js +19 -20
  316. package/lib/empty/index.js.map +1 -1
  317. package/lib/exception/exception.js +31 -46
  318. package/lib/exception/exception.js.map +1 -1
  319. package/lib/exception/index.js +18 -19
  320. package/lib/form/index.d.ts +3 -3
  321. package/lib/form/index.js +22 -23
  322. package/lib/form/index.js.map +1 -1
  323. package/lib/handle/index.js +104 -140
  324. package/lib/handle/index.js.map +1 -1
  325. package/lib/icon/index.d.ts +3 -3
  326. package/lib/icon/index.js +22 -23
  327. package/lib/icon/index.js.map +1 -1
  328. package/lib/icon-list/index.js +121 -7
  329. package/lib/img/Contain.js +44 -69
  330. package/lib/img/Cover.js +78 -117
  331. package/lib/img/index.js +60 -74
  332. package/lib/index.js +184 -614
  333. package/lib/input/index.d.ts +3 -3
  334. package/lib/input/index.js +22 -23
  335. package/lib/input/index.js.map +1 -1
  336. package/lib/input-number/index.d.ts +3 -3
  337. package/lib/input-number/index.js +22 -23
  338. package/lib/input-number/index.js.map +1 -1
  339. package/lib/layout/index.d.ts +3 -3
  340. package/lib/layout/index.js +22 -23
  341. package/lib/layout/index.js.map +1 -1
  342. package/lib/list/index.d.ts +3 -3
  343. package/lib/list/index.js +22 -23
  344. package/lib/list/index.js.map +1 -1
  345. package/lib/loading-button/index.js +55 -58
  346. package/lib/locale/default.d.ts +1 -163
  347. package/lib/locale/default.d.ts.map +1 -1
  348. package/lib/locale/default.js +10 -12
  349. package/lib/locale/default.js.map +1 -1
  350. package/lib/locale/en_US.d.ts +1 -96
  351. package/lib/locale/en_US.d.ts.map +1 -1
  352. package/lib/locale/en_US.js +35 -37
  353. package/lib/locale/en_US.js.map +1 -1
  354. package/lib/locale/index.js +18 -36
  355. package/lib/locale/zh_CN.d.ts +1 -95
  356. package/lib/locale/zh_CN.d.ts.map +1 -1
  357. package/lib/locale/zh_CN.js +35 -37
  358. package/lib/locale/zh_CN.js.map +1 -1
  359. package/lib/locale-provider/index.d.ts +3 -3
  360. package/lib/locale-provider/index.js +22 -23
  361. package/lib/locale-provider/index.js.map +1 -1
  362. package/lib/mention/index.d.ts +3 -3
  363. package/lib/mention/index.js +22 -23
  364. package/lib/mention/index.js.map +1 -1
  365. package/lib/mentions/index.d.ts +3 -3
  366. package/lib/mentions/index.js +22 -23
  367. package/lib/mentions/index.js.map +1 -1
  368. package/lib/menu/index.d.ts +3 -3
  369. package/lib/menu/index.js +22 -23
  370. package/lib/menu/index.js.map +1 -1
  371. package/lib/message/index.d.ts +3 -3
  372. package/lib/message/index.js +22 -23
  373. package/lib/message/index.js.map +1 -1
  374. package/lib/modal/index.d.ts +1 -1
  375. package/lib/modal/index.js +21 -22
  376. package/lib/modal/index.js.map +1 -1
  377. package/lib/modal/modal.d.ts +9 -9
  378. package/lib/modal/modal.js +49 -53
  379. package/lib/modal/modal.js.map +1 -1
  380. package/lib/notification/index.d.ts +3 -3
  381. package/lib/notification/index.js +22 -23
  382. package/lib/notification/index.js.map +1 -1
  383. package/lib/page/Box.js +40 -66
  384. package/lib/page/index.js +99 -151
  385. package/lib/page/utils.js +16 -22
  386. package/lib/page-header/index.d.ts +3 -3
  387. package/lib/page-header/index.js +22 -23
  388. package/lib/page-header/index.js.map +1 -1
  389. package/lib/pagination/index.d.ts +3 -3
  390. package/lib/pagination/index.js +22 -23
  391. package/lib/pagination/index.js.map +1 -1
  392. package/lib/popconfirm/index.d.ts +3 -3
  393. package/lib/popconfirm/index.js +22 -23
  394. package/lib/popconfirm/index.js.map +1 -1
  395. package/lib/popover/index.d.ts +3 -3
  396. package/lib/popover/index.js +22 -23
  397. package/lib/popover/index.js.map +1 -1
  398. package/lib/prev-locale.js +53 -67
  399. package/lib/progress/index.d.ts +3 -3
  400. package/lib/progress/index.js +22 -23
  401. package/lib/progress/index.js.map +1 -1
  402. package/lib/query-form/Field/Checkbox.js +22 -28
  403. package/lib/query-form/Field/Select.js +68 -79
  404. package/lib/query-form/Field/SelectInput.js +73 -85
  405. package/lib/query-form/Field/fieldsMap.d.ts +2 -2
  406. package/lib/query-form/Field/fieldsMap.js +32 -34
  407. package/lib/query-form/Field/index.js +95 -139
  408. package/lib/query-form/createActions.js +50 -53
  409. package/lib/query-form/index.d.ts +1 -1
  410. package/lib/query-form/index.d.ts.map +1 -1
  411. package/lib/query-form/index.js +286 -377
  412. package/lib/query-form/useForm.js +11 -11
  413. package/lib/query-list-scene/List.d.ts +2 -2
  414. package/lib/query-list-scene/List.d.ts.map +1 -1
  415. package/lib/query-list-scene/List.js +291 -360
  416. package/lib/query-list-scene/QueryForm.js +103 -160
  417. package/lib/query-list-scene/QueryListScene.js +31 -66
  418. package/lib/query-list-scene/Title.js +9 -15
  419. package/lib/query-list-scene/Toolbar.js +20 -31
  420. package/lib/query-list-scene/createActions.d.ts +4 -4
  421. package/lib/query-list-scene/createActions.js +64 -79
  422. package/lib/query-list-scene/index.d.ts +4 -4
  423. package/lib/query-list-scene/index.js +24 -28
  424. package/lib/query-list-scene/useActions.d.ts +4 -4
  425. package/lib/query-list-scene/useActions.js +11 -11
  426. package/lib/radio/index.d.ts +3 -3
  427. package/lib/radio/index.js +22 -23
  428. package/lib/radio/index.js.map +1 -1
  429. package/lib/rate/index.d.ts +3 -3
  430. package/lib/rate/index.js +22 -23
  431. package/lib/rate/index.js.map +1 -1
  432. package/lib/render-empty/index.js +4 -8
  433. package/lib/render-empty/render-empty.js +22 -28
  434. package/lib/render-empty/render-empty.js.map +1 -1
  435. package/lib/result/index.d.ts +3 -3
  436. package/lib/result/index.js +22 -23
  437. package/lib/result/index.js.map +1 -1
  438. package/lib/row/index.d.ts +3 -3
  439. package/lib/row/index.js +22 -23
  440. package/lib/row/index.js.map +1 -1
  441. package/lib/select/index.d.ts +3 -3
  442. package/lib/select/index.js +22 -23
  443. package/lib/select/index.js.map +1 -1
  444. package/lib/skeleton/index.d.ts +3 -3
  445. package/lib/skeleton/index.js +22 -23
  446. package/lib/skeleton/index.js.map +1 -1
  447. package/lib/slider/index.d.ts +3 -3
  448. package/lib/slider/index.js +22 -23
  449. package/lib/slider/index.js.map +1 -1
  450. package/lib/spin/index.d.ts +3 -3
  451. package/lib/spin/index.js +22 -23
  452. package/lib/spin/index.js.map +1 -1
  453. package/lib/statistic/index.d.ts +3 -3
  454. package/lib/statistic/index.js +22 -23
  455. package/lib/statistic/index.js.map +1 -1
  456. package/lib/steps/index.d.ts +1 -1
  457. package/lib/steps/index.js +19 -20
  458. package/lib/steps/index.js.map +1 -1
  459. package/lib/steps/steps.d.ts +3 -3
  460. package/lib/steps/steps.js +59 -72
  461. package/lib/steps/steps.js.map +1 -1
  462. package/lib/svg-components/illustration-403.js +84 -217
  463. package/lib/svg-components/illustration-404.js +101 -301
  464. package/lib/svg-components/illustration-500.js +109 -332
  465. package/lib/svg-components/illustration-empty.js +41 -65
  466. package/lib/svg-components/illustration-failure.js +62 -123
  467. package/lib/svg-components/illustration-no-access.js +61 -125
  468. package/lib/svg-components/illustration-no-chart.js +63 -145
  469. package/lib/svg-components/illustration-no-result.js +58 -103
  470. package/lib/svg-components/illustration-offline.js +69 -142
  471. package/lib/svg-components/illustration-success.js +69 -148
  472. package/lib/svg-components/index.js +26 -75
  473. package/lib/switch/index.d.ts +3 -3
  474. package/lib/switch/index.js +22 -23
  475. package/lib/switch/index.js.map +1 -1
  476. package/lib/table/assets/image-loading-background.js +43 -56
  477. package/lib/table/assets/image-loading.js +31 -37
  478. package/lib/table/constants.js +3 -6
  479. package/lib/table/context.js +4 -7
  480. package/lib/table/hooks/index.js +16 -14
  481. package/lib/table/hooks/use-column-setting.d.ts +1 -1
  482. package/lib/table/hooks/use-column-setting.js +20 -37
  483. package/lib/table/hooks/use-column-setting.js.map +1 -1
  484. package/lib/table/index.d.ts +1 -1
  485. package/lib/table/index.js +19 -20
  486. package/lib/table/index.js.map +1 -1
  487. package/lib/table/table.d.ts +3 -3
  488. package/lib/table/table.js +90 -108
  489. package/lib/table/table.js.map +1 -1
  490. package/lib/table/table.stories.js +154 -182
  491. package/lib/table/utils.d.ts +1 -1
  492. package/lib/table/utils.js +25 -24
  493. package/lib/table/utils.js.map +1 -1
  494. package/lib/tabs/index.d.ts +3 -3
  495. package/lib/tabs/index.js +22 -23
  496. package/lib/tabs/index.js.map +1 -1
  497. package/lib/tag/index.d.ts +3 -3
  498. package/lib/tag/index.js +22 -23
  499. package/lib/tag/index.js.map +1 -1
  500. package/lib/time-picker/index.d.ts +3 -3
  501. package/lib/time-picker/index.js +22 -23
  502. package/lib/time-picker/index.js.map +1 -1
  503. package/lib/timeline/index.d.ts +3 -3
  504. package/lib/timeline/index.js +22 -23
  505. package/lib/timeline/index.js.map +1 -1
  506. package/lib/title/index.js +26 -45
  507. package/lib/tnt-second-page/index.d.ts +17 -0
  508. package/lib/tnt-second-page/index.d.ts.map +1 -0
  509. package/lib/tnt-second-page/index.js +33 -0
  510. package/lib/tnt-second-page/index.js.map +1 -0
  511. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +31 -18
  512. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +26 -9
  513. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +26 -9
  514. package/lib/tntd-cascader/AntdCascader/component/context.js +16 -18
  515. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +39 -36
  516. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  517. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +75 -81
  518. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +50 -31
  519. package/lib/tntd-cascader/AntdCascader/config/utils.js +27 -29
  520. package/lib/tntd-cascader/AntdCascader/config/warning.js +35 -19
  521. package/lib/tntd-cascader/AntdCascader/index.js +162 -216
  522. package/lib/tntd-cascader/AntdCascader/interface.js +6 -13
  523. package/lib/tntd-cascader/img/no-data-s.png +0 -0
  524. package/lib/tntd-cascader/index.js +8 -12
  525. package/lib/tntd-cascader/rc-cascader/Cascader.js +284 -325
  526. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +41 -30
  527. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +152 -198
  528. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +163 -223
  529. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +48 -40
  530. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +166 -179
  531. package/lib/tntd-cascader/rc-cascader/context.js +27 -11
  532. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +63 -62
  533. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +49 -39
  534. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +41 -26
  535. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +33 -16
  536. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +51 -30
  537. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +65 -75
  538. package/lib/tntd-cascader/rc-cascader/index.js +7 -9
  539. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +38 -49
  540. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +39 -42
  541. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +30 -34
  542. package/lib/tntd-form/TntdForm/components/Item.d.ts.map +1 -1
  543. package/lib/tntd-form/TntdForm/components/Item.js +63 -42
  544. package/lib/tntd-form/TntdForm/components/Item.js.map +1 -1
  545. package/lib/tntd-form/TntdForm/components/ItemComp.d.ts.map +1 -1
  546. package/lib/tntd-form/TntdForm/components/ItemComp.js +194 -161
  547. package/lib/tntd-form/TntdForm/components/ItemComp.js.map +1 -1
  548. package/lib/tntd-form/TntdForm/components/List.d.ts.map +1 -1
  549. package/lib/tntd-form/TntdForm/components/List.js +111 -91
  550. package/lib/tntd-form/TntdForm/components/List.js.map +1 -1
  551. package/lib/tntd-form/TntdForm/index.d.ts.map +1 -1
  552. package/lib/tntd-form/TntdForm/index.js +74 -66
  553. package/lib/tntd-form/TntdForm/index.js.map +1 -1
  554. package/lib/tntd-form/TntdForm/interface.d.ts +10 -8
  555. package/lib/tntd-form/TntdForm/interface.d.ts.map +1 -1
  556. package/lib/tntd-form/TntdForm/interface.js +2 -4
  557. package/lib/tntd-form/TntdForm/interface.js.map +1 -1
  558. package/lib/tntd-form/TntdForm/store.js +7 -8
  559. package/lib/tntd-form/TntdForm/utils.js +184 -182
  560. package/lib/tntd-form/index.js +8 -12
  561. package/lib/tntd-icon/fonts/iconfont.js +53 -36
  562. package/lib/tntd-icon/index.js +25 -40
  563. package/lib/tntd-layout/ActionsContext.js +4 -8
  564. package/lib/tntd-layout/AppList.js +224 -173
  565. package/lib/tntd-layout/Application.js +111 -75
  566. package/lib/tntd-layout/Avatar.js +135 -100
  567. package/lib/tntd-layout/CompatibleLanguage.js +180 -128
  568. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +146 -117
  569. package/lib/tntd-layout/EnterpriseLayout/Language.js +90 -73
  570. package/lib/tntd-layout/EnterpriseLayout/Theme.js +102 -69
  571. package/lib/tntd-layout/EnterpriseLayout/index.js +17 -28
  572. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +277 -284
  573. package/lib/tntd-layout/GlobalNavigation/index.js +115 -108
  574. package/lib/tntd-layout/Header.js +136 -77
  575. package/lib/tntd-layout/HeaderActions.js +106 -105
  576. package/lib/tntd-layout/HeaderNavs.js +107 -78
  577. package/lib/tntd-layout/HeaderTabs.js +316 -224
  578. package/lib/tntd-layout/Iconfont.js +7 -11
  579. package/lib/tntd-layout/Language.js +76 -69
  580. package/lib/tntd-layout/Layout.js +171 -214
  581. package/lib/tntd-layout/Logo.js +144 -69
  582. package/lib/tntd-layout/OrgAppList.js +388 -238
  583. package/lib/tntd-layout/SideMenu.js +408 -269
  584. package/lib/tntd-layout/Theme.js +93 -75
  585. package/lib/tntd-layout/createActions.js +34 -45
  586. package/lib/tntd-layout/images/avatar/empty.png +0 -0
  587. package/lib/tntd-layout/images/avatar/female1.png +0 -0
  588. package/lib/tntd-layout/images/avatar/female2.png +0 -0
  589. package/lib/tntd-layout/images/avatar/female3.png +0 -0
  590. package/lib/tntd-layout/images/avatar/female4.png +0 -0
  591. package/lib/tntd-layout/images/avatar/female5.png +0 -0
  592. package/lib/tntd-layout/images/avatar/female6.png +0 -0
  593. package/lib/tntd-layout/images/avatar/male1.png +0 -0
  594. package/lib/tntd-layout/images/avatar/male2.png +0 -0
  595. package/lib/tntd-layout/images/avatar/male3.png +0 -0
  596. package/lib/tntd-layout/images/avatar/male4.png +0 -0
  597. package/lib/tntd-layout/images/avatar/male5.png +0 -0
  598. package/lib/tntd-layout/images/avatar/male6.png +0 -0
  599. package/lib/tntd-layout/images/index.js +66 -68
  600. package/lib/tntd-layout/index.js +95 -137
  601. package/lib/tntd-layout/paaslayout/CompactSideMenu.js +182 -131
  602. package/lib/tntd-layout/paaslayout/Header.js +79 -51
  603. package/lib/tntd-layout/paaslayout/Logo.js +30 -15
  604. package/lib/tntd-layout/paaslayout/SideMenu.js +147 -131
  605. package/lib/tntd-layout/paaslayout/index.js +141 -205
  606. package/lib/tntd-layout/storage.js +30 -58
  607. package/lib/tntd-layout/tntdLayout.stories.d.ts +5 -0
  608. package/lib/tntd-layout/tntdLayout.stories.d.ts.map +1 -0
  609. package/lib/tntd-layout/tntdLayout.stories.js +304 -0
  610. package/lib/tntd-layout/tntdLayout.stories.js.map +1 -0
  611. package/lib/tntd-modal/index.js +62 -98
  612. package/lib/tntd-second-page/index.js +33 -60
  613. package/lib/tntd-second-page/index.js.map +1 -1
  614. package/lib/tntd-second-page/index.less +2 -2
  615. package/lib/tntd-select/DropDownWrap.js +78 -102
  616. package/lib/tntd-select/index.d.ts +1 -1
  617. package/lib/tntd-select/index.js +519 -607
  618. package/lib/tooltip/index.d.ts +3 -3
  619. package/lib/tooltip/index.js +22 -23
  620. package/lib/tooltip/index.js.map +1 -1
  621. package/lib/transfer/index.d.ts +3 -3
  622. package/lib/transfer/index.js +22 -23
  623. package/lib/transfer/index.js.map +1 -1
  624. package/lib/tree/index.d.ts +3 -3
  625. package/lib/tree/index.js +22 -23
  626. package/lib/tree/index.js.map +1 -1
  627. package/lib/tree-select/index.d.ts +3 -3
  628. package/lib/tree-select/index.js +22 -23
  629. package/lib/tree-select/index.js.map +1 -1
  630. package/lib/typography/index.d.ts +3 -3
  631. package/lib/typography/index.js +22 -23
  632. package/lib/typography/index.js.map +1 -1
  633. package/lib/upload/index.d.ts +3 -3
  634. package/lib/upload/index.js +22 -23
  635. package/lib/upload/index.js.map +1 -1
  636. package/lib/utils/checkAuth.js +23 -34
  637. package/lib/utils/findMenuInfoByPath.js +34 -41
  638. package/lib/utils/index.js +80 -117
  639. package/lib/version/index.d.ts +3 -3
  640. package/lib/version/index.js +22 -23
  641. package/lib/version/index.js.map +1 -1
  642. package/package.json +1 -1
  643. package/es/tntd-form/CustomForm/components/Item.js +0 -40
  644. package/es/tntd-form/CustomForm/components/Item.js.map +0 -1
  645. package/es/tntd-form/CustomForm/components/ItemComp.js +0 -149
  646. package/es/tntd-form/CustomForm/components/ItemComp.js.map +0 -1
  647. package/es/tntd-form/CustomForm/components/List.js +0 -75
  648. package/es/tntd-form/CustomForm/components/List.js.map +0 -1
  649. package/es/tntd-form/CustomForm/index.js +0 -48
  650. package/es/tntd-form/CustomForm/index.js.map +0 -1
  651. package/es/tntd-form/CustomForm/interface.js +0 -1
  652. package/es/tntd-form/CustomForm/interface.js.map +0 -1
  653. package/es/tntd-form/CustomForm/store.js +0 -2
  654. package/es/tntd-form/CustomForm/store.js.map +0 -1
  655. package/es/tntd-form/CustomForm/utils.js +0 -215
  656. package/es/tntd-form/CustomForm/utils.js.map +0 -1
  657. package/lib/tntd-form/CustomForm/components/Item.d.ts +0 -5
  658. package/lib/tntd-form/CustomForm/components/Item.d.ts.map +0 -1
  659. package/lib/tntd-form/CustomForm/components/Item.js +0 -50
  660. package/lib/tntd-form/CustomForm/components/Item.js.map +0 -1
  661. package/lib/tntd-form/CustomForm/components/ItemComp.d.ts +0 -5
  662. package/lib/tntd-form/CustomForm/components/ItemComp.d.ts.map +0 -1
  663. package/lib/tntd-form/CustomForm/components/ItemComp.js +0 -169
  664. package/lib/tntd-form/CustomForm/components/ItemComp.js.map +0 -1
  665. package/lib/tntd-form/CustomForm/components/List.d.ts +0 -5
  666. package/lib/tntd-form/CustomForm/components/List.d.ts.map +0 -1
  667. package/lib/tntd-form/CustomForm/components/List.js +0 -96
  668. package/lib/tntd-form/CustomForm/components/List.js.map +0 -1
  669. package/lib/tntd-form/CustomForm/index.d.ts +0 -10
  670. package/lib/tntd-form/CustomForm/index.d.ts.map +0 -1
  671. package/lib/tntd-form/CustomForm/index.js +0 -66
  672. package/lib/tntd-form/CustomForm/index.js.map +0 -1
  673. package/lib/tntd-form/CustomForm/interface.d.ts +0 -88
  674. package/lib/tntd-form/CustomForm/interface.d.ts.map +0 -1
  675. package/lib/tntd-form/CustomForm/interface.js +0 -5
  676. package/lib/tntd-form/CustomForm/interface.js.map +0 -1
  677. package/lib/tntd-form/CustomForm/store.d.ts +0 -4
  678. package/lib/tntd-form/CustomForm/store.d.ts.map +0 -1
  679. package/lib/tntd-form/CustomForm/store.js +0 -10
  680. package/lib/tntd-form/CustomForm/store.js.map +0 -1
  681. package/lib/tntd-form/CustomForm/utils.d.ts +0 -48
  682. package/lib/tntd-form/CustomForm/utils.d.ts.map +0 -1
  683. package/lib/tntd-form/CustomForm/utils.js +0 -235
  684. package/lib/tntd-form/CustomForm/utils.js.map +0 -1
@@ -1,149 +1,177 @@
1
- import _isEqual from "lodash/isEqual";
2
1
  /*
3
2
  * @Descripttion: TntdForm.Item进行性能优化
4
3
  * @Author: 郑泳健
5
4
  * @Date: 2023-02-23 12:47:28
6
5
  * @LastEditors: 郑泳健
7
- * @LastEditTime: 2023-03-17 18:27:03
6
+ * @LastEditTime: 2023-04-06 17:45:35
8
7
  */
9
- import React, { useState, memo, useEffect } from 'react';
8
+ import React, { useState, memo, useEffect, useImperativeHandle } from 'react';
10
9
  import { getNames, handleCheckItem, getInitValue } from '../utils';
11
- const ItemComp = ({
12
- form,
13
- name,
14
- children,
15
- style,
16
- initialValues,
17
- initialValue,
18
- rules,
19
- setCurrentChangeKeys
20
- }) => {
21
- const [value, setValue] = useState(undefined);
22
- const [errorMsg, setErrorMsg] = useState(undefined);
23
- /**
24
- * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的
25
- * @param name
26
- * @param value
27
- * @returns
28
- */
29
- const generateFormData = (name, value) => {
30
- if (!name || !form) return;
31
- const [str, ...rest] = name;
32
- rest.forEach(i => {
33
- if (form.formData[str]) {
34
- form.formData[str][i].value = value;
35
- form.formData[str][i].checkItem = () => {
36
- const error = handleCheckItem(value, rules);
37
- setErrorMsg(error);
38
- return error;
39
- };
40
- } else {
41
- form.formData[str] = {
42
- [i]: {
43
- value,
10
+ const ItemComp = React.forwardRef(({ name, children, style, initialValue, rules, shouldUpdate, dependencies, form, updateRefs, initialValues, compsRefs, }, ref) => {
11
+ const [value, setValue] = useState(undefined);
12
+ const [errorMsg, setErrorMsg] = useState(undefined);
13
+ const [refresh, setRefresh] = useState(false);
14
+ useImperativeHandle(ref, () => ({
15
+ onRefresh: () => {
16
+ setRefresh(!refresh);
17
+ },
18
+ }));
19
+ /** 根据shouldUpdate 和 dependencies收集修改某个字段后需要同步更新的字段 */
20
+ useEffect(() => {
21
+ var _a;
22
+ const nameStr = (_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.');
23
+ if (shouldUpdate) {
24
+ updateRefs.current.shouldUpdateList.push(nameStr);
25
+ }
26
+ if (Array.isArray(dependencies)) {
27
+ const arr = dependencies.map((i) => getNames(i).join('.'));
28
+ if (Array.isArray(arr)) {
29
+ arr.forEach((i) => {
30
+ if (Array.isArray(updateRefs.current.dependencies[i])) {
31
+ updateRefs.current.dependencies[i] = [
32
+ ...updateRefs.current.dependencies[i],
33
+ getNames(name).join('.'),
34
+ ];
35
+ }
36
+ else {
37
+ updateRefs.current.dependencies[i] = [getNames(name).join('.')];
38
+ }
39
+ });
40
+ }
41
+ }
42
+ }, [shouldUpdate, dependencies, name, updateRefs]);
43
+ const updateRender = () => {
44
+ if (Array.isArray(updateRefs.current.shouldUpdateList)) {
45
+ updateRefs.current.shouldUpdateList.forEach((i) => {
46
+ var _a, _b;
47
+ (_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);
48
+ });
49
+ }
50
+ const list = updateRefs.current.dependencies[getNames(name).join('.')];
51
+ if (Array.isArray(list)) {
52
+ list.forEach((i) => {
53
+ var _a, _b;
54
+ (_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);
55
+ });
56
+ }
57
+ };
58
+ /**
59
+ * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的
60
+ * @param name
61
+ * @param value
62
+ * @returns
63
+ */
64
+ const generateFormData = (name, value) => {
65
+ if (!name || !form || typeof name !== 'object')
66
+ return;
67
+ const [str, ...rest] = name;
68
+ rest.forEach((i) => {
69
+ if (form.formData[str]) {
70
+ form.formData[str][i].value = value;
71
+ form.formData[str][i].checkItem = () => {
72
+ const error = handleCheckItem(value, rules);
73
+ setErrorMsg(error);
74
+ return error;
75
+ };
76
+ }
77
+ else {
78
+ form.formData[str] = {
79
+ [i]: {
80
+ value,
81
+ checkItem: () => {
82
+ const error = handleCheckItem(value, rules);
83
+ setErrorMsg(error);
84
+ return error;
85
+ },
86
+ setItemValue: () => { },
87
+ errorMsg: undefined,
88
+ },
89
+ };
90
+ }
91
+ });
92
+ };
93
+ // 为了给最外层提供方法去校验,比如保存的时候.
94
+ // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的
95
+ useEffect(() => {
96
+ if (!name || !form || typeof name !== 'object')
97
+ return;
98
+ const [str, ...rest] = name;
99
+ const addItem = {
100
+ setItemValue: (_val, callback) => {
101
+ const error = handleCheckItem(_val, rules);
102
+ setValue(_val);
103
+ setErrorMsg(error);
104
+ callback === null || callback === void 0 ? void 0 : callback();
105
+ updateRender();
106
+ },
44
107
  checkItem: () => {
45
- const error = handleCheckItem(value, rules);
46
- setErrorMsg(error);
47
- return error;
108
+ const error = handleCheckItem(value, rules);
109
+ setErrorMsg(error);
110
+ return error;
48
111
  },
49
- setItemValue: () => {},
50
- errorMsg: undefined
51
- }
112
+ value,
113
+ errorMsg,
52
114
  };
53
- }
54
- });
55
- };
56
- // 为了给最外层提供方法去校验,比如保存的时候.
57
- // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的
58
- useEffect(() => {
59
- if (!name || !form) return;
60
- const [str, ...rest] = name;
61
- const addItem = {
62
- setItemValue: (_val, callback) => {
63
- const error = handleCheckItem(_val, rules);
64
- setValue(_val);
65
- setErrorMsg(error);
66
- callback === null || callback === void 0 ? void 0 : callback();
67
- },
68
- checkItem: () => {
69
- const error = handleCheckItem(value, rules);
115
+ rest.forEach((i) => {
116
+ if (form.formData[str]) {
117
+ form.formData[str][i] = addItem;
118
+ }
119
+ else {
120
+ form.formData[str] = {
121
+ [i]: addItem,
122
+ };
123
+ }
124
+ });
125
+ }, [rules, name, errorMsg, form]);
126
+ /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */
127
+ useEffect(() => {
128
+ if (initialValue) {
129
+ setValue(initialValue);
130
+ generateFormData(name, initialValue);
131
+ updateRender();
132
+ }
133
+ }, [initialValue]);
134
+ // 初始化设置默认值,
135
+ useEffect(() => {
136
+ const initValue = getInitValue(initialValues, name);
137
+ // @ts-ignore
138
+ const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue;
139
+ setValue(_value);
140
+ generateFormData(name, _value);
141
+ updateRender();
142
+ }, []);
143
+ // 默认方法
144
+ const handleChange = (e) => {
145
+ var _a;
146
+ let val;
147
+ if (typeof e === 'object') {
148
+ val = (_a = e === null || e === void 0 ? void 0 : e.target) === null || _a === void 0 ? void 0 : _a.value;
149
+ }
150
+ else {
151
+ val = e;
152
+ }
153
+ setValue(val);
154
+ generateFormData(name, val);
155
+ const error = handleCheckItem(val, rules);
70
156
  setErrorMsg(error);
71
- return error;
72
- },
73
- value,
74
- errorMsg
157
+ updateRender();
75
158
  };
76
- rest.forEach(i => {
77
- if (form.formData[str]) {
78
- form.formData[str][i] = addItem;
79
- } else {
80
- form.formData[str] = {
81
- [i]: addItem
82
- };
83
- }
84
- });
85
- }, [rules, name, errorMsg, form]);
86
- /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */
87
- useEffect(() => {
88
- if (initialValue) {
89
- setValue(initialValue);
90
- generateFormData(name, initialValue);
91
- }
92
- }, [initialValue]);
93
- // 初始化设置默认值,
94
- useEffect(() => {
95
- var _a;
96
- const initValue = getInitValue(initialValues, name);
97
- // @ts-ignore
98
- const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue;
99
- setValue(_value);
100
- generateFormData(name, _value);
101
- if (name) {
102
- setCurrentChangeKeys([(_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.')]);
103
- }
104
- }, []);
105
- // 默认方法
106
- const handleChange = e => {
107
- var _a, _b;
108
- let val;
109
- if (typeof e === 'object') {
110
- val = (_a = e === null || e === void 0 ? void 0 : e.target) === null || _a === void 0 ? void 0 : _a.value;
111
- } else {
112
- val = e;
113
- }
114
- setValue(val);
115
- generateFormData(name, val);
116
- const error = handleCheckItem(val, rules);
117
- setErrorMsg(error);
118
- if (name) {
119
- setCurrentChangeKeys([(_b = getNames(name)) === null || _b === void 0 ? void 0 : _b.join('.')]);
120
- }
121
- };
122
- return React.createElement("div", {
123
- className: errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper',
124
- style: style
125
- }, React.Children.map(children, child => {
126
- var _a;
127
- if (React.isValidElement(child)) {
128
- return React.cloneElement(child, Object.assign({
129
- value,
130
- form,
131
- onChange: handleChange,
132
- 'data-key': (_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.')
133
- }, child.props));
134
- }
135
- return null;
136
- }), errorMsg && React.createElement("div", {
137
- className: "ant-form-explain ant-form-item-explain-error"
138
- }, errorMsg));
139
- };
159
+ return (React.createElement("div", { className: errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper', style: style },
160
+ React.Children.map(children, (child) => {
161
+ var _a;
162
+ if (React.isValidElement(child)) {
163
+ return React.cloneElement(child, Object.assign({ value,
164
+ form, onChange: handleChange, 'data-key': (_a = getNames(name)) === null || _a === void 0 ? void 0 : _a.join('.') }, child.props));
165
+ }
166
+ return null;
167
+ }),
168
+ errorMsg && React.createElement("div", { className: "ant-form-explain ant-form-item-explain-error" }, errorMsg)));
169
+ });
140
170
  function arePropsEqual(prevProps, nextProps) {
141
- if (Array.isArray(nextProps.currentChangeKeys) && nextProps.currentChangeKeys.length && _isEqual(prevProps.initialValues, nextProps.initialValues) && !nextProps.currentChangeKeys.includes(getNames(nextProps.name).join('.')) && !nextProps.shouldUpdate && Array.isArray(nextProps.dependencies) && nextProps.dependencies.every(i => {
142
- var _a;
143
- return !((_a = nextProps.currentChangeKeys) === null || _a === void 0 ? void 0 : _a.includes(getNames(i).join('.')));
144
- })) {
145
- return true;
146
- }
147
- return false;
171
+ if (!nextProps.shouldUpdate && Array.isArray(nextProps.dependencies)) {
172
+ return true;
173
+ }
174
+ return false;
148
175
  }
149
- export default memo(ItemComp, arePropsEqual);
176
+ export default memo(ItemComp);
177
+ //# sourceMappingURL=ItemComp.js.map
@@ -1 +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-03-17 18:27:03\n */\n\nimport React, { useState, memo, useEffect } from 'react'\nimport { isEqual } from 'lodash'\nimport { getNames, handleCheckItem, getInitValue } from '../utils'\nimport type { IFormItem, IFormItemData, TinitialValueType } from '../interface'\n\nconst ItemComp: React.FC<IFormItem> = ({\n form,\n name,\n children,\n style,\n initialValues,\n initialValue,\n rules,\n setCurrentChangeKeys,\n}) => {\n const [value, setValue] = useState<TinitialValueType>(undefined)\n const [errorMsg, setErrorMsg] = useState<string | undefined>(undefined)\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) 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) 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 },\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 }\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 if (name) {\n setCurrentChangeKeys([getNames(name)?.join('.')])\n }\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 if (name) {\n setCurrentChangeKeys([getNames(name)?.join('.')])\n }\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\nfunction arePropsEqual(prevProps: IFormItem, nextProps: IFormItem) {\n if (\n Array.isArray(nextProps.currentChangeKeys) &&\n nextProps.currentChangeKeys.length &&\n isEqual(prevProps.initialValues, nextProps.initialValues) &&\n !nextProps.currentChangeKeys.includes(getNames(nextProps.name).join('.')) &&\n !nextProps.shouldUpdate &&\n Array.isArray(nextProps.dependencies) &&\n nextProps.dependencies.every(\n (i) => !nextProps.currentChangeKeys?.includes(getNames(i).join('.'))\n )\n ) {\n return true\n }\n return false\n}\n\nexport default memo(ItemComp, arePropsEqual)\n"]}
1
+ {"version":3,"file":"ItemComp.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/ItemComp.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,OAAO,CAAA;AAC7E,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAGlE,MAAM,QAAQ,GAAwB,KAAK,CAAC,UAAU,CACpD,CACE,EACE,IAAI,EACJ,QAAQ,EACR,KAAK,EACL,YAAY,EACZ,KAAK,EACL,YAAY,EACZ,YAAY,EACZ,IAAI,EACJ,UAAU,EACV,aAAa,EACb,SAAS,GACV,EACD,GAAG,EACH,EAAE;IACF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAoB,SAAS,CAAC,CAAA;IAChE,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAqB,SAAS,CAAC,CAAA;IACvE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAA;IAEtD,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QAC9B,SAAS,EAAE,GAAG,EAAE;YACd,UAAU,CAAC,CAAC,OAAO,CAAC,CAAA;QACtB,CAAC;KACF,CAAC,CAAC,CAAA;IAEH,sDAAsD;IACtD,SAAS,CAAC,GAAG,EAAE;;QACb,MAAM,OAAO,GAAG,MAAA,QAAQ,CAAC,IAAI,CAAC,0CAAE,IAAI,CAAC,GAAG,CAAC,CAAA;QACzC,IAAI,YAAY,EAAE;YAChB,UAAU,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;SAClD;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;YAC/B,MAAM,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;YAC1D,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACtB,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBAChB,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE;wBACrD,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG;4BACnC,GAAG,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;4BACrC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;yBACzB,CAAA;qBACF;yBAAM;wBACL,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;qBAChE;gBACH,CAAC,CAAC,CAAA;aACH;SACF;IACH,CAAC,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC,CAAA;IAElD,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE;YACtD,UAAU,CAAC,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;;gBAChD,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,0CAAG,CAAC,CAAC,kDAAI,CAAA;YAC7B,CAAC,CAAC,CAAA;SACH;QACD,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;QAEtE,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACvB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;;gBACjB,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,0CAAG,CAAC,CAAC,kDAAI,CAAA;YAC7B,CAAC,CAAC,CAAA;SACH;IACH,CAAC,CAAA;IAED;;;;;OAKG;IACH,MAAM,gBAAgB,GAAG,CAAC,IAAuB,EAAE,KAAwB,EAAE,EAAE;QAC7E,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ;YAAE,OAAM;QACtD,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,CAAA;QAE3B,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBACtB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAA;gBACnC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,GAAG,EAAE;oBACrC,MAAM,KAAK,GAAG,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;oBAC3C,WAAW,CAAC,KAAK,CAAC,CAAA;oBAClB,OAAO,KAAK,CAAA;gBACd,CAAC,CAAA;aACF;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG;oBACnB,CAAC,CAAC,CAAC,EAAE;wBACH,KAAK;wBACL,SAAS,EAAE,GAAG,EAAE;4BACd,MAAM,KAAK,GAAG,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;4BAC3C,WAAW,CAAC,KAAK,CAAC,CAAA;4BAClB,OAAO,KAAK,CAAA;wBACd,CAAC;wBACD,YAAY,EAAE,GAAG,EAAE,GAAE,CAAC;wBACtB,QAAQ,EAAE,SAAS;qBACpB;iBACF,CAAA;aACF;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAA;IAED,yBAAyB;IACzB,uFAAuF;IACvF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ;YAAE,OAAM;QACtD,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,CAAA;QAE3B,MAAM,OAAO,GAAkB;YAC7B,YAAY,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;gBAC/B,MAAM,KAAK,GAAG,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;gBAC1C,QAAQ,CAAC,IAAI,CAAC,CAAA;gBACd,WAAW,CAAC,KAAK,CAAC,CAAA;gBAClB,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,EAAI,CAAA;gBACZ,YAAY,EAAE,CAAA;YAChB,CAAC;YACD,SAAS,EAAE,GAAG,EAAE;gBACd,MAAM,KAAK,GAAG,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;gBAC3C,WAAW,CAAC,KAAK,CAAC,CAAA;gBAClB,OAAO,KAAK,CAAA;YACd,CAAC;YACD,KAAK;YACL,QAAQ;SACT,CAAA;QACD,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBACtB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAA;aAChC;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG;oBACnB,CAAC,CAAC,CAAC,EAAE,OAAO;iBACb,CAAA;aACF;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAA;IAEjC,mCAAmC;IACnC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,YAAY,EAAE;YAChB,QAAQ,CAAC,YAAY,CAAC,CAAA;YACtB,gBAAgB,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;YACpC,YAAY,EAAE,CAAA;SACf;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;IAElB,YAAY;IACZ,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,SAAS,GAAG,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,CAAA;QACnD,aAAa;QACb,MAAM,MAAM,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAA;QAEnF,QAAQ,CAAC,MAAM,CAAC,CAAA;QAChB,gBAAgB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;QAC9B,YAAY,EAAE,CAAA;IAChB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO;IACP,MAAM,YAAY,GAAG,CACnB,CAIa,EACb,EAAE;;QACF,IAAI,GAAG,CAAA;QACP,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;YACzB,GAAG,GAAG,MAAC,CAAmF,aAAnF,CAAC,uBAAD,CAAC,CACJ,MAAM,0CAAE,KAAK,CAAA;SAClB;aAAM;YACL,GAAG,GAAG,CAAC,CAAA;SACR;QACD,QAAQ,CAAC,GAAG,CAAC,CAAA;QACb,gBAAgB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;QAC3B,MAAM,KAAK,GAAG,eAAe,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;QACzC,WAAW,CAAC,KAAK,CAAC,CAAA;QAClB,YAAY,EAAE,CAAA;IAChB,CAAC,CAAA;IAED,OAAO,CACL,6BACE,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,oCAAoC,CAAC,CAAC,CAAC,0BAA0B,EACvF,KAAK,EAAE,KAAK;QAEX,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;;YACtC,IAAI,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;gBAC/B,OAAO,KAAK,CAAC,YAAY,CAAC,KAAK,kBAC7B,KAAK;oBACL,IAAI,EACJ,QAAQ,EAAE,YAAY,EACtB,UAAU,EAAE,MAAA,QAAQ,CAAC,IAAI,CAAC,0CAAE,IAAI,CAAC,GAAG,CAAC,IAClC,KAAK,CAAC,KAAK,EACd,CAAA;aACH;YACD,OAAO,IAAI,CAAA;QACb,CAAC,CAAC;QACD,QAAQ,IAAI,6BAAK,SAAS,EAAC,8CAA8C,IAAE,QAAQ,CAAO,CACvF,CACP,CAAA;AACH,CAAC,CACF,CAAA;AAED,SAAS,aAAa,CAAC,SAAoB,EAAE,SAAoB;IAC/D,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE;QACpE,OAAO,IAAI,CAAA;KACZ;IAED,OAAO,KAAK,CAAA;AACd,CAAC;AAED,eAAe,IAAI,CAAC,QAAQ,CAAC,CAAA","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"]}
@@ -1,75 +1,91 @@
1
- import _isEqual from "lodash/isEqual";
2
- import _cloneDeep from "lodash/cloneDeep";
3
1
  /*
4
2
  * @Descripttion: FormList
5
3
  * @Author: 郑泳健
6
4
  * @Date: 2023-03-06 18:42:08
7
5
  * @LastEditors: 郑泳健
8
- * @LastEditTime: 2023-03-17 18:47:05
6
+ * @LastEditTime: 2023-04-06 17:42:31
9
7
  */
10
8
  import React, { useState, useEffect, useRef, useContext, memo } from 'react';
9
+ import { cloneDeep, isEqual } from 'lodash';
11
10
  import { getNames } from '../utils';
12
11
  import { FormContext } from '../store';
13
- const List = ({
14
- name,
15
- children
16
- }) => {
17
- const maxRef = useRef(-1);
18
- const {
19
- form,
20
- initialValues
21
- } = useContext(FormContext);
22
- const [dataLevel, setDataLevel] = useState([]);
23
- useEffect(() => {
24
- const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
25
- if (form && form.dataLevel) {
26
- form.dataLevel[key] = dataLevel;
27
- }
28
- }, [form, dataLevel, name]);
29
- /** 根据默认数值自动生成dataLevel */
30
- useEffect(() => {
31
- let dataSource = initialValues;
32
- const attrs = getNames(name);
33
- for (const key of attrs) {
34
- dataSource = (dataSource === null || dataSource === void 0 ? void 0 : dataSource[key]) || [{}];
35
- }
36
- if (Array.isArray(dataSource)) {
37
- const _level = dataSource.map((i, index) => {
38
- return {
39
- key: index,
40
- name: `${attrs.join('.')}.${index}`
41
- };
42
- });
43
- setDataLevel(_level);
44
- maxRef.current = dataSource.length - 1;
45
- }
46
- }, [initialValues, name]);
47
- /** 新增一列 */
48
- const handleAdd = index => {
49
- const tempDataLevel = _cloneDeep(dataLevel);
50
- maxRef.current++;
51
- const attrs = getNames(name);
52
- tempDataLevel.splice(index + 1, 0, {
53
- key: maxRef.current,
54
- name: `${attrs === null || attrs === void 0 ? void 0 : attrs.join('.')}.${maxRef.current}`
55
- });
56
- setDataLevel(tempDataLevel);
57
- };
58
- /** 删除一列 */
59
- const handleDel = index => {
60
- const temp = _cloneDeep(dataLevel);
61
- temp.splice(index, 1);
62
- setDataLevel(temp);
63
- };
64
- return React.createElement(React.Fragment, null, children === null || children === void 0 ? void 0 : children(dataLevel, {
65
- add: handleAdd,
66
- remove: handleDel
67
- }));
12
+ const List = ({ name, children }) => {
13
+ const maxRef = useRef(-1);
14
+ const { form, initialValues, compsRefs, updateRefs } = useContext(FormContext);
15
+ const [dataLevel, setDataLevel] = useState([]);
16
+ /** 根据一开始记录的渲染shouldUpdate dependencies组件 */
17
+ const updateRender = () => {
18
+ if (Array.isArray(updateRefs.current.shouldUpdateList)) {
19
+ updateRefs.current.shouldUpdateList.forEach((i) => {
20
+ var _a, _b;
21
+ (_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);
22
+ });
23
+ }
24
+ const list = updateRefs.current.dependencies[getNames(name).join('.')];
25
+ if (Array.isArray(list)) {
26
+ list.forEach((i) => {
27
+ var _a, _b;
28
+ (_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);
29
+ });
30
+ }
31
+ };
32
+ /** 根据默认数值自动生成dataLevel */
33
+ useEffect(() => {
34
+ let dataSource = initialValues;
35
+ const attrs = getNames(name);
36
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
37
+ for (const key of attrs) {
38
+ dataSource = (dataSource === null || dataSource === void 0 ? void 0 : dataSource[key]) || [{}];
39
+ }
40
+ if (Array.isArray(dataSource)) {
41
+ const _level = dataSource.map((i, index) => {
42
+ return {
43
+ key: index,
44
+ name: `${attrs.join('.')}.${index}`,
45
+ };
46
+ });
47
+ setDataLevel(_level);
48
+ maxRef.current = dataSource.length - 1;
49
+ if (form) {
50
+ form.dataLevel[key] = _level;
51
+ }
52
+ updateRender();
53
+ }
54
+ }, [form, initialValues, name]);
55
+ /** 新增一列 */
56
+ const handleAdd = (index) => {
57
+ const tempDataLevel = cloneDeep(dataLevel);
58
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
59
+ maxRef.current++;
60
+ const attrs = getNames(name);
61
+ tempDataLevel.splice(index + 1, 0, {
62
+ key: maxRef.current,
63
+ name: `${attrs === null || attrs === void 0 ? void 0 : attrs.join('.')}.${maxRef.current}`,
64
+ });
65
+ setDataLevel(tempDataLevel);
66
+ if (form) {
67
+ form.dataLevel[key] = tempDataLevel;
68
+ }
69
+ updateRender();
70
+ };
71
+ /** 删除一列 */
72
+ const handleDel = (index) => {
73
+ const temp = cloneDeep(dataLevel);
74
+ const key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
75
+ temp.splice(index, 1);
76
+ setDataLevel(temp);
77
+ if (form) {
78
+ form.dataLevel[key] = temp;
79
+ }
80
+ updateRender();
81
+ };
82
+ return React.createElement(React.Fragment, null, children === null || children === void 0 ? void 0 : children(dataLevel, { add: handleAdd, remove: handleDel }));
68
83
  };
69
84
  // name 没有改变就不需要重复render
70
85
  export default memo(List, (nextProps, prevProps) => {
71
- if (_isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {
72
- return true;
73
- }
74
- return false;
75
- });
86
+ if (isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {
87
+ return true;
88
+ }
89
+ return false;
90
+ });
91
+ //# sourceMappingURL=List.js.map
@@ -1 +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-03-17 18:47:05\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 } = useContext<IFormContext>(FormContext)\n const [dataLevel, setDataLevel] = useState<ILevel[]>([])\n\n useEffect(() => {\n const key: string = Array.isArray(name) ? name?.[0] : name\n if (form && form.dataLevel) {\n form.dataLevel[key] = dataLevel\n }\n }, [form, dataLevel, name])\n\n /** 根据默认数值自动生成dataLevel */\n useEffect(() => {\n let dataSource = initialValues\n const attrs = getNames(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 }\n }, [initialValues, name])\n\n /** 新增一列 */\n const handleAdd: TAddOrRemove = (index) => {\n const tempDataLevel = cloneDeep(dataLevel)\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 }\n\n /** 删除一列 */\n const handleDel: TAddOrRemove = (index) => {\n const temp = cloneDeep(dataLevel)\n temp.splice(index, 1)\n setDataLevel(temp)\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"]}
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"]}
@@ -3,50 +3,48 @@
3
3
  * @Author: 郑泳健
4
4
  * @Date: 2023-02-16 10:43:03
5
5
  * @LastEditors: 郑泳健
6
- * @LastEditTime: 2023-03-20 10:27:35
6
+ * @LastEditTime: 2023-04-06 15:32:07
7
7
  */
8
- import React, { useState, useRef } from 'react';
8
+ import React, { useRef } from 'react';
9
9
  import { validateFields, getFieldsValue, getFieldValue } from './utils';
10
10
  import { FormContext } from './store';
11
11
  import List from './components/List';
12
12
  import Item from './components/Item';
13
- const TntdForm = ({
14
- form,
15
- initialValues,
16
- children
17
- }) => {
18
- // 这个是为了获取当前是哪一个单元格在输入
19
- const [currentChangeKeys, setCurrentChangeKeys] = useState([]);
20
- return React.createElement(FormContext.Provider, {
21
- value: {
22
- form,
23
- initialValues,
24
- currentChangeKeys,
25
- setCurrentChangeKeys
26
- }
27
- }, children);
13
+ const TntdForm = ({ form, initialValues, children }) => {
14
+ const updateRefs = useRef({
15
+ shouldUpdateList: [],
16
+ dependencies: {},
17
+ });
18
+ const compsRefs = useRef({});
19
+ return (React.createElement(FormContext.Provider, { value: {
20
+ form,
21
+ initialValues,
22
+ updateRefs,
23
+ compsRefs,
24
+ } }, children));
28
25
  };
29
26
  TntdForm.useForm = () => {
30
- const form = useRef({
31
- dataLevel: {},
32
- formData: {},
33
- validateFields: () => validateFields(form.current),
34
- getFieldsValue: () => getFieldsValue(form.current),
35
- getFieldValue: field => getFieldValue(form.current, field),
36
- setFieldsValue: obj => {
37
- for (const i in obj) {
38
- if (Object.prototype.hasOwnProperty.call(obj, i)) {
39
- const prefix = (i === null || i === void 0 ? void 0 : i.split('.')) || [];
40
- const attr = prefix.pop();
41
- if (attr && form.current.formData[prefix.join('.')][attr]) {
42
- form.current.formData[prefix.join('.')][attr].setItemValue(obj[i]);
43
- }
44
- }
45
- }
46
- }
47
- });
48
- return [form.current];
27
+ const form = useRef({
28
+ dataLevel: {},
29
+ formData: {},
30
+ validateFields: () => validateFields(form.current),
31
+ getFieldsValue: () => getFieldsValue(form.current),
32
+ getFieldValue: (field) => getFieldValue(form.current, field),
33
+ setFieldsValue: (obj) => {
34
+ for (const i in obj) {
35
+ if (Object.prototype.hasOwnProperty.call(obj, i)) {
36
+ const prefix = (i === null || i === void 0 ? void 0 : i.split('.')) || [];
37
+ const attr = prefix.pop();
38
+ if (attr && form.current.formData[prefix.join('.')][attr]) {
39
+ form.current.formData[prefix.join('.')][attr].setItemValue(obj[i]);
40
+ }
41
+ }
42
+ }
43
+ },
44
+ });
45
+ return [form.current];
49
46
  };
50
47
  TntdForm.List = List;
51
48
  TntdForm.Item = Item;
52
- export default TntdForm;
49
+ export default TntdForm;
50
+ //# sourceMappingURL=index.js.map