tntd 2.0.11 → 2.0.12

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 (716) hide show
  1. package/es/affix/index.js +1 -2
  2. package/es/alert/index.js +1 -2
  3. package/es/anchor/index.js +1 -2
  4. package/es/array-input/icon.js +24 -6
  5. package/es/array-input/index.js +228 -119
  6. package/es/auth-context/index.js +1 -2
  7. package/es/auto-complete/index.js +1 -2
  8. package/es/avatar/index.js +1 -2
  9. package/es/back-top/index.js +1 -2
  10. package/es/badge/index.js +1 -2
  11. package/es/breadcrumb/index.js +1 -2
  12. package/es/button/index.js +1 -2
  13. package/es/calendar/index.js +1 -2
  14. package/es/card/index.js +1 -2
  15. package/es/carousel/index.js +1 -2
  16. package/es/cascader/index.js +1 -2
  17. package/es/checkbox/index.js +1 -2
  18. package/es/col/index.js +1 -2
  19. package/es/collapse/index.js +1 -2
  20. package/es/columns/index.js +72 -30
  21. package/es/columns/style/index.js +1 -2
  22. package/es/comment/index.js +1 -2
  23. package/es/config-provider/config-provider.js +1 -2
  24. package/es/config-provider/index.js +1 -2
  25. package/es/date-picker/index.js +1 -2
  26. package/es/descriptions/index.js +1 -2
  27. package/es/development-login/LoginModal.js +89 -48
  28. package/es/development-login/index.js +17 -8
  29. package/es/divider/index.js +1 -2
  30. package/es/drawer/drawer.js +31 -20
  31. package/es/drawer/drawer.less +1 -1
  32. package/es/drawer/index.js +1 -2
  33. package/es/dropdown/index.js +1 -2
  34. package/es/ellipsis/Svg/CopySVG.js +63 -17
  35. package/es/ellipsis/Svg/TickSVG.js +41 -12
  36. package/es/ellipsis/index.js +111 -68
  37. package/es/empty/empty.js +65 -51
  38. package/es/empty/empty.stories.js +5 -6
  39. package/es/empty/index.js +1 -2
  40. package/es/exception/exception.js +32 -19
  41. package/es/exception/exception.less +1 -1
  42. package/es/exception/index.js +1 -2
  43. package/es/form/index.js +1 -2
  44. package/es/handle/index.js +120 -69
  45. package/es/icon/index.js +1 -2
  46. package/es/icon-list/index.js +1 -120
  47. package/es/img/Contain.js +66 -39
  48. package/es/img/Cover.js +109 -72
  49. package/es/img/index.js +55 -32
  50. package/es/index.js +2 -2
  51. package/es/input/index.js +1 -2
  52. package/es/input-number/index.js +1 -2
  53. package/es/layout/index.js +1 -2
  54. package/es/list/index.js +1 -2
  55. package/es/loading-button/index.js +40 -28
  56. package/es/locale/default.js +5 -4
  57. package/es/locale/en_US.js +31 -30
  58. package/es/locale/index.js +1 -2
  59. package/es/locale/zh_CN.js +31 -30
  60. package/es/locale-provider/index.js +1 -2
  61. package/es/mention/index.js +1 -2
  62. package/es/mentions/index.js +1 -2
  63. package/es/menu/index.js +1 -2
  64. package/es/message/index.js +1 -2
  65. package/es/modal/index.js +1 -2
  66. package/es/modal/modal.less +1 -1
  67. package/es/notification/index.js +1 -2
  68. package/es/page/Box.js +58 -33
  69. package/es/page/index.js +139 -88
  70. package/es/page/utils.js +17 -14
  71. package/es/page-header/index.js +1 -2
  72. package/es/pagination/index.js +1 -2
  73. package/es/popconfirm/index.js +1 -2
  74. package/es/popover/index.js +1 -2
  75. package/es/prev-locale.js +52 -47
  76. package/es/progress/index.js +1 -2
  77. package/es/query-form/Field/Checkbox.js +24 -17
  78. package/es/query-form/Field/Select.js +62 -40
  79. package/es/query-form/Field/SelectInput.js +77 -45
  80. package/es/query-form/Field/fieldsMap.js +20 -20
  81. package/es/query-form/Field/index.js +113 -66
  82. package/es/query-form/createActions.js +54 -46
  83. package/es/query-form/index.js +359 -247
  84. package/es/query-form/useForm.js +3 -4
  85. package/es/query-list-scene/List.js +343 -258
  86. package/es/query-list-scene/QueryForm.js +141 -95
  87. package/es/query-list-scene/QueryListScene.js +31 -21
  88. package/es/query-list-scene/Title.js +6 -4
  89. package/es/query-list-scene/Toolbar.js +25 -15
  90. package/es/query-list-scene/createActions.js +63 -60
  91. package/es/query-list-scene/index.js +1 -2
  92. package/es/query-list-scene/useActions.js +3 -4
  93. package/es/radio/index.js +1 -2
  94. package/es/rate/index.js +1 -2
  95. package/es/render-empty/index.js +1 -2
  96. package/es/render-empty/render-empty.js +21 -16
  97. package/es/result/index.js +1 -2
  98. package/es/row/index.js +1 -2
  99. package/es/select/index.js +1 -2
  100. package/es/skeleton/index.js +1 -2
  101. package/es/slider/index.js +1 -2
  102. package/es/spin/index.js +1 -2
  103. package/es/statistic/index.js +1 -2
  104. package/es/steps/index.js +1 -2
  105. package/es/steps/steps.js +59 -35
  106. package/es/steps/style/nav.less +3 -3
  107. package/es/svg-components/illustration-403.js +208 -58
  108. package/es/svg-components/illustration-404.js +292 -75
  109. package/es/svg-components/illustration-500.js +323 -83
  110. package/es/svg-components/illustration-empty.js +56 -15
  111. package/es/svg-components/illustration-failure.js +114 -36
  112. package/es/svg-components/illustration-no-access.js +116 -35
  113. package/es/svg-components/illustration-no-chart.js +136 -37
  114. package/es/svg-components/illustration-no-result.js +94 -32
  115. package/es/svg-components/illustration-offline.js +133 -43
  116. package/es/svg-components/illustration-success.js +139 -43
  117. package/es/svg-components/index.js +1 -2
  118. package/es/switch/index.js +1 -2
  119. package/es/table/assets/image-loading-background.js +47 -17
  120. package/es/table/assets/image-loading.js +28 -5
  121. package/es/table/constants.js +1 -2
  122. package/es/table/context.js +1 -2
  123. package/es/table/hooks/index.js +1 -2
  124. package/es/table/hooks/use-column-setting.js +14 -16
  125. package/es/table/index.js +1 -2
  126. package/es/table/table.js +75 -48
  127. package/es/table/table.stories.js +150 -139
  128. package/es/table/utils.js +21 -18
  129. package/es/tabs/index.js +1 -2
  130. package/es/tag/index.js +1 -2
  131. package/es/time-picker/index.js +1 -2
  132. package/es/timeline/index.js +1 -2
  133. package/es/title/index.js +38 -20
  134. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +9 -5
  135. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +1 -2
  136. package/es/tntd-cascader/AntdCascader/component/SizeContext.js +1 -2
  137. package/es/tntd-cascader/AntdCascader/component/context.js +9 -9
  138. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +24 -10
  139. package/es/tntd-cascader/AntdCascader/component/getIcons.js +81 -50
  140. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +22 -20
  141. package/es/tntd-cascader/AntdCascader/config/utils.js +19 -18
  142. package/es/tntd-cascader/AntdCascader/config/warning.js +14 -11
  143. package/es/tntd-cascader/AntdCascader/index.js +212 -119
  144. package/es/tntd-cascader/AntdCascader/index.less +2 -2
  145. package/es/tntd-cascader/AntdCascader/interface.js +1 -2
  146. package/es/tntd-cascader/index.js +1 -2
  147. package/es/tntd-cascader/rc-cascader/Cascader.js +279 -235
  148. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +21 -11
  149. package/es/tntd-cascader/rc-cascader/OptionList/Column.js +185 -116
  150. package/es/tntd-cascader/rc-cascader/OptionList/index.js +197 -128
  151. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +24 -19
  152. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +173 -137
  153. package/es/tntd-cascader/rc-cascader/context.js +1 -2
  154. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +50 -37
  155. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +27 -24
  156. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +16 -17
  157. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +8 -8
  158. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +27 -23
  159. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +58 -41
  160. package/es/tntd-cascader/rc-cascader/index.js +1 -2
  161. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +37 -27
  162. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +32 -33
  163. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +33 -25
  164. package/es/tntd-icon/fonts/iconfont.js +41 -53
  165. package/es/tntd-icon/index.js +27 -17
  166. package/es/tntd-layout/ActionsContext.js +3 -4
  167. package/es/tntd-layout/AppList.js +149 -79
  168. package/es/tntd-layout/Application.js +46 -29
  169. package/es/tntd-layout/Avatar.js +84 -42
  170. package/es/tntd-layout/CompatibleLanguage.js +106 -56
  171. package/es/tntd-layout/EnterpriseLayout/Avatar.js +97 -47
  172. package/es/tntd-layout/EnterpriseLayout/Language.js +62 -34
  173. package/es/tntd-layout/EnterpriseLayout/Theme.js +49 -24
  174. package/es/tntd-layout/EnterpriseLayout/index.js +17 -9
  175. package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +244 -154
  176. package/es/tntd-layout/GlobalNavigation/index.js +90 -50
  177. package/es/tntd-layout/Header.js +59 -26
  178. package/es/tntd-layout/HeaderActions.js +87 -34
  179. package/es/tntd-layout/HeaderNavs.js +54 -35
  180. package/es/tntd-layout/HeaderTabs.js +197 -140
  181. package/es/tntd-layout/Iconfont.js +1 -2
  182. package/es/tntd-layout/Language.js +61 -33
  183. package/es/tntd-layout/Layout.js +181 -78
  184. package/es/tntd-layout/Logo.js +61 -42
  185. package/es/tntd-layout/OrgAppList.js +228 -142
  186. package/es/tntd-layout/SideMenu.js +268 -161
  187. package/es/tntd-layout/Theme.js +53 -29
  188. package/es/tntd-layout/createActions.js +28 -29
  189. package/es/tntd-layout/images/index.js +31 -32
  190. package/es/tntd-layout/index.js +100 -60
  191. package/es/tntd-layout/paaslayout/CompactSideMenu.js +124 -65
  192. package/es/tntd-layout/paaslayout/Header.js +37 -14
  193. package/es/tntd-layout/paaslayout/Logo.js +2 -3
  194. package/es/tntd-layout/paaslayout/SideMenu.js +124 -63
  195. package/es/tntd-layout/paaslayout/index.js +168 -79
  196. package/es/tntd-layout/storage.js +20 -13
  197. package/es/tntd-modal/index.js +79 -32
  198. package/es/tntd-second-page/index.js +50 -24
  199. package/es/tntd-select/DropDownWrap.js +77 -52
  200. package/es/tntd-select/index.js +612 -486
  201. package/es/tooltip/index.js +1 -2
  202. package/es/transfer/index.js +1 -2
  203. package/es/tree/index.js +1 -2
  204. package/es/tree-select/index.js +1 -2
  205. package/es/typography/index.js +1 -2
  206. package/es/upload/index.js +1 -2
  207. package/es/utils/checkAuth.js +25 -21
  208. package/es/utils/findMenuInfoByPath.js +36 -30
  209. package/es/utils/index.js +75 -60
  210. package/es/version/index.js +1 -2
  211. package/lib/affix/index.d.ts +3 -3
  212. package/lib/affix/index.js +29 -22
  213. package/lib/affix/index.js.map +1 -1
  214. package/lib/alert/index.d.ts +3 -3
  215. package/lib/alert/index.js +29 -22
  216. package/lib/alert/index.js.map +1 -1
  217. package/lib/anchor/index.d.ts +3 -3
  218. package/lib/anchor/index.js +29 -22
  219. package/lib/anchor/index.js.map +1 -1
  220. package/lib/array-input/icon.js +38 -11
  221. package/lib/array-input/index.js +304 -150
  222. package/lib/auth-context/index.js +13 -4
  223. package/lib/auto-complete/index.d.ts +3 -3
  224. package/lib/auto-complete/index.js +29 -22
  225. package/lib/auto-complete/index.js.map +1 -1
  226. package/lib/avatar/index.d.ts +3 -3
  227. package/lib/avatar/index.js +29 -22
  228. package/lib/avatar/index.js.map +1 -1
  229. package/lib/back-top/index.d.ts +3 -3
  230. package/lib/back-top/index.js +29 -22
  231. package/lib/back-top/index.js.map +1 -1
  232. package/lib/badge/index.d.ts +3 -3
  233. package/lib/badge/index.js +29 -22
  234. package/lib/badge/index.js.map +1 -1
  235. package/lib/breadcrumb/index.d.ts +3 -3
  236. package/lib/breadcrumb/index.js +29 -22
  237. package/lib/breadcrumb/index.js.map +1 -1
  238. package/lib/button/index.d.ts +3 -3
  239. package/lib/button/index.js +29 -22
  240. package/lib/button/index.js.map +1 -1
  241. package/lib/calendar/index.d.ts +3 -3
  242. package/lib/calendar/index.js +29 -22
  243. package/lib/calendar/index.js.map +1 -1
  244. package/lib/card/index.d.ts +3 -3
  245. package/lib/card/index.js +29 -22
  246. package/lib/card/index.js.map +1 -1
  247. package/lib/carousel/index.d.ts +3 -3
  248. package/lib/carousel/index.js +29 -22
  249. package/lib/carousel/index.js.map +1 -1
  250. package/lib/cascader/index.d.ts +3 -3
  251. package/lib/cascader/index.js +29 -22
  252. package/lib/cascader/index.js.map +1 -1
  253. package/lib/checkbox/index.d.ts +3 -3
  254. package/lib/checkbox/index.js +29 -22
  255. package/lib/checkbox/index.js.map +1 -1
  256. package/lib/col/index.d.ts +3 -3
  257. package/lib/col/index.js +29 -22
  258. package/lib/col/index.js.map +1 -1
  259. package/lib/collapse/index.d.ts +3 -3
  260. package/lib/collapse/index.js +31 -23
  261. package/lib/collapse/index.js.map +1 -1
  262. package/lib/columns/index.js +95 -41
  263. package/lib/columns/style/index.js +1 -2
  264. package/lib/comment/index.d.ts +3 -3
  265. package/lib/comment/index.js +29 -22
  266. package/lib/comment/index.js.map +1 -1
  267. package/lib/config-provider/config-provider.d.ts +1 -1
  268. package/lib/config-provider/config-provider.js +14 -8
  269. package/lib/config-provider/config-provider.js.map +1 -1
  270. package/lib/config-provider/index.d.ts +3 -3
  271. package/lib/config-provider/index.js +29 -22
  272. package/lib/config-provider/index.js.map +1 -1
  273. package/lib/date-picker/index.d.ts +3 -3
  274. package/lib/date-picker/index.js +29 -22
  275. package/lib/date-picker/index.js.map +1 -1
  276. package/lib/descriptions/index.d.ts +3 -3
  277. package/lib/descriptions/index.js +29 -22
  278. package/lib/descriptions/index.js.map +1 -1
  279. package/lib/development-login/LoginModal.js +136 -80
  280. package/lib/development-login/index.js +53 -35
  281. package/lib/divider/index.d.ts +3 -3
  282. package/lib/divider/index.js +29 -22
  283. package/lib/divider/index.js.map +1 -1
  284. package/lib/drawer/drawer.d.ts +1 -1
  285. package/lib/drawer/drawer.js +51 -30
  286. package/lib/drawer/drawer.js.map +1 -1
  287. package/lib/drawer/drawer.less +1 -1
  288. package/lib/drawer/index.d.ts +2 -2
  289. package/lib/drawer/index.js +26 -20
  290. package/lib/drawer/index.js.map +1 -1
  291. package/lib/dropdown/index.d.ts +3 -3
  292. package/lib/dropdown/index.js +29 -22
  293. package/lib/dropdown/index.js.map +1 -1
  294. package/lib/ellipsis/Svg/CopySVG.js +74 -21
  295. package/lib/ellipsis/Svg/TickSVG.js +52 -16
  296. package/lib/ellipsis/index.js +159 -105
  297. package/lib/empty/empty.d.ts +2 -2
  298. package/lib/empty/empty.js +107 -76
  299. package/lib/empty/empty.js.map +1 -1
  300. package/lib/empty/empty.stories.js +37 -18
  301. package/lib/empty/index.d.ts +1 -1
  302. package/lib/empty/index.js +24 -19
  303. package/lib/empty/index.js.map +1 -1
  304. package/lib/exception/exception.js +53 -31
  305. package/lib/exception/exception.js.map +1 -1
  306. package/lib/exception/exception.less +1 -1
  307. package/lib/exception/index.js +22 -18
  308. package/lib/form/index.d.ts +3 -3
  309. package/lib/form/index.js +29 -22
  310. package/lib/form/index.js.map +1 -1
  311. package/lib/handle/index.js +164 -102
  312. package/lib/handle/index.js.map +1 -1
  313. package/lib/icon/index.d.ts +3 -3
  314. package/lib/icon/index.js +29 -22
  315. package/lib/icon/index.js.map +1 -1
  316. package/lib/icon-list/index.js +7 -121
  317. package/lib/img/Contain.js +80 -44
  318. package/lib/img/Cover.js +139 -78
  319. package/lib/img/index.js +92 -60
  320. package/lib/index.js +694 -182
  321. package/lib/input/index.d.ts +3 -3
  322. package/lib/input/index.js +29 -22
  323. package/lib/input/index.js.map +1 -1
  324. package/lib/input-number/index.d.ts +3 -3
  325. package/lib/input-number/index.js +29 -22
  326. package/lib/input-number/index.js.map +1 -1
  327. package/lib/layout/index.d.ts +3 -3
  328. package/lib/layout/index.js +29 -22
  329. package/lib/layout/index.js.map +1 -1
  330. package/lib/list/index.d.ts +3 -3
  331. package/lib/list/index.js +29 -22
  332. package/lib/list/index.js.map +1 -1
  333. package/lib/loading-button/index.js +75 -55
  334. package/lib/locale/default.js +17 -10
  335. package/lib/locale/default.js.map +1 -1
  336. package/lib/locale/en_US.js +41 -35
  337. package/lib/locale/en_US.js.map +1 -1
  338. package/lib/locale/index.js +39 -18
  339. package/lib/locale/zh_CN.js +41 -35
  340. package/lib/locale/zh_CN.js.map +1 -1
  341. package/lib/locale-provider/index.d.ts +3 -3
  342. package/lib/locale-provider/index.js +29 -22
  343. package/lib/locale-provider/index.js.map +1 -1
  344. package/lib/mention/index.d.ts +3 -3
  345. package/lib/mention/index.js +29 -22
  346. package/lib/mention/index.js.map +1 -1
  347. package/lib/mentions/index.d.ts +3 -3
  348. package/lib/mentions/index.js +29 -22
  349. package/lib/mentions/index.js.map +1 -1
  350. package/lib/menu/index.d.ts +3 -3
  351. package/lib/menu/index.js +29 -22
  352. package/lib/menu/index.js.map +1 -1
  353. package/lib/message/index.d.ts +3 -3
  354. package/lib/message/index.js +30 -22
  355. package/lib/message/index.js.map +1 -1
  356. package/lib/modal/index.d.ts +3 -3
  357. package/lib/modal/index.js +30 -22
  358. package/lib/modal/index.js.map +1 -1
  359. package/lib/modal/modal.less +1 -1
  360. package/lib/notification/index.d.ts +3 -3
  361. package/lib/notification/index.js +29 -22
  362. package/lib/notification/index.js.map +1 -1
  363. package/lib/page/Box.js +79 -40
  364. package/lib/page/index.js +180 -99
  365. package/lib/page/utils.js +29 -15
  366. package/lib/page-header/index.d.ts +3 -3
  367. package/lib/page-header/index.js +29 -22
  368. package/lib/page-header/index.js.map +1 -1
  369. package/lib/pagination/index.d.ts +3 -3
  370. package/lib/pagination/index.js +29 -22
  371. package/lib/pagination/index.js.map +1 -1
  372. package/lib/popconfirm/index.d.ts +3 -3
  373. package/lib/popconfirm/index.js +29 -22
  374. package/lib/popconfirm/index.js.map +1 -1
  375. package/lib/popover/index.d.ts +3 -3
  376. package/lib/popover/index.js +29 -22
  377. package/lib/popover/index.js.map +1 -1
  378. package/lib/prev-locale.js +76 -53
  379. package/lib/progress/index.d.ts +3 -3
  380. package/lib/progress/index.js +29 -22
  381. package/lib/progress/index.js.map +1 -1
  382. package/lib/query-form/Field/Checkbox.js +37 -22
  383. package/lib/query-form/Field/Select.js +97 -68
  384. package/lib/query-form/Field/SelectInput.js +110 -73
  385. package/lib/query-form/Field/fieldsMap.d.ts +2 -2
  386. package/lib/query-form/Field/fieldsMap.js +45 -32
  387. package/lib/query-form/Field/index.js +171 -95
  388. package/lib/query-form/createActions.js +60 -50
  389. package/lib/query-form/index.js +446 -286
  390. package/lib/query-form/useForm.js +15 -11
  391. package/lib/query-list-scene/List.js +414 -292
  392. package/lib/query-list-scene/QueryForm.js +191 -104
  393. package/lib/query-list-scene/QueryListScene.js +87 -31
  394. package/lib/query-list-scene/Title.js +19 -9
  395. package/lib/query-list-scene/Toolbar.js +38 -20
  396. package/lib/query-list-scene/createActions.js +85 -64
  397. package/lib/query-list-scene/index.js +38 -24
  398. package/lib/query-list-scene/useActions.js +15 -11
  399. package/lib/radio/index.d.ts +3 -3
  400. package/lib/radio/index.js +29 -22
  401. package/lib/radio/index.js.map +1 -1
  402. package/lib/rate/index.d.ts +3 -3
  403. package/lib/rate/index.js +29 -22
  404. package/lib/rate/index.js.map +1 -1
  405. package/lib/render-empty/index.js +10 -4
  406. package/lib/render-empty/render-empty.js +36 -22
  407. package/lib/render-empty/render-empty.js.map +1 -1
  408. package/lib/result/index.d.ts +3 -3
  409. package/lib/result/index.js +29 -22
  410. package/lib/result/index.js.map +1 -1
  411. package/lib/row/index.d.ts +3 -3
  412. package/lib/row/index.js +29 -22
  413. package/lib/row/index.js.map +1 -1
  414. package/lib/select/index.d.ts +3 -3
  415. package/lib/select/index.js +29 -22
  416. package/lib/select/index.js.map +1 -1
  417. package/lib/skeleton/index.d.ts +3 -3
  418. package/lib/skeleton/index.js +29 -22
  419. package/lib/skeleton/index.js.map +1 -1
  420. package/lib/slider/index.d.ts +3 -3
  421. package/lib/slider/index.js +29 -22
  422. package/lib/slider/index.js.map +1 -1
  423. package/lib/spin/index.d.ts +3 -3
  424. package/lib/spin/index.js +29 -22
  425. package/lib/spin/index.js.map +1 -1
  426. package/lib/statistic/index.d.ts +3 -3
  427. package/lib/statistic/index.js +29 -22
  428. package/lib/statistic/index.js.map +1 -1
  429. package/lib/steps/index.d.ts +1 -1
  430. package/lib/steps/index.js +24 -19
  431. package/lib/steps/index.js.map +1 -1
  432. package/lib/steps/steps.d.ts +3 -3
  433. package/lib/steps/steps.js +89 -59
  434. package/lib/steps/steps.js.map +1 -1
  435. package/lib/steps/style/nav.less +3 -3
  436. package/lib/svg-components/illustration-403.js +223 -84
  437. package/lib/svg-components/illustration-404.js +307 -101
  438. package/lib/svg-components/illustration-500.js +338 -109
  439. package/lib/svg-components/illustration-empty.js +71 -41
  440. package/lib/svg-components/illustration-failure.js +129 -62
  441. package/lib/svg-components/illustration-no-access.js +131 -61
  442. package/lib/svg-components/illustration-no-chart.js +151 -63
  443. package/lib/svg-components/illustration-no-result.js +109 -58
  444. package/lib/svg-components/illustration-offline.js +148 -69
  445. package/lib/svg-components/illustration-success.js +154 -69
  446. package/lib/svg-components/index.js +86 -26
  447. package/lib/switch/index.d.ts +3 -3
  448. package/lib/switch/index.js +29 -22
  449. package/lib/switch/index.js.map +1 -1
  450. package/lib/table/assets/image-loading-background.js +62 -43
  451. package/lib/table/assets/image-loading.js +43 -31
  452. package/lib/table/constants.js +6 -3
  453. package/lib/table/context.d.ts +1 -1
  454. package/lib/table/context.js +9 -4
  455. package/lib/table/context.js.map +1 -1
  456. package/lib/table/hooks/index.js +15 -16
  457. package/lib/table/hooks/use-column-setting.d.ts +1 -1
  458. package/lib/table/hooks/use-column-setting.js +45 -20
  459. package/lib/table/hooks/use-column-setting.js.map +1 -1
  460. package/lib/table/index.d.ts +1 -1
  461. package/lib/table/index.js +24 -19
  462. package/lib/table/index.js.map +1 -1
  463. package/lib/table/table.d.ts +3 -3
  464. package/lib/table/table.js +139 -89
  465. package/lib/table/table.js.map +1 -1
  466. package/lib/table/table.stories.js +191 -154
  467. package/lib/table/utils.d.ts +1 -1
  468. package/lib/table/utils.js +33 -25
  469. package/lib/table/utils.js.map +1 -1
  470. package/lib/tabs/index.d.ts +3 -3
  471. package/lib/tabs/index.js +29 -22
  472. package/lib/tabs/index.js.map +1 -1
  473. package/lib/tag/index.d.ts +3 -3
  474. package/lib/tag/index.js +29 -22
  475. package/lib/tag/index.js.map +1 -1
  476. package/lib/time-picker/index.d.ts +3 -3
  477. package/lib/time-picker/index.js +29 -22
  478. package/lib/time-picker/index.js.map +1 -1
  479. package/lib/timeline/index.d.ts +3 -3
  480. package/lib/timeline/index.js +29 -22
  481. package/lib/timeline/index.js.map +1 -1
  482. package/lib/title/index.js +55 -26
  483. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +25 -31
  484. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +14 -26
  485. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +14 -26
  486. package/lib/tntd-cascader/AntdCascader/component/context.js +24 -16
  487. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +44 -39
  488. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  489. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +99 -75
  490. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +40 -50
  491. package/lib/tntd-cascader/AntdCascader/config/utils.js +38 -27
  492. package/lib/tntd-cascader/AntdCascader/config/warning.js +28 -36
  493. package/lib/tntd-cascader/AntdCascader/index.js +269 -162
  494. package/lib/tntd-cascader/AntdCascader/index.less +2 -2
  495. package/lib/tntd-cascader/AntdCascader/interface.js +16 -6
  496. package/lib/tntd-cascader/img/no-data-s.png +0 -0
  497. package/lib/tntd-cascader/index.js +14 -8
  498. package/lib/tntd-cascader/rc-cascader/Cascader.js +390 -284
  499. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +40 -41
  500. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +226 -152
  501. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +267 -163
  502. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +55 -48
  503. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +229 -166
  504. package/lib/tntd-cascader/rc-cascader/context.js +16 -27
  505. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +79 -63
  506. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +49 -49
  507. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +34 -41
  508. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +21 -33
  509. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +42 -51
  510. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +90 -65
  511. package/lib/tntd-cascader/rc-cascader/index.js +12 -7
  512. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +60 -38
  513. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +50 -39
  514. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +43 -32
  515. package/lib/tntd-icon/fonts/iconfont.js +41 -53
  516. package/lib/tntd-icon/index.js +51 -25
  517. package/lib/tntd-layout/ActionsContext.js +11 -4
  518. package/lib/tntd-layout/AppList.js +245 -221
  519. package/lib/tntd-layout/Application.js +137 -111
  520. package/lib/tntd-layout/Avatar.js +154 -135
  521. package/lib/tntd-layout/CompatibleLanguage.js +201 -180
  522. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +173 -146
  523. package/lib/tntd-layout/EnterpriseLayout/Language.js +104 -90
  524. package/lib/tntd-layout/EnterpriseLayout/Theme.js +99 -102
  525. package/lib/tntd-layout/EnterpriseLayout/index.js +36 -17
  526. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +413 -277
  527. package/lib/tntd-layout/GlobalNavigation/index.js +159 -115
  528. package/lib/tntd-layout/Header.js +111 -136
  529. package/lib/tntd-layout/HeaderActions.js +134 -104
  530. package/lib/tntd-layout/HeaderNavs.js +117 -106
  531. package/lib/tntd-layout/HeaderTabs.js +286 -310
  532. package/lib/tntd-layout/Iconfont.js +16 -7
  533. package/lib/tntd-layout/Language.js +100 -76
  534. package/lib/tntd-layout/Layout.js +253 -171
  535. package/lib/tntd-layout/Logo.js +91 -139
  536. package/lib/tntd-layout/OrgAppList.js +301 -383
  537. package/lib/tntd-layout/SideMenu.js +331 -392
  538. package/lib/tntd-layout/Theme.js +127 -93
  539. package/lib/tntd-layout/createActions.js +50 -34
  540. package/lib/tntd-layout/images/avatar/empty.png +0 -0
  541. package/lib/tntd-layout/images/avatar/female1.png +0 -0
  542. package/lib/tntd-layout/images/avatar/female2.png +0 -0
  543. package/lib/tntd-layout/images/avatar/female3.png +0 -0
  544. package/lib/tntd-layout/images/avatar/female4.png +0 -0
  545. package/lib/tntd-layout/images/avatar/female5.png +0 -0
  546. package/lib/tntd-layout/images/avatar/female6.png +0 -0
  547. package/lib/tntd-layout/images/avatar/male1.png +0 -0
  548. package/lib/tntd-layout/images/avatar/male2.png +0 -0
  549. package/lib/tntd-layout/images/avatar/male3.png +0 -0
  550. package/lib/tntd-layout/images/avatar/male4.png +0 -0
  551. package/lib/tntd-layout/images/avatar/male5.png +0 -0
  552. package/lib/tntd-layout/images/avatar/male6.png +0 -0
  553. package/lib/tntd-layout/images/index.js +96 -66
  554. package/lib/tntd-layout/index.js +165 -95
  555. package/lib/tntd-layout/paaslayout/CompactSideMenu.js +178 -177
  556. package/lib/tntd-layout/paaslayout/Header.js +84 -79
  557. package/lib/tntd-layout/paaslayout/Logo.js +32 -30
  558. package/lib/tntd-layout/paaslayout/SideMenu.js +182 -147
  559. package/lib/tntd-layout/paaslayout/index.js +251 -141
  560. package/lib/tntd-layout/storage.d.ts +1 -1
  561. package/lib/tntd-layout/storage.d.ts.map +1 -1
  562. package/lib/tntd-layout/storage.js +88 -30
  563. package/lib/tntd-modal/index.js +117 -62
  564. package/lib/tntd-second-page/index.js +70 -33
  565. package/lib/tntd-second-page/index.js.map +1 -1
  566. package/lib/tntd-select/DropDownWrap.js +123 -78
  567. package/lib/tntd-select/index.d.ts +1 -1
  568. package/lib/tntd-select/index.js +697 -520
  569. package/lib/tooltip/index.d.ts +3 -3
  570. package/lib/tooltip/index.js +29 -22
  571. package/lib/tooltip/index.js.map +1 -1
  572. package/lib/transfer/index.d.ts +3 -3
  573. package/lib/transfer/index.js +29 -22
  574. package/lib/transfer/index.js.map +1 -1
  575. package/lib/tree/index.d.ts +3 -3
  576. package/lib/tree/index.js +29 -22
  577. package/lib/tree/index.js.map +1 -1
  578. package/lib/tree-select/index.d.ts +3 -3
  579. package/lib/tree-select/index.js +29 -22
  580. package/lib/tree-select/index.js.map +1 -1
  581. package/lib/typography/index.d.ts +3 -3
  582. package/lib/typography/index.js +29 -22
  583. package/lib/typography/index.js.map +1 -1
  584. package/lib/upload/index.d.ts +3 -3
  585. package/lib/upload/index.js +29 -22
  586. package/lib/upload/index.js.map +1 -1
  587. package/lib/utils/checkAuth.js +40 -23
  588. package/lib/utils/findMenuInfoByPath.js +47 -34
  589. package/lib/utils/index.js +144 -79
  590. package/lib/version/index.d.ts +3 -3
  591. package/lib/version/index.js +29 -22
  592. package/lib/version/index.js.map +1 -1
  593. package/package.json +2 -2
  594. package/themes/default/colors.less +0 -6
  595. package/themes/default/tntd.less +0 -0
  596. package/themes/default/variables.less +5 -5
  597. package/es/array-input/style/index.js +0 -2
  598. package/es/array-input/style/index.js.map +0 -1
  599. package/es/auth-context/style/index.js +0 -2
  600. package/es/auth-context/style/index.js.map +0 -1
  601. package/es/development-login/style/index.js +0 -2
  602. package/es/development-login/style/index.js.map +0 -1
  603. package/es/ellipsis/style/index.js +0 -2
  604. package/es/ellipsis/style/index.js.map +0 -1
  605. package/es/empty/render-empty.js +0 -19
  606. package/es/empty/render-empty.js.map +0 -1
  607. package/es/empty/style/index.js +0 -3
  608. package/es/empty/style/index.js.map +0 -1
  609. package/es/handle/style/index.js +0 -2
  610. package/es/handle/style/index.js.map +0 -1
  611. package/es/icon-list/style/index.js +0 -120
  612. package/es/icon-list/style/index.js.map +0 -1
  613. package/es/img/style/index.js +0 -2
  614. package/es/img/style/index.js.map +0 -1
  615. package/es/loading-button/style/index.js +0 -2
  616. package/es/loading-button/style/index.js.map +0 -1
  617. package/es/page/style/index.js +0 -2
  618. package/es/page/style/index.js.map +0 -1
  619. package/es/query-form/style/index.js +0 -2
  620. package/es/query-form/style/index.js.map +0 -1
  621. package/es/query-list-scene/style/index.js +0 -2
  622. package/es/query-list-scene/style/index.js.map +0 -1
  623. package/es/render-empty/style/index.js +0 -2
  624. package/es/render-empty/style/index.js.map +0 -1
  625. package/es/table/style/index.js +0 -3
  626. package/es/table/style/index.js.map +0 -1
  627. package/es/title/style/index.js +0 -2
  628. package/es/title/style/index.js.map +0 -1
  629. package/es/tntd-icon/style/index.js +0 -2
  630. package/es/tntd-icon/style/index.js.map +0 -1
  631. package/es/tntd-layout/style/index.js +0 -2
  632. package/es/tntd-layout/style/index.js.map +0 -1
  633. package/es/tntd-modal/style/index.js +0 -2
  634. package/es/tntd-modal/style/index.js.map +0 -1
  635. package/es/tntd-select/style/index.js +0 -2
  636. package/es/tntd-select/style/index.js.map +0 -1
  637. package/lib/array-input/style/index.d.ts +0 -1
  638. package/lib/array-input/style/index.d.ts.map +0 -1
  639. package/lib/array-input/style/index.js +0 -2
  640. package/lib/array-input/style/index.js.map +0 -1
  641. package/lib/auth-context/style/index.d.ts +0 -1
  642. package/lib/auth-context/style/index.d.ts.map +0 -1
  643. package/lib/auth-context/style/index.js +0 -2
  644. package/lib/auth-context/style/index.js.map +0 -1
  645. package/lib/development-login/style/index.d.ts +0 -1
  646. package/lib/development-login/style/index.d.ts.map +0 -1
  647. package/lib/development-login/style/index.js +0 -2
  648. package/lib/development-login/style/index.js.map +0 -1
  649. package/lib/ellipsis/style/index.d.ts +0 -1
  650. package/lib/ellipsis/style/index.d.ts.map +0 -1
  651. package/lib/ellipsis/style/index.js +0 -2
  652. package/lib/ellipsis/style/index.js.map +0 -1
  653. package/lib/empty/render-empty.d.ts +0 -3
  654. package/lib/empty/render-empty.d.ts.map +0 -1
  655. package/lib/empty/render-empty.js +0 -26
  656. package/lib/empty/render-empty.js.map +0 -1
  657. package/lib/empty/style/index.d.ts +0 -3
  658. package/lib/empty/style/index.d.ts.map +0 -1
  659. package/lib/empty/style/index.js +0 -5
  660. package/lib/empty/style/index.js.map +0 -1
  661. package/lib/handle/style/index.d.ts +0 -1
  662. package/lib/handle/style/index.d.ts.map +0 -1
  663. package/lib/handle/style/index.js +0 -2
  664. package/lib/handle/style/index.js.map +0 -1
  665. package/lib/icon-list/style/index.d.ts +0 -3
  666. package/lib/icon-list/style/index.d.ts.map +0 -1
  667. package/lib/icon-list/style/index.js +0 -122
  668. package/lib/icon-list/style/index.js.map +0 -1
  669. package/lib/img/style/index.d.ts +0 -1
  670. package/lib/img/style/index.d.ts.map +0 -1
  671. package/lib/img/style/index.js +0 -2
  672. package/lib/img/style/index.js.map +0 -1
  673. package/lib/loading-button/style/index.d.ts +0 -1
  674. package/lib/loading-button/style/index.d.ts.map +0 -1
  675. package/lib/loading-button/style/index.js +0 -2
  676. package/lib/loading-button/style/index.js.map +0 -1
  677. package/lib/page/style/index.d.ts +0 -1
  678. package/lib/page/style/index.d.ts.map +0 -1
  679. package/lib/page/style/index.js +0 -2
  680. package/lib/page/style/index.js.map +0 -1
  681. package/lib/query-form/style/index.d.ts +0 -1
  682. package/lib/query-form/style/index.d.ts.map +0 -1
  683. package/lib/query-form/style/index.js +0 -2
  684. package/lib/query-form/style/index.js.map +0 -1
  685. package/lib/query-list-scene/style/index.d.ts +0 -1
  686. package/lib/query-list-scene/style/index.d.ts.map +0 -1
  687. package/lib/query-list-scene/style/index.js +0 -2
  688. package/lib/query-list-scene/style/index.js.map +0 -1
  689. package/lib/render-empty/style/index.d.ts +0 -2
  690. package/lib/render-empty/style/index.d.ts.map +0 -1
  691. package/lib/render-empty/style/index.js +0 -4
  692. package/lib/render-empty/style/index.js.map +0 -1
  693. package/lib/table/style/index.d.ts +0 -3
  694. package/lib/table/style/index.d.ts.map +0 -1
  695. package/lib/table/style/index.js +0 -5
  696. package/lib/table/style/index.js.map +0 -1
  697. package/lib/title/style/index.d.ts +0 -1
  698. package/lib/title/style/index.d.ts.map +0 -1
  699. package/lib/title/style/index.js +0 -2
  700. package/lib/title/style/index.js.map +0 -1
  701. package/lib/tntd-icon/style/index.d.ts +0 -1
  702. package/lib/tntd-icon/style/index.d.ts.map +0 -1
  703. package/lib/tntd-icon/style/index.js +0 -2
  704. package/lib/tntd-icon/style/index.js.map +0 -1
  705. package/lib/tntd-layout/style/index.d.ts +0 -1
  706. package/lib/tntd-layout/style/index.d.ts.map +0 -1
  707. package/lib/tntd-layout/style/index.js +0 -2
  708. package/lib/tntd-layout/style/index.js.map +0 -1
  709. package/lib/tntd-modal/style/index.d.ts +0 -1
  710. package/lib/tntd-modal/style/index.d.ts.map +0 -1
  711. package/lib/tntd-modal/style/index.js +0 -2
  712. package/lib/tntd-modal/style/index.js.map +0 -1
  713. package/lib/tntd-select/style/index.d.ts +0 -1
  714. package/lib/tntd-select/style/index.d.ts.map +0 -1
  715. package/lib/tntd-select/style/index.js +0 -2
  716. package/lib/tntd-select/style/index.js.map +0 -1
@@ -7,120 +7,189 @@ import Checkbox from './Checkbox';
7
7
  import { SEARCH_MARK } from '../hooks/useSearchOptions';
8
8
  import List from 'rc-virtual-list';
9
9
  export const FIX_LABEL = '__cascader_fix_label__';
10
- export default function Column({ prefixCls, multiple, options, activeValue, prevValuePath, onToggleOpen, onSelect, onActive, checkedSet, halfCheckedSet, loadingKeys, isSelectable, renderItem, searchValue, level, dropdownVisible, optionHeight, }) {
11
- const ref = React.useRef(null);
12
- const menuPrefixCls = `${prefixCls}-menu ${prefixCls}-menu-${level}`;
13
- const menuItemPrefixCls = `${prefixCls}-menu-item`;
14
- const { fieldNames, changeOnSelect, expandTrigger, expandIcon, loadingIcon, dropdownMenuColumnStyle, } = React.useContext(CascaderContext);
15
- const hoverOpen = expandTrigger === 'hover';
16
- /** 单选情况下滚动到相应的位置 */
17
- React.useEffect(() => {
18
- let timer = null;
19
- if (ref.current && ref.current.scrollTo && !multiple && dropdownVisible) {
20
- const index = options.findIndex((it) => it[fieldNames.value] === activeValue);
21
- if (index > 0 && !isNaN(index)) {
22
- timer = window.setTimeout(() => {
23
- ref.current.scrollTo((optionHeight || 36) * index);
24
- }, 5);
25
- }
10
+ export default function Column({
11
+ prefixCls,
12
+ multiple,
13
+ options,
14
+ activeValue,
15
+ prevValuePath,
16
+ onToggleOpen,
17
+ onSelect,
18
+ onActive,
19
+ checkedSet,
20
+ halfCheckedSet,
21
+ loadingKeys,
22
+ isSelectable,
23
+ renderItem,
24
+ searchValue,
25
+ level,
26
+ dropdownVisible,
27
+ optionHeight
28
+ }) {
29
+ const ref = React.useRef(null);
30
+ const menuPrefixCls = `${prefixCls}-menu ${prefixCls}-menu-${level}`;
31
+ const menuItemPrefixCls = `${prefixCls}-menu-item`;
32
+ const {
33
+ fieldNames,
34
+ changeOnSelect,
35
+ expandTrigger,
36
+ expandIcon,
37
+ loadingIcon,
38
+ dropdownMenuColumnStyle
39
+ } = React.useContext(CascaderContext);
40
+ const hoverOpen = expandTrigger === 'hover';
41
+ /** 单选情况下滚动到相应的位置 */
42
+
43
+ React.useEffect(() => {
44
+ let timer = null;
45
+
46
+ if (ref.current && ref.current.scrollTo && !multiple && dropdownVisible) {
47
+ const index = options.findIndex(it => it[fieldNames.value] === activeValue);
48
+
49
+ if (index > 0 && !isNaN(index)) {
50
+ timer = window.setTimeout(() => {
51
+ ref.current.scrollTo((optionHeight || 36) * index);
52
+ }, 5);
53
+ }
54
+ }
55
+
56
+ return () => {
57
+ if (timer) {
58
+ window.clearTimeout(timer);
59
+ }
60
+
61
+ timer = null;
62
+ };
63
+ }, [multiple, activeValue, options, fieldNames, dropdownVisible, optionHeight]); // ============================ Option ============================
64
+
65
+ const optionInfoList = React.useMemo(() => options.map(option => {
66
+ var _a;
67
+
68
+ const {
69
+ disabled
70
+ } = option;
71
+ const searchOptions = option[SEARCH_MARK];
72
+ const label = (_a = option[FIX_LABEL]) !== null && _a !== void 0 ? _a : option[fieldNames.label];
73
+ const value = option[fieldNames.value];
74
+ const isMergedLeaf = isLeaf(option, fieldNames); // Get real value of option. Search option is different way.
75
+
76
+ const fullPath = searchOptions ? // @ts-ignore
77
+ searchOptions.map(opt => opt[fieldNames.value]) : [...prevValuePath, value];
78
+ const fullPathKey = toPathKey(fullPath);
79
+ const isLoading = loadingKeys.includes(fullPathKey); // >>>>> checked
80
+
81
+ const checked = checkedSet.has(fullPathKey); // >>>>> halfChecked
82
+
83
+ const halfChecked = halfCheckedSet.has(fullPathKey);
84
+ return {
85
+ disabled,
86
+ label,
87
+ value,
88
+ isLeaf: isMergedLeaf,
89
+ isLoading,
90
+ checked,
91
+ halfChecked,
92
+ option,
93
+ fullPath,
94
+ fullPathKey
95
+ };
96
+ }), [options, checkedSet, fieldNames, halfCheckedSet, loadingKeys, prevValuePath]); // ============================ Render ============================
97
+
98
+ return React.createElement("ul", {
99
+ className: menuPrefixCls,
100
+ role: "menu"
101
+ }, React.createElement(List, {
102
+ className: optionInfoList[0].fullPathKey === '__EMPTY__' || !!searchValue ? 'rc-virtual-list-full' : '',
103
+ data: optionInfoList,
104
+ height: 180,
105
+ itemHeight: optionHeight || 36,
106
+ itemKey: "value",
107
+ ref: ref
108
+ }, ({
109
+ disabled,
110
+ label,
111
+ value,
112
+ isLeaf: isMergedLeaf,
113
+ isLoading,
114
+ checked,
115
+ halfChecked,
116
+ option,
117
+ fullPath,
118
+ fullPathKey
119
+ }) => {
120
+ // >>>>> Open
121
+ const triggerOpenPath = () => {
122
+ if (!disabled && (!hoverOpen || !isMergedLeaf)) {
123
+ onActive(fullPath);
124
+ }
125
+ }; // >>>>> Selection
126
+
127
+
128
+ const triggerSelect = () => {
129
+ if (isSelectable(option)) {
130
+ onSelect(fullPath, isMergedLeaf);
131
+ }
132
+ }; // >>>>> Title
133
+
134
+
135
+ let title;
136
+
137
+ if (typeof option.title === 'string') {
138
+ title = option.title;
139
+ } else if (typeof label === 'string') {
140
+ title = label;
141
+ }
142
+
143
+ return React.createElement("li", {
144
+ key: fullPathKey,
145
+ className: classNames(menuItemPrefixCls, {
146
+ [`${menuItemPrefixCls}-expand`]: !isMergedLeaf,
147
+ [`${menuItemPrefixCls}-active`]: activeValue === value,
148
+ [`${menuItemPrefixCls}-disabled`]: disabled,
149
+ [`${menuItemPrefixCls}-loading`]: isLoading
150
+ }),
151
+ style: dropdownMenuColumnStyle,
152
+ role: "menuitemcheckbox",
153
+ // @ts-ignore
154
+ title: title,
155
+ "aria-checked": checked,
156
+ "data-path-key": fullPathKey,
157
+ onClick: () => {
158
+ triggerOpenPath();
159
+
160
+ if (!multiple || isMergedLeaf) {
161
+ triggerSelect();
26
162
  }
27
- return () => {
28
- if (timer) {
29
- window.clearTimeout(timer);
30
- }
31
- timer = null;
32
- };
33
- }, [multiple, activeValue, options, fieldNames, dropdownVisible, optionHeight]);
34
- // ============================ Option ============================
35
- const optionInfoList = React.useMemo(() => options.map((option) => {
36
- var _a;
37
- const { disabled } = option;
38
- const searchOptions = option[SEARCH_MARK];
39
- const label = (_a = option[FIX_LABEL]) !== null && _a !== void 0 ? _a : option[fieldNames.label];
40
- const value = option[fieldNames.value];
41
- const isMergedLeaf = isLeaf(option, fieldNames);
42
- // Get real value of option. Search option is different way.
43
- const fullPath = searchOptions
44
- ? // @ts-ignore
45
- searchOptions.map((opt) => opt[fieldNames.value])
46
- : [...prevValuePath, value];
47
- const fullPathKey = toPathKey(fullPath);
48
- const isLoading = loadingKeys.includes(fullPathKey);
49
- // >>>>> checked
50
- const checked = checkedSet.has(fullPathKey);
51
- // >>>>> halfChecked
52
- const halfChecked = halfCheckedSet.has(fullPathKey);
53
- return {
54
- disabled,
55
- label,
56
- value,
57
- isLeaf: isMergedLeaf,
58
- isLoading,
59
- checked,
60
- halfChecked,
61
- option,
62
- fullPath,
63
- fullPathKey,
64
- };
65
- }), [options, checkedSet, fieldNames, halfCheckedSet, loadingKeys, prevValuePath]);
66
- // ============================ Render ============================
67
- return (React.createElement("ul", { className: menuPrefixCls, role: "menu" },
68
- React.createElement(List, { className: optionInfoList[0].fullPathKey === '__EMPTY__' || !!searchValue
69
- ? 'rc-virtual-list-full'
70
- : '', data: optionInfoList, height: 180, itemHeight: optionHeight || 36, itemKey: "value", ref: ref }, ({ disabled, label, value, isLeaf: isMergedLeaf, isLoading, checked, halfChecked, option, fullPath, fullPathKey, }) => {
71
- // >>>>> Open
72
- const triggerOpenPath = () => {
73
- if (!disabled && (!hoverOpen || !isMergedLeaf)) {
74
- onActive(fullPath);
75
- }
76
- };
77
- // >>>>> Selection
78
- const triggerSelect = () => {
79
- if (isSelectable(option)) {
80
- onSelect(fullPath, isMergedLeaf);
81
- }
82
- };
83
- // >>>>> Title
84
- let title;
85
- if (typeof option.title === 'string') {
86
- title = option.title;
87
- }
88
- else if (typeof label === 'string') {
89
- title = label;
90
- }
91
- return (React.createElement("li", { key: fullPathKey, className: classNames(menuItemPrefixCls, {
92
- [`${menuItemPrefixCls}-expand`]: !isMergedLeaf,
93
- [`${menuItemPrefixCls}-active`]: activeValue === value,
94
- [`${menuItemPrefixCls}-disabled`]: disabled,
95
- [`${menuItemPrefixCls}-loading`]: isLoading,
96
- }), style: dropdownMenuColumnStyle, role: "menuitemcheckbox",
97
- // @ts-ignore
98
- title: title, "aria-checked": checked, "data-path-key": fullPathKey, onClick: () => {
99
- triggerOpenPath();
100
- if (!multiple || isMergedLeaf) {
101
- triggerSelect();
102
- }
103
- }, onDoubleClick: () => {
104
- if (changeOnSelect) {
105
- onToggleOpen(false);
106
- }
107
- }, onMouseEnter: () => {
108
- if (hoverOpen) {
109
- triggerOpenPath();
110
- }
111
- }, onMouseDown: (e) => {
112
- // Prevent selector from blurring
113
- e.preventDefault();
114
- } },
115
- multiple && (React.createElement(Checkbox, { prefixCls: `${prefixCls}-checkbox`, checked: checked, halfChecked: halfChecked, disabled: disabled, onClick: (e) => {
116
- e.stopPropagation();
117
- triggerSelect();
118
- } })),
119
- React.createElement("div", { className: `${menuItemPrefixCls}-content` }, optionInfoList[0].fullPathKey !== '__EMPTY__' && renderItem
120
- ? renderItem(option, level)
121
- : label),
122
- !isLoading && expandIcon && !isMergedLeaf && (React.createElement("div", { className: `${menuItemPrefixCls}-expand-icon` }, expandIcon)),
123
- isLoading && loadingIcon && (React.createElement("div", { className: `${menuItemPrefixCls}-loading-icon` }, loadingIcon))));
124
- })));
125
- }
126
- //# sourceMappingURL=Column.js.map
163
+ },
164
+ onDoubleClick: () => {
165
+ if (changeOnSelect) {
166
+ onToggleOpen(false);
167
+ }
168
+ },
169
+ onMouseEnter: () => {
170
+ if (hoverOpen) {
171
+ triggerOpenPath();
172
+ }
173
+ },
174
+ onMouseDown: e => {
175
+ // Prevent selector from blurring
176
+ e.preventDefault();
177
+ }
178
+ }, multiple && React.createElement(Checkbox, {
179
+ prefixCls: `${prefixCls}-checkbox`,
180
+ checked: checked,
181
+ halfChecked: halfChecked,
182
+ disabled: disabled,
183
+ onClick: e => {
184
+ e.stopPropagation();
185
+ triggerSelect();
186
+ }
187
+ }), React.createElement("div", {
188
+ className: `${menuItemPrefixCls}-content`
189
+ }, optionInfoList[0].fullPathKey !== '__EMPTY__' && renderItem ? renderItem(option, level) : label), !isLoading && expandIcon && !isMergedLeaf && React.createElement("div", {
190
+ className: `${menuItemPrefixCls}-expand-icon`
191
+ }, expandIcon), isLoading && loadingIcon && React.createElement("div", {
192
+ className: `${menuItemPrefixCls}-loading-icon`
193
+ }, loadingIcon));
194
+ }));
195
+ }
@@ -4,138 +4,207 @@ import classNames from 'classnames';
4
4
  import { useBaseProps } from 'rc-select';
5
5
  import * as React from 'react';
6
6
  import CascaderContext from '../context';
7
- import { isLeaf, scrollIntoParentView, toPathKey, toPathKeys, toPathValueStr, } from '../utils/commonUtil';
7
+ import { isLeaf, scrollIntoParentView, toPathKey, toPathKeys, toPathValueStr } from '../utils/commonUtil';
8
8
  import { toPathOptions } from '../utils/treeUtil';
9
9
  import Column, { FIX_LABEL } from './Column';
10
10
  import useActive from './useActive';
11
11
  import useKeyboard from './useKeyboard';
12
12
  const RefOptionList = React.forwardRef((props, ref) => {
13
- var _a, _b;
14
- const { prefixCls, multiple, searchValue, toggleOpen, notFoundContent, direction, optionHeight } = useBaseProps();
15
- const containerRef = React.useRef();
16
- const rtl = direction === 'rtl';
17
- const { options, values, halfValues, fieldNames, changeOnSelect, onSelect, searchOptions, dropdownPrefixCls, loadData, expandTrigger, renderItem, dropdownVisible, } = React.useContext(CascaderContext);
18
- const mergedPrefixCls = dropdownPrefixCls || prefixCls;
19
- // ========================= loadData =========================
20
- const [loadingKeys, setLoadingKeys] = React.useState([]);
21
- const internalLoadData = (valueCells) => {
22
- // Do not load when search
23
- if (!loadData || searchValue) {
24
- return;
13
+ var _a, _b;
14
+
15
+ const {
16
+ prefixCls,
17
+ multiple,
18
+ searchValue,
19
+ toggleOpen,
20
+ notFoundContent,
21
+ direction,
22
+ optionHeight
23
+ } = useBaseProps();
24
+ const containerRef = React.useRef();
25
+ const rtl = direction === 'rtl';
26
+ const {
27
+ options,
28
+ values,
29
+ halfValues,
30
+ fieldNames,
31
+ changeOnSelect,
32
+ onSelect,
33
+ searchOptions,
34
+ dropdownPrefixCls,
35
+ loadData,
36
+ expandTrigger,
37
+ renderItem,
38
+ dropdownVisible
39
+ } = React.useContext(CascaderContext);
40
+ const mergedPrefixCls = dropdownPrefixCls || prefixCls; // ========================= loadData =========================
41
+
42
+ const [loadingKeys, setLoadingKeys] = React.useState([]);
43
+
44
+ const internalLoadData = valueCells => {
45
+ // Do not load when search
46
+ if (!loadData || searchValue) {
47
+ return;
48
+ }
49
+
50
+ const optionList = toPathOptions(valueCells, options, fieldNames);
51
+ const rawOptions = optionList.map(({
52
+ option
53
+ }) => option);
54
+ const lastOption = rawOptions[rawOptions.length - 1];
55
+
56
+ if (lastOption && !isLeaf(lastOption, fieldNames)) {
57
+ const pathKey = toPathKey(valueCells);
58
+ setLoadingKeys(keys => [...keys, pathKey]);
59
+ loadData(rawOptions);
60
+ }
61
+ }; // zombieJ: This is bad. We should make this same as `rc-tree` to use Promise instead.
62
+
63
+
64
+ React.useEffect(() => {
65
+ if (loadingKeys.length) {
66
+ loadingKeys.forEach(loadingKey => {
67
+ const valueStrCells = toPathValueStr(loadingKey);
68
+ const optionList = toPathOptions(valueStrCells, options, fieldNames, true).map(({
69
+ option
70
+ }) => option);
71
+ const lastOption = optionList[optionList.length - 1];
72
+
73
+ if (!lastOption || lastOption[fieldNames.children] || isLeaf(lastOption, fieldNames)) {
74
+ setLoadingKeys(keys => keys.filter(key => key !== loadingKey));
25
75
  }
26
- const optionList = toPathOptions(valueCells, options, fieldNames);
27
- const rawOptions = optionList.map(({ option }) => option);
28
- const lastOption = rawOptions[rawOptions.length - 1];
29
- if (lastOption && !isLeaf(lastOption, fieldNames)) {
30
- const pathKey = toPathKey(valueCells);
31
- setLoadingKeys((keys) => [...keys, pathKey]);
32
- loadData(rawOptions);
33
- }
34
- };
35
- // zombieJ: This is bad. We should make this same as `rc-tree` to use Promise instead.
36
- React.useEffect(() => {
37
- if (loadingKeys.length) {
38
- loadingKeys.forEach((loadingKey) => {
39
- const valueStrCells = toPathValueStr(loadingKey);
40
- const optionList = toPathOptions(valueStrCells, options, fieldNames, true).map(({ option }) => option);
41
- const lastOption = optionList[optionList.length - 1];
42
- if (!lastOption || lastOption[fieldNames.children] || isLeaf(lastOption, fieldNames)) {
43
- setLoadingKeys((keys) => keys.filter((key) => key !== loadingKey));
44
- }
45
- });
46
- }
47
- }, [options, loadingKeys, fieldNames]);
48
- // ========================== Values ==========================
49
- const checkedSet = React.useMemo(() => new Set(toPathKeys(values)), [values]);
50
- const halfCheckedSet = React.useMemo(() => new Set(toPathKeys(halfValues)), [halfValues]);
51
- // ====================== Accessibility =======================
52
- const [activeValueCells, setActiveValueCells] = useActive();
53
- // =========================== Path ===========================
54
- const onPathOpen = (nextValueCells) => {
55
- setActiveValueCells(nextValueCells);
56
- // Trigger loadData
57
- internalLoadData(nextValueCells);
58
- };
59
- const isSelectable = (option) => {
60
- const { disabled } = option;
61
- const isMergedLeaf = isLeaf(option, fieldNames);
62
- return !disabled && (isMergedLeaf || changeOnSelect || multiple);
63
- };
64
- const onPathSelect = (valuePath, leaf, fromKeyboard = false) => {
65
- onSelect(valuePath);
66
- if (!multiple && (leaf || (changeOnSelect && (expandTrigger === 'hover' || fromKeyboard)))) {
67
- toggleOpen(false);
68
- }
69
- };
70
- // ========================== Option ==========================
71
- const mergedOptions = React.useMemo(() => {
72
- if (searchValue) {
73
- return searchOptions;
74
- }
75
- return options;
76
- }, [searchValue, searchOptions, options]);
77
- // ========================== Column ==========================
78
- const optionColumns = React.useMemo(() => {
79
- const optionList = [{ options: mergedOptions }];
80
- let currentList = mergedOptions;
81
- for (let i = 0; i < activeValueCells.length; i += 1) {
82
- const activeValueCell = activeValueCells[i];
83
- const currentOption = currentList.find((option) => option[fieldNames.value] === activeValueCell);
84
- const subOptions = currentOption === null || currentOption === void 0 ? void 0 : currentOption[fieldNames.children];
85
- if (!(subOptions === null || subOptions === void 0 ? void 0 : subOptions.length)) {
86
- break;
87
- }
88
- currentList = subOptions;
89
- optionList.push({ options: subOptions });
90
- }
91
- return optionList;
92
- }, [mergedOptions, activeValueCells, fieldNames]);
93
- // ========================= Keyboard =========================
94
- const onKeyboardSelect = (selectValueCells, option) => {
95
- if (isSelectable(option)) {
96
- onPathSelect(selectValueCells, isLeaf(option, fieldNames), true);
97
- }
98
- };
99
- useKeyboard(ref, mergedOptions, fieldNames, activeValueCells, onPathOpen, onKeyboardSelect);
100
- // >>>>> Active Scroll
101
- React.useEffect(() => {
102
- var _a;
103
- for (let i = 0; i < activeValueCells.length; i += 1) {
104
- const cellPath = activeValueCells.slice(0, i + 1);
105
- const cellKeyPath = toPathKey(cellPath);
106
- const ele = (_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(`li[data-path-key="${cellKeyPath.replace(/\\{0,2}"/g, '\\"')}"]` // matches unescaped double quotes
107
- );
108
- if (ele) {
109
- scrollIntoParentView(ele);
110
- }
111
- }
112
- }, [activeValueCells]);
113
- // ========================== Render ==========================
114
- // >>>>> Empty
115
- const isEmpty = !((_b = (_a = optionColumns[0]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.length);
116
- const emptyList = [
117
- {
118
- [fieldNames.value]: '__EMPTY__',
119
- [FIX_LABEL]: notFoundContent,
120
- disabled: true,
121
- },
122
- ];
123
- const columnProps = Object.assign(Object.assign({}, props), { multiple: !isEmpty && multiple, onSelect: onPathSelect, onActive: onPathOpen, onToggleOpen: toggleOpen, checkedSet,
124
- halfCheckedSet,
125
- loadingKeys,
126
- isSelectable });
127
- // >>>>> Columns
128
- const mergedOptionColumns = isEmpty ? [{ options: emptyList }] : optionColumns;
129
- const columnNodes = mergedOptionColumns.map((col, index) => {
130
- const prevValuePath = activeValueCells.slice(0, index);
131
- const activeValue = activeValueCells[index];
132
- return (React.createElement(Column, Object.assign({ key: index, level: index, optionHeight: optionHeight, dropdownVisible: dropdownVisible }, columnProps, { prefixCls: mergedPrefixCls, options: col.options, searchValue: searchValue, prevValuePath: prevValuePath, activeValue: activeValue, renderItem: renderItem })));
133
- });
134
- // >>>>> Render
135
- return (React.createElement("div", { className: classNames(`${mergedPrefixCls}-menus`, {
136
- [`${mergedPrefixCls}-menu-empty`]: isEmpty,
137
- [`${mergedPrefixCls}-rtl`]: rtl,
138
- }), ref: containerRef }, columnNodes));
76
+ });
77
+ }
78
+ }, [options, loadingKeys, fieldNames]); // ========================== Values ==========================
79
+
80
+ const checkedSet = React.useMemo(() => new Set(toPathKeys(values)), [values]);
81
+ const halfCheckedSet = React.useMemo(() => new Set(toPathKeys(halfValues)), [halfValues]); // ====================== Accessibility =======================
82
+
83
+ const [activeValueCells, setActiveValueCells] = useActive(); // =========================== Path ===========================
84
+
85
+ const onPathOpen = nextValueCells => {
86
+ setActiveValueCells(nextValueCells); // Trigger loadData
87
+
88
+ internalLoadData(nextValueCells);
89
+ };
90
+
91
+ const isSelectable = option => {
92
+ const {
93
+ disabled
94
+ } = option;
95
+ const isMergedLeaf = isLeaf(option, fieldNames);
96
+ return !disabled && (isMergedLeaf || changeOnSelect || multiple);
97
+ };
98
+
99
+ const onPathSelect = (valuePath, leaf, fromKeyboard = false) => {
100
+ onSelect(valuePath);
101
+
102
+ if (!multiple && (leaf || changeOnSelect && (expandTrigger === 'hover' || fromKeyboard))) {
103
+ toggleOpen(false);
104
+ }
105
+ }; // ========================== Option ==========================
106
+
107
+
108
+ const mergedOptions = React.useMemo(() => {
109
+ if (searchValue) {
110
+ return searchOptions;
111
+ }
112
+
113
+ return options;
114
+ }, [searchValue, searchOptions, options]); // ========================== Column ==========================
115
+
116
+ const optionColumns = React.useMemo(() => {
117
+ const optionList = [{
118
+ options: mergedOptions
119
+ }];
120
+ let currentList = mergedOptions;
121
+
122
+ for (let i = 0; i < activeValueCells.length; i += 1) {
123
+ const activeValueCell = activeValueCells[i];
124
+ const currentOption = currentList.find(option => option[fieldNames.value] === activeValueCell);
125
+ const subOptions = currentOption === null || currentOption === void 0 ? void 0 : currentOption[fieldNames.children];
126
+
127
+ if (!(subOptions === null || subOptions === void 0 ? void 0 : subOptions.length)) {
128
+ break;
129
+ }
130
+
131
+ currentList = subOptions;
132
+ optionList.push({
133
+ options: subOptions
134
+ });
135
+ }
136
+
137
+ return optionList;
138
+ }, [mergedOptions, activeValueCells, fieldNames]); // ========================= Keyboard =========================
139
+
140
+ const onKeyboardSelect = (selectValueCells, option) => {
141
+ if (isSelectable(option)) {
142
+ onPathSelect(selectValueCells, isLeaf(option, fieldNames), true);
143
+ }
144
+ };
145
+
146
+ useKeyboard(ref, mergedOptions, fieldNames, activeValueCells, onPathOpen, onKeyboardSelect); // >>>>> Active Scroll
147
+
148
+ React.useEffect(() => {
149
+ var _a;
150
+
151
+ for (let i = 0; i < activeValueCells.length; i += 1) {
152
+ const cellPath = activeValueCells.slice(0, i + 1);
153
+ const cellKeyPath = toPathKey(cellPath);
154
+ const ele = (_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(`li[data-path-key="${cellKeyPath.replace(/\\{0,2}"/g, '\\"')}"]` // matches unescaped double quotes
155
+ );
156
+
157
+ if (ele) {
158
+ scrollIntoParentView(ele);
159
+ }
160
+ }
161
+ }, [activeValueCells]); // ========================== Render ==========================
162
+ // >>>>> Empty
163
+
164
+ const isEmpty = !((_b = (_a = optionColumns[0]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.length);
165
+ const emptyList = [{
166
+ [fieldNames.value]: '__EMPTY__',
167
+ [FIX_LABEL]: notFoundContent,
168
+ disabled: true
169
+ }];
170
+ const columnProps = Object.assign(Object.assign({}, props), {
171
+ multiple: !isEmpty && multiple,
172
+ onSelect: onPathSelect,
173
+ onActive: onPathOpen,
174
+ onToggleOpen: toggleOpen,
175
+ checkedSet,
176
+ halfCheckedSet,
177
+ loadingKeys,
178
+ isSelectable
179
+ }); // >>>>> Columns
180
+
181
+ const mergedOptionColumns = isEmpty ? [{
182
+ options: emptyList
183
+ }] : optionColumns;
184
+ const columnNodes = mergedOptionColumns.map((col, index) => {
185
+ const prevValuePath = activeValueCells.slice(0, index);
186
+ const activeValue = activeValueCells[index];
187
+ return React.createElement(Column, Object.assign({
188
+ key: index,
189
+ level: index,
190
+ optionHeight: optionHeight,
191
+ dropdownVisible: dropdownVisible
192
+ }, columnProps, {
193
+ prefixCls: mergedPrefixCls,
194
+ options: col.options,
195
+ searchValue: searchValue,
196
+ prevValuePath: prevValuePath,
197
+ activeValue: activeValue,
198
+ renderItem: renderItem
199
+ }));
200
+ }); // >>>>> Render
201
+
202
+ return React.createElement("div", {
203
+ className: classNames(`${mergedPrefixCls}-menus`, {
204
+ [`${mergedPrefixCls}-menu-empty`]: isEmpty,
205
+ [`${mergedPrefixCls}-rtl`]: rtl
206
+ }),
207
+ ref: containerRef
208
+ }, columnNodes);
139
209
  });
140
- export default RefOptionList;
141
- //# sourceMappingURL=index.js.map
210
+ export default RefOptionList;