tntd 2.0.1 → 2.0.3

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 (415) hide show
  1. package/es/ellipsis/index.js +1 -1
  2. package/es/ellipsis/index.js.map +1 -1
  3. package/es/exception/exception.js +34 -0
  4. package/es/exception/exception.js.map +1 -0
  5. package/es/exception/exception.less +29 -0
  6. package/es/exception/index.js +5 -0
  7. package/es/exception/index.js.map +1 -0
  8. package/es/handle/index.js +52 -33
  9. package/es/handle/index.js.map +1 -1
  10. package/es/index.js +2 -0
  11. package/es/index.js.map +1 -1
  12. package/es/locale/default.js +3 -2
  13. package/es/locale/default.js.map +1 -1
  14. package/es/locale/en_US.js +13 -1
  15. package/es/locale/en_US.js.map +1 -1
  16. package/es/locale/zh_CN.js +13 -1
  17. package/es/locale/zh_CN.js.map +1 -1
  18. package/es/page/index.js +1 -1
  19. package/es/page/index.js.map +1 -1
  20. package/es/prev-locale.js +7 -1
  21. package/es/prev-locale.js.map +1 -1
  22. package/es/steps/index.js +3 -2
  23. package/es/steps/index.js.map +1 -1
  24. package/es/steps/steps.js +46 -0
  25. package/es/steps/steps.js.map +1 -0
  26. package/es/steps/style/index.less +11 -0
  27. package/es/steps/style/nav.less +273 -0
  28. package/es/steps/style/small.less +5 -0
  29. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +8 -0
  30. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -0
  31. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +3 -0
  32. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -0
  33. package/es/tntd-cascader/AntdCascader/component/SizeContext.js +3 -0
  34. package/es/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -0
  35. package/es/tntd-cascader/AntdCascader/component/context.js +14 -0
  36. package/es/tntd-cascader/AntdCascader/component/context.js.map +1 -0
  37. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +20 -0
  38. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -0
  39. package/es/tntd-cascader/AntdCascader/component/getIcons.js +52 -0
  40. package/es/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -0
  41. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +24 -0
  42. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -0
  43. package/es/tntd-cascader/AntdCascader/config/utils.js +24 -0
  44. package/es/tntd-cascader/AntdCascader/config/utils.js.map +1 -0
  45. package/es/tntd-cascader/AntdCascader/config/warning.js +15 -0
  46. package/es/tntd-cascader/AntdCascader/config/warning.js.map +1 -0
  47. package/es/tntd-cascader/AntdCascader/index.css +2327 -0
  48. package/es/tntd-cascader/AntdCascader/index.js +149 -0
  49. package/es/tntd-cascader/AntdCascader/index.js.map +1 -0
  50. package/es/tntd-cascader/AntdCascader/interface.js +5 -0
  51. package/es/tntd-cascader/AntdCascader/interface.js.map +1 -0
  52. package/es/tntd-cascader/img/no-data-s.png +0 -0
  53. package/es/tntd-cascader/index.js +2 -0
  54. package/es/tntd-cascader/index.js.map +1 -0
  55. package/es/tntd-cascader/rc-cascader/Cascader.js +270 -0
  56. package/es/tntd-cascader/rc-cascader/Cascader.js.map +1 -0
  57. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +14 -0
  58. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -0
  59. package/es/tntd-cascader/rc-cascader/OptionList/Column.js +126 -0
  60. package/es/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -0
  61. package/es/tntd-cascader/rc-cascader/OptionList/index.js +140 -0
  62. package/es/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -0
  63. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +24 -0
  64. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -0
  65. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +145 -0
  66. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -0
  67. package/es/tntd-cascader/rc-cascader/context.js +4 -0
  68. package/es/tntd-cascader/rc-cascader/context.js.map +1 -0
  69. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +41 -0
  70. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -0
  71. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +30 -0
  72. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -0
  73. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +19 -0
  74. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -0
  75. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +15 -0
  76. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -0
  77. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +26 -0
  78. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -0
  79. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +46 -0
  80. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -0
  81. package/es/tntd-cascader/rc-cascader/index.js +3 -0
  82. package/es/tntd-cascader/rc-cascader/index.js.map +1 -0
  83. package/es/tntd-cascader/rc-cascader/index.less +19 -0
  84. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +41 -0
  85. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js.map +1 -0
  86. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +37 -0
  87. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js.map +1 -0
  88. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +30 -0
  89. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js.map +1 -0
  90. package/es/tntd-layout/Avatar.js +25 -19
  91. package/es/tntd-layout/Avatar.js.map +1 -1
  92. package/es/tntd-layout/EnterpriseLayout/Avatar.js +10 -8
  93. package/es/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
  94. package/es/tntd-layout/EnterpriseLayout/Language.js +5 -4
  95. package/es/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
  96. package/es/tntd-layout/EnterpriseLayout/Theme.js +7 -6
  97. package/es/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
  98. package/es/tntd-layout/HeaderActions.js +5 -4
  99. package/es/tntd-layout/HeaderActions.js.map +1 -1
  100. package/es/tntd-layout/Layout.js +2 -2
  101. package/es/tntd-layout/Layout.js.map +1 -1
  102. package/es/tntd-layout/SideMenu.js.map +1 -1
  103. package/es/tntd-layout/index.js +2 -2
  104. package/es/tntd-layout/index.js.map +1 -1
  105. package/es/tntd-layout/storage.js +10 -2
  106. package/es/tntd-layout/storage.js.map +1 -1
  107. package/lib/ellipsis/index.js +1 -1
  108. package/lib/ellipsis/index.js.map +1 -1
  109. package/lib/exception/exception.d.ts +16 -0
  110. package/lib/exception/exception.d.ts.map +1 -0
  111. package/lib/exception/exception.js +41 -0
  112. package/lib/exception/exception.js.map +1 -0
  113. package/lib/exception/exception.less +29 -0
  114. package/lib/exception/index.d.ts +5 -0
  115. package/lib/exception/index.d.ts.map +1 -0
  116. package/lib/exception/index.js +21 -0
  117. package/lib/exception/index.js.map +1 -0
  118. package/lib/handle/index.d.ts.map +1 -1
  119. package/lib/handle/index.js +52 -33
  120. package/lib/handle/index.js.map +1 -1
  121. package/lib/index.d.ts +2 -0
  122. package/lib/index.d.ts.map +1 -1
  123. package/lib/index.js +5 -1
  124. package/lib/index.js.map +1 -1
  125. package/lib/locale/default.d.ts +13 -1
  126. package/lib/locale/default.d.ts.map +1 -1
  127. package/lib/locale/default.js +3 -3
  128. package/lib/locale/default.js.map +1 -1
  129. package/lib/locale/en_US.d.ts +13 -1
  130. package/lib/locale/en_US.d.ts.map +1 -1
  131. package/lib/locale/en_US.js +13 -2
  132. package/lib/locale/en_US.js.map +1 -1
  133. package/lib/locale/zh_CN.d.ts +13 -1
  134. package/lib/locale/zh_CN.d.ts.map +1 -1
  135. package/lib/locale/zh_CN.js +13 -2
  136. package/lib/locale/zh_CN.js.map +1 -1
  137. package/lib/page/index.js +1 -1
  138. package/lib/page/index.js.map +1 -1
  139. package/lib/prev-locale.d.ts +6 -0
  140. package/lib/prev-locale.d.ts.map +1 -1
  141. package/lib/prev-locale.js +7 -1
  142. package/lib/prev-locale.js.map +1 -1
  143. package/lib/steps/index.d.ts +3 -2
  144. package/lib/steps/index.d.ts.map +1 -1
  145. package/lib/steps/index.js +4 -6
  146. package/lib/steps/index.js.map +1 -1
  147. package/lib/steps/steps.d.ts +12 -0
  148. package/lib/steps/steps.d.ts.map +1 -0
  149. package/lib/steps/steps.js +67 -0
  150. package/lib/steps/steps.js.map +1 -0
  151. package/lib/steps/style/index.less +11 -0
  152. package/lib/steps/style/nav.less +273 -0
  153. package/lib/steps/style/small.less +5 -0
  154. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.d.ts +10 -0
  155. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.d.ts.map +1 -0
  156. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +35 -0
  157. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js.map +1 -0
  158. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.d.ts +4 -0
  159. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.d.ts.map +1 -0
  160. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +29 -0
  161. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js.map +1 -0
  162. package/lib/tntd-cascader/AntdCascader/component/SizeContext.d.ts +4 -0
  163. package/lib/tntd-cascader/AntdCascader/component/SizeContext.d.ts.map +1 -0
  164. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +29 -0
  165. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js.map +1 -0
  166. package/lib/tntd-cascader/AntdCascader/component/context.d.ts +42 -0
  167. package/lib/tntd-cascader/AntdCascader/component/context.d.ts.map +1 -0
  168. package/lib/tntd-cascader/AntdCascader/component/context.js +20 -0
  169. package/lib/tntd-cascader/AntdCascader/component/context.js.map +1 -0
  170. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.d.ts +5 -0
  171. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.d.ts.map +1 -0
  172. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +48 -0
  173. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -0
  174. package/lib/tntd-cascader/AntdCascader/component/getIcons.d.ts +25 -0
  175. package/lib/tntd-cascader/AntdCascader/component/getIcons.d.ts.map +1 -0
  176. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +78 -0
  177. package/lib/tntd-cascader/AntdCascader/component/getIcons.js.map +1 -0
  178. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.d.ts +9 -0
  179. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.d.ts.map +1 -0
  180. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +54 -0
  181. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js.map +1 -0
  182. package/lib/tntd-cascader/AntdCascader/config/utils.d.ts +6 -0
  183. package/lib/tntd-cascader/AntdCascader/config/utils.d.ts.map +1 -0
  184. package/lib/tntd-cascader/AntdCascader/config/utils.js +34 -0
  185. package/lib/tntd-cascader/AntdCascader/config/utils.js.map +1 -0
  186. package/lib/tntd-cascader/AntdCascader/config/warning.d.ts +4 -0
  187. package/lib/tntd-cascader/AntdCascader/config/warning.d.ts.map +1 -0
  188. package/lib/tntd-cascader/AntdCascader/config/warning.js +40 -0
  189. package/lib/tntd-cascader/AntdCascader/config/warning.js.map +1 -0
  190. package/lib/tntd-cascader/AntdCascader/index.css +2327 -0
  191. package/lib/tntd-cascader/AntdCascader/index.d.ts +44 -0
  192. package/lib/tntd-cascader/AntdCascader/index.d.ts.map +1 -0
  193. package/lib/tntd-cascader/AntdCascader/index.js +177 -0
  194. package/lib/tntd-cascader/AntdCascader/index.js.map +1 -0
  195. package/lib/tntd-cascader/AntdCascader/interface.d.ts +25 -0
  196. package/lib/tntd-cascader/AntdCascader/interface.d.ts.map +1 -0
  197. package/lib/tntd-cascader/AntdCascader/interface.js +9 -0
  198. package/lib/tntd-cascader/AntdCascader/interface.js.map +1 -0
  199. package/lib/tntd-cascader/img/no-data-s.png +0 -0
  200. package/lib/tntd-cascader/index.d.ts +2 -0
  201. package/lib/tntd-cascader/index.d.ts.map +1 -0
  202. package/lib/tntd-cascader/index.js +9 -0
  203. package/lib/tntd-cascader/index.js.map +1 -0
  204. package/lib/tntd-cascader/rc-cascader/Cascader.d.ts +92 -0
  205. package/lib/tntd-cascader/rc-cascader/Cascader.d.ts.map +1 -0
  206. package/lib/tntd-cascader/rc-cascader/Cascader.js +298 -0
  207. package/lib/tntd-cascader/rc-cascader/Cascader.js.map +1 -0
  208. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.d.ts +10 -0
  209. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.d.ts.map +1 -0
  210. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +43 -0
  211. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js.map +1 -0
  212. package/lib/tntd-cascader/rc-cascader/OptionList/Column.d.ts +26 -0
  213. package/lib/tntd-cascader/rc-cascader/OptionList/Column.d.ts.map +1 -0
  214. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +156 -0
  215. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js.map +1 -0
  216. package/lib/tntd-cascader/rc-cascader/OptionList/index.d.ts +5 -0
  217. package/lib/tntd-cascader/rc-cascader/OptionList/index.d.ts.map +1 -0
  218. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +168 -0
  219. package/lib/tntd-cascader/rc-cascader/OptionList/index.js.map +1 -0
  220. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.d.ts +7 -0
  221. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.d.ts.map +1 -0
  222. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +52 -0
  223. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js.map +1 -0
  224. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.d.ts +6 -0
  225. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.d.ts.map +1 -0
  226. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +173 -0
  227. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js.map +1 -0
  228. package/lib/tntd-cascader/rc-cascader/context.d.ts +26 -0
  229. package/lib/tntd-cascader/rc-cascader/context.d.ts.map +1 -0
  230. package/lib/tntd-cascader/rc-cascader/context.js +29 -0
  231. package/lib/tntd-cascader/rc-cascader/context.js.map +1 -0
  232. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.d.ts +11 -0
  233. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.d.ts.map +1 -0
  234. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +66 -0
  235. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js.map +1 -0
  236. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.d.ts +11 -0
  237. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.d.ts.map +1 -0
  238. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +55 -0
  239. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js.map +1 -0
  240. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.d.ts +4 -0
  241. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.d.ts.map +1 -0
  242. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +44 -0
  243. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js.map +1 -0
  244. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.d.ts +6 -0
  245. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.d.ts.map +1 -0
  246. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +41 -0
  247. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js.map +1 -0
  248. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.d.ts +3 -0
  249. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.d.ts.map +1 -0
  250. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +55 -0
  251. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js.map +1 -0
  252. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.d.ts +5 -0
  253. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.d.ts.map +1 -0
  254. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +72 -0
  255. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js.map +1 -0
  256. package/lib/tntd-cascader/rc-cascader/index.d.ts +4 -0
  257. package/lib/tntd-cascader/rc-cascader/index.d.ts.map +1 -0
  258. package/lib/tntd-cascader/rc-cascader/index.js +8 -0
  259. package/lib/tntd-cascader/rc-cascader/index.js.map +1 -0
  260. package/lib/tntd-cascader/rc-cascader/index.less +19 -0
  261. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.d.ts +11 -0
  262. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.d.ts.map +1 -0
  263. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +50 -0
  264. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js.map +1 -0
  265. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.d.ts +10 -0
  266. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.d.ts.map +1 -0
  267. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +42 -0
  268. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js.map +1 -0
  269. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.d.ts +5 -0
  270. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.d.ts.map +1 -0
  271. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +37 -0
  272. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js.map +1 -0
  273. package/lib/tntd-layout/Avatar.d.ts.map +1 -1
  274. package/lib/tntd-layout/Avatar.js +25 -19
  275. package/lib/tntd-layout/Avatar.js.map +1 -1
  276. package/lib/tntd-layout/EnterpriseLayout/Avatar.d.ts.map +1 -1
  277. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +10 -8
  278. package/lib/tntd-layout/EnterpriseLayout/Avatar.js.map +1 -1
  279. package/lib/tntd-layout/EnterpriseLayout/Language.js +4 -3
  280. package/lib/tntd-layout/EnterpriseLayout/Language.js.map +1 -1
  281. package/lib/tntd-layout/EnterpriseLayout/Theme.js +6 -5
  282. package/lib/tntd-layout/EnterpriseLayout/Theme.js.map +1 -1
  283. package/lib/tntd-layout/HeaderActions.js +5 -4
  284. package/lib/tntd-layout/HeaderActions.js.map +1 -1
  285. package/lib/tntd-layout/Layout.js +2 -2
  286. package/lib/tntd-layout/Layout.js.map +1 -1
  287. package/lib/tntd-layout/SideMenu.js.map +1 -1
  288. package/lib/tntd-layout/index.d.ts.map +1 -1
  289. package/lib/tntd-layout/index.js +2 -2
  290. package/lib/tntd-layout/index.js.map +1 -1
  291. package/lib/tntd-layout/storage.d.ts +3 -2
  292. package/lib/tntd-layout/storage.d.ts.map +1 -1
  293. package/lib/tntd-layout/storage.js +15 -3
  294. package/lib/tntd-layout/storage.js.map +1 -1
  295. package/package.json +11 -2
  296. package/es/array-input/style/index.js +0 -2
  297. package/es/array-input/style/index.js.map +0 -1
  298. package/es/auth-context/style/index.js +0 -2
  299. package/es/auth-context/style/index.js.map +0 -1
  300. package/es/development-login/style/index.js +0 -2
  301. package/es/development-login/style/index.js.map +0 -1
  302. package/es/ellipsis/style/index.js +0 -2
  303. package/es/ellipsis/style/index.js.map +0 -1
  304. package/es/empty/render-empty.js +0 -19
  305. package/es/empty/render-empty.js.map +0 -1
  306. package/es/empty/style/index.js +0 -3
  307. package/es/empty/style/index.js.map +0 -1
  308. package/es/handle/style/index.js +0 -2
  309. package/es/handle/style/index.js.map +0 -1
  310. package/es/icon-list/style/index.js +0 -120
  311. package/es/icon-list/style/index.js.map +0 -1
  312. package/es/img/style/index.js +0 -2
  313. package/es/img/style/index.js.map +0 -1
  314. package/es/loading-button/style/index.js +0 -2
  315. package/es/loading-button/style/index.js.map +0 -1
  316. package/es/page/style/index.js +0 -2
  317. package/es/page/style/index.js.map +0 -1
  318. package/es/query-form/style/index.js +0 -2
  319. package/es/query-form/style/index.js.map +0 -1
  320. package/es/query-list-scene/style/index.js +0 -2
  321. package/es/query-list-scene/style/index.js.map +0 -1
  322. package/es/render-empty/style/index.js +0 -2
  323. package/es/render-empty/style/index.js.map +0 -1
  324. package/es/table/style/index.js +0 -3
  325. package/es/table/style/index.js.map +0 -1
  326. package/es/title/style/index.js +0 -2
  327. package/es/title/style/index.js.map +0 -1
  328. package/es/tntd-icon/style/index.js +0 -2
  329. package/es/tntd-icon/style/index.js.map +0 -1
  330. package/es/tntd-layout/style/index.js +0 -2
  331. package/es/tntd-layout/style/index.js.map +0 -1
  332. package/es/tntd-modal/style/index.js +0 -2
  333. package/es/tntd-modal/style/index.js.map +0 -1
  334. package/es/tntd-select/style/index.js +0 -2
  335. package/es/tntd-select/style/index.js.map +0 -1
  336. package/lib/array-input/style/index.d.ts +0 -1
  337. package/lib/array-input/style/index.d.ts.map +0 -1
  338. package/lib/array-input/style/index.js +0 -2
  339. package/lib/array-input/style/index.js.map +0 -1
  340. package/lib/auth-context/style/index.d.ts +0 -1
  341. package/lib/auth-context/style/index.d.ts.map +0 -1
  342. package/lib/auth-context/style/index.js +0 -2
  343. package/lib/auth-context/style/index.js.map +0 -1
  344. package/lib/development-login/style/index.d.ts +0 -1
  345. package/lib/development-login/style/index.d.ts.map +0 -1
  346. package/lib/development-login/style/index.js +0 -2
  347. package/lib/development-login/style/index.js.map +0 -1
  348. package/lib/ellipsis/style/index.d.ts +0 -1
  349. package/lib/ellipsis/style/index.d.ts.map +0 -1
  350. package/lib/ellipsis/style/index.js +0 -2
  351. package/lib/ellipsis/style/index.js.map +0 -1
  352. package/lib/empty/render-empty.d.ts +0 -3
  353. package/lib/empty/render-empty.d.ts.map +0 -1
  354. package/lib/empty/render-empty.js +0 -26
  355. package/lib/empty/render-empty.js.map +0 -1
  356. package/lib/empty/style/index.d.ts +0 -3
  357. package/lib/empty/style/index.d.ts.map +0 -1
  358. package/lib/empty/style/index.js +0 -5
  359. package/lib/empty/style/index.js.map +0 -1
  360. package/lib/handle/style/index.d.ts +0 -1
  361. package/lib/handle/style/index.d.ts.map +0 -1
  362. package/lib/handle/style/index.js +0 -2
  363. package/lib/handle/style/index.js.map +0 -1
  364. package/lib/icon-list/style/index.d.ts +0 -3
  365. package/lib/icon-list/style/index.d.ts.map +0 -1
  366. package/lib/icon-list/style/index.js +0 -122
  367. package/lib/icon-list/style/index.js.map +0 -1
  368. package/lib/img/style/index.d.ts +0 -1
  369. package/lib/img/style/index.d.ts.map +0 -1
  370. package/lib/img/style/index.js +0 -2
  371. package/lib/img/style/index.js.map +0 -1
  372. package/lib/loading-button/style/index.d.ts +0 -1
  373. package/lib/loading-button/style/index.d.ts.map +0 -1
  374. package/lib/loading-button/style/index.js +0 -2
  375. package/lib/loading-button/style/index.js.map +0 -1
  376. package/lib/page/style/index.d.ts +0 -1
  377. package/lib/page/style/index.d.ts.map +0 -1
  378. package/lib/page/style/index.js +0 -2
  379. package/lib/page/style/index.js.map +0 -1
  380. package/lib/query-form/style/index.d.ts +0 -1
  381. package/lib/query-form/style/index.d.ts.map +0 -1
  382. package/lib/query-form/style/index.js +0 -2
  383. package/lib/query-form/style/index.js.map +0 -1
  384. package/lib/query-list-scene/style/index.d.ts +0 -1
  385. package/lib/query-list-scene/style/index.d.ts.map +0 -1
  386. package/lib/query-list-scene/style/index.js +0 -2
  387. package/lib/query-list-scene/style/index.js.map +0 -1
  388. package/lib/render-empty/style/index.d.ts +0 -2
  389. package/lib/render-empty/style/index.d.ts.map +0 -1
  390. package/lib/render-empty/style/index.js +0 -4
  391. package/lib/render-empty/style/index.js.map +0 -1
  392. package/lib/table/style/index.d.ts +0 -3
  393. package/lib/table/style/index.d.ts.map +0 -1
  394. package/lib/table/style/index.js +0 -5
  395. package/lib/table/style/index.js.map +0 -1
  396. package/lib/title/style/index.d.ts +0 -1
  397. package/lib/title/style/index.d.ts.map +0 -1
  398. package/lib/title/style/index.js +0 -2
  399. package/lib/title/style/index.js.map +0 -1
  400. package/lib/tntd-icon/style/index.d.ts +0 -1
  401. package/lib/tntd-icon/style/index.d.ts.map +0 -1
  402. package/lib/tntd-icon/style/index.js +0 -2
  403. package/lib/tntd-icon/style/index.js.map +0 -1
  404. package/lib/tntd-layout/style/index.d.ts +0 -1
  405. package/lib/tntd-layout/style/index.d.ts.map +0 -1
  406. package/lib/tntd-layout/style/index.js +0 -2
  407. package/lib/tntd-layout/style/index.js.map +0 -1
  408. package/lib/tntd-modal/style/index.d.ts +0 -1
  409. package/lib/tntd-modal/style/index.d.ts.map +0 -1
  410. package/lib/tntd-modal/style/index.js +0 -2
  411. package/lib/tntd-modal/style/index.js.map +0 -1
  412. package/lib/tntd-select/style/index.d.ts +0 -1
  413. package/lib/tntd-select/style/index.d.ts.map +0 -1
  414. package/lib/tntd-select/style/index.js +0 -2
  415. package/lib/tntd-select/style/index.js.map +0 -1
@@ -0,0 +1,126 @@
1
+ // @ts-nocheck
2
+ import * as React from 'react';
3
+ import classNames from 'classnames';
4
+ import { isLeaf, toPathKey } from '../utils/commonUtil';
5
+ import CascaderContext from '../context';
6
+ import Checkbox from './Checkbox';
7
+ import { SEARCH_MARK } from '../hooks/useSearchOptions';
8
+ import List from 'rc-virtual-list';
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, }) {
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(32 * index);
24
+ }, 5);
25
+ }
26
+ }
27
+ return () => {
28
+ if (timer) {
29
+ window.clearTimeout(timer);
30
+ }
31
+ timer = null;
32
+ };
33
+ }, [multiple, activeValue, options, fieldNames, dropdownVisible]);
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: 32, 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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Column.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/Column.tsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-nocheck\nimport * as React from 'react';\nimport classNames from 'classnames';\nimport { isLeaf, toPathKey } from '../utils/commonUtil';\nimport CascaderContext from '../context';\nimport Checkbox from './Checkbox';\nimport type { DefaultOptionType, SingleValueType } from '../Cascader';\nimport { SEARCH_MARK } from '../hooks/useSearchOptions';\nimport List, { ListRef } from 'rc-virtual-list';\nimport type { RenderItem } from '../context';\n\nexport const FIX_LABEL = '__cascader_fix_label__';\n\nexport interface ColumnProps {\n prefixCls: string;\n multiple?: boolean;\n options: DefaultOptionType[];\n /** Current Column opened item key */\n activeValue?: React.Key;\n /** The value path before current column */\n prevValuePath: React.Key[];\n onToggleOpen: (open: boolean) => void;\n onSelect: (valuePath: SingleValueType, leaf: boolean) => void;\n onActive: (valuePath: SingleValueType) => void;\n checkedSet: Set<React.Key>;\n halfCheckedSet: Set<React.Key>;\n loadingKeys: React.Key[];\n isSelectable: (option: DefaultOptionType) => boolean;\n renderItem?: (item: RenderItem) => React.ReactNode;\n searchValue?: string;\n level?: number;\n dropdownVisible?: boolean;\n}\n\nexport default function Column({\n prefixCls,\n multiple,\n options,\n activeValue,\n prevValuePath,\n onToggleOpen,\n onSelect,\n onActive,\n checkedSet,\n halfCheckedSet,\n loadingKeys,\n isSelectable,\n renderItem,\n searchValue,\n level,\n dropdownVisible,\n}: ColumnProps) {\n const ref = React.useRef<ListRef>(null);\n const menuPrefixCls = `${prefixCls}-menu ${prefixCls}-menu-${level}`;\n const menuItemPrefixCls = `${prefixCls}-menu-item`;\n\n const {\n fieldNames,\n changeOnSelect,\n expandTrigger,\n expandIcon,\n loadingIcon,\n dropdownMenuColumnStyle,\n } = React.useContext(CascaderContext);\n\n const hoverOpen = expandTrigger === 'hover';\n\n /** 单选情况下滚动到相应的位置 */\n React.useEffect(() => {\n let timer = null;\n if (ref.current && ref.current.scrollTo && !multiple && dropdownVisible) {\n const index = options.findIndex((it) => it[fieldNames.value] === activeValue);\n\n if (index > 0 && !isNaN(index)) {\n timer = window.setTimeout(() => {\n ref.current.scrollTo(32 * index);\n }, 5);\n }\n }\n\n return () => {\n if (timer) {\n window.clearTimeout(timer);\n }\n timer = null;\n };\n }, [multiple, activeValue, options, fieldNames, dropdownVisible]);\n\n // ============================ Option ============================\n const optionInfoList = React.useMemo(\n () =>\n options.map((option) => {\n const { disabled } = option;\n const searchOptions = option[SEARCH_MARK];\n const label = option[FIX_LABEL] ?? option[fieldNames.label];\n const value = option[fieldNames.value];\n\n const isMergedLeaf = isLeaf(option, fieldNames);\n\n // Get real value of option. Search option is different way.\n const fullPath = searchOptions\n ? // @ts-ignore\n searchOptions.map((opt) => opt[fieldNames.value])\n : [...prevValuePath, value];\n const fullPathKey = toPathKey(fullPath);\n\n const isLoading = loadingKeys.includes(fullPathKey);\n\n // >>>>> checked\n const checked = checkedSet.has(fullPathKey);\n\n // >>>>> halfChecked\n const halfChecked = halfCheckedSet.has(fullPathKey);\n\n return {\n disabled,\n label,\n value,\n isLeaf: isMergedLeaf,\n isLoading,\n checked,\n halfChecked,\n option,\n fullPath,\n fullPathKey,\n };\n }),\n [options, checkedSet, fieldNames, halfCheckedSet, loadingKeys, prevValuePath],\n );\n // ============================ Render ============================\n return (\n <ul className={menuPrefixCls} role=\"menu\">\n <List\n className={\n optionInfoList[0].fullPathKey === '__EMPTY__' || !!searchValue\n ? 'rc-virtual-list-full'\n : ''\n }\n data={optionInfoList}\n height={180}\n itemHeight={32}\n itemKey=\"value\"\n ref={ref}\n >\n {({\n disabled,\n label,\n value,\n isLeaf: isMergedLeaf,\n isLoading,\n checked,\n halfChecked,\n option,\n fullPath,\n fullPathKey,\n }) => {\n // >>>>> Open\n const triggerOpenPath = () => {\n if (!disabled && (!hoverOpen || !isMergedLeaf)) {\n onActive(fullPath);\n }\n };\n\n // >>>>> Selection\n const triggerSelect = () => {\n if (isSelectable(option)) {\n onSelect(fullPath, isMergedLeaf);\n }\n };\n\n // >>>>> Title\n let title: string;\n if (typeof option.title === 'string') {\n title = option.title;\n } else if (typeof label === 'string') {\n title = label;\n }\n return (\n <li\n key={fullPathKey}\n className={classNames(menuItemPrefixCls, {\n [`${menuItemPrefixCls}-expand`]: !isMergedLeaf,\n [`${menuItemPrefixCls}-active`]: activeValue === value,\n [`${menuItemPrefixCls}-disabled`]: disabled,\n [`${menuItemPrefixCls}-loading`]: isLoading,\n })}\n style={dropdownMenuColumnStyle}\n role=\"menuitemcheckbox\"\n // @ts-ignore\n title={title}\n aria-checked={checked}\n data-path-key={fullPathKey}\n onClick={() => {\n triggerOpenPath();\n if (!multiple || isMergedLeaf) {\n triggerSelect();\n }\n }}\n onDoubleClick={() => {\n if (changeOnSelect) {\n onToggleOpen(false);\n }\n }}\n onMouseEnter={() => {\n if (hoverOpen) {\n triggerOpenPath();\n }\n }}\n onMouseDown={(e) => {\n // Prevent selector from blurring\n e.preventDefault();\n }}\n >\n {multiple && (\n <Checkbox\n prefixCls={`${prefixCls}-checkbox`}\n checked={checked}\n halfChecked={halfChecked}\n disabled={disabled}\n onClick={(e: React.MouseEvent<HTMLSpanElement>) => {\n e.stopPropagation();\n triggerSelect();\n }}\n />\n )}\n <div className={`${menuItemPrefixCls}-content`}>\n {optionInfoList[0].fullPathKey !== '__EMPTY__' && renderItem\n ? renderItem(option, level)\n : label}\n </div>\n {!isLoading && expandIcon && !isMergedLeaf && (\n <div className={`${menuItemPrefixCls}-expand-icon`}>{expandIcon}</div>\n )}\n {isLoading && loadingIcon && (\n <div className={`${menuItemPrefixCls}-loading-icon`}>{loadingIcon}</div>\n )}\n </li>\n );\n }}\n </List>\n </ul>\n );\n}\n"]}
@@ -0,0 +1,140 @@
1
+ /* eslint-disable default-case */
2
+ // @ts-nocheck
3
+ import classNames from 'classnames';
4
+ import { useBaseProps } from 'rc-select';
5
+ import * as React from 'react';
6
+ import CascaderContext from '../context';
7
+ import { isLeaf, scrollIntoParentView, toPathKey, toPathKeys, toPathValueStr, } from '../utils/commonUtil';
8
+ import { toPathOptions } from '../utils/treeUtil';
9
+ import Column, { FIX_LABEL } from './Column';
10
+ import useActive from './useActive';
11
+ import useKeyboard from './useKeyboard';
12
+ const RefOptionList = React.forwardRef((props, ref) => {
13
+ var _a, _b;
14
+ const { prefixCls, multiple, searchValue, toggleOpen, notFoundContent, direction } = 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;
25
+ }
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, '\\"')}"]`);
107
+ if (ele) {
108
+ scrollIntoParentView(ele);
109
+ }
110
+ }
111
+ }, [activeValueCells]);
112
+ // ========================== Render ==========================
113
+ // >>>>> Empty
114
+ const isEmpty = !((_b = (_a = optionColumns[0]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.length);
115
+ const emptyList = [
116
+ {
117
+ [fieldNames.value]: '__EMPTY__',
118
+ [FIX_LABEL]: notFoundContent,
119
+ disabled: true,
120
+ },
121
+ ];
122
+ const columnProps = Object.assign(Object.assign({}, props), { multiple: !isEmpty && multiple, onSelect: onPathSelect, onActive: onPathOpen, onToggleOpen: toggleOpen, checkedSet,
123
+ halfCheckedSet,
124
+ loadingKeys,
125
+ isSelectable });
126
+ // >>>>> Columns
127
+ const mergedOptionColumns = isEmpty ? [{ options: emptyList }] : optionColumns;
128
+ const columnNodes = mergedOptionColumns.map((col, index) => {
129
+ const prevValuePath = activeValueCells.slice(0, index);
130
+ const activeValue = activeValueCells[index];
131
+ return (React.createElement(Column, Object.assign({ key: index, level: index, dropdownVisible: dropdownVisible }, columnProps, { prefixCls: mergedPrefixCls, options: col.options, searchValue: searchValue, prevValuePath: prevValuePath, activeValue: activeValue, renderItem: renderItem })));
132
+ });
133
+ // >>>>> Render
134
+ return (React.createElement("div", { className: classNames(`${mergedPrefixCls}-menus`, {
135
+ [`${mergedPrefixCls}-menu-empty`]: isEmpty,
136
+ [`${mergedPrefixCls}-rtl`]: rtl,
137
+ }), ref: containerRef }, columnNodes));
138
+ });
139
+ export default RefOptionList;
140
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/index.tsx"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable default-case */\n// @ts-nocheck\nimport classNames from 'classnames';\nimport { useBaseProps } from 'rc-select';\nimport type { RefOptionListProps } from 'rc-select/lib/OptionList';\nimport * as React from 'react';\nimport type { DefaultOptionType, SingleValueType } from '../Cascader';\nimport CascaderContext from '../context';\nimport {\n isLeaf,\n scrollIntoParentView,\n toPathKey,\n toPathKeys,\n toPathValueStr,\n} from '../utils/commonUtil';\nimport { toPathOptions } from '../utils/treeUtil';\nimport Column, { FIX_LABEL } from './Column';\nimport useActive from './useActive';\nimport useKeyboard from './useKeyboard';\n\nconst RefOptionList = React.forwardRef<RefOptionListProps>((props, ref) => {\n const { prefixCls, multiple, searchValue, toggleOpen, notFoundContent, direction } =\n useBaseProps();\n\n const containerRef = React.useRef<HTMLDivElement>();\n const rtl = direction === 'rtl';\n\n const {\n options,\n values,\n halfValues,\n fieldNames,\n changeOnSelect,\n onSelect,\n searchOptions,\n dropdownPrefixCls,\n loadData,\n expandTrigger,\n renderItem,\n dropdownVisible,\n } = React.useContext(CascaderContext);\n\n const mergedPrefixCls = dropdownPrefixCls || prefixCls;\n\n // ========================= loadData =========================\n const [loadingKeys, setLoadingKeys] = React.useState([]);\n\n const internalLoadData = (valueCells: React.Key[]) => {\n // Do not load when search\n if (!loadData || searchValue) {\n return;\n }\n\n const optionList = toPathOptions(valueCells, options, fieldNames);\n const rawOptions = optionList.map(({ option }) => option);\n const lastOption = rawOptions[rawOptions.length - 1];\n\n if (lastOption && !isLeaf(lastOption, fieldNames)) {\n const pathKey = toPathKey(valueCells);\n\n setLoadingKeys((keys) => [...keys, pathKey]);\n\n loadData(rawOptions);\n }\n };\n\n // zombieJ: This is bad. We should make this same as `rc-tree` to use Promise instead.\n React.useEffect(() => {\n if (loadingKeys.length) {\n loadingKeys.forEach((loadingKey) => {\n const valueStrCells = toPathValueStr(loadingKey);\n const optionList = toPathOptions(valueStrCells, options, fieldNames, true).map(\n ({ option }) => option,\n );\n const lastOption = optionList[optionList.length - 1];\n\n if (!lastOption || lastOption[fieldNames.children] || isLeaf(lastOption, fieldNames)) {\n setLoadingKeys((keys) => keys.filter((key) => key !== loadingKey));\n }\n });\n }\n }, [options, loadingKeys, fieldNames]);\n\n // ========================== Values ==========================\n const checkedSet = React.useMemo(() => new Set(toPathKeys(values)), [values]);\n const halfCheckedSet = React.useMemo(() => new Set(toPathKeys(halfValues)), [halfValues]);\n\n // ====================== Accessibility =======================\n const [activeValueCells, setActiveValueCells] = useActive();\n\n // =========================== Path ===========================\n const onPathOpen = (nextValueCells: React.Key[]) => {\n setActiveValueCells(nextValueCells);\n\n // Trigger loadData\n internalLoadData(nextValueCells);\n };\n\n const isSelectable = (option: DefaultOptionType) => {\n const { disabled } = option;\n\n const isMergedLeaf = isLeaf(option, fieldNames);\n return !disabled && (isMergedLeaf || changeOnSelect || multiple);\n };\n\n const onPathSelect = (valuePath: SingleValueType, leaf: boolean, fromKeyboard = false) => {\n onSelect(valuePath);\n\n if (!multiple && (leaf || (changeOnSelect && (expandTrigger === 'hover' || fromKeyboard)))) {\n toggleOpen(false);\n }\n };\n\n // ========================== Option ==========================\n const mergedOptions = React.useMemo(() => {\n if (searchValue) {\n return searchOptions;\n }\n\n return options;\n }, [searchValue, searchOptions, options]);\n\n // ========================== Column ==========================\n const optionColumns = React.useMemo(() => {\n const optionList = [{ options: mergedOptions }];\n let currentList = mergedOptions;\n\n for (let i = 0; i < activeValueCells.length; i += 1) {\n const activeValueCell = activeValueCells[i];\n const currentOption = currentList.find(\n (option) => option[fieldNames.value] === activeValueCell,\n );\n\n const subOptions = currentOption?.[fieldNames.children];\n if (!subOptions?.length) {\n break;\n }\n\n currentList = subOptions;\n optionList.push({ options: subOptions });\n }\n\n return optionList;\n }, [mergedOptions, activeValueCells, fieldNames]);\n\n // ========================= Keyboard =========================\n const onKeyboardSelect = (selectValueCells: SingleValueType, option: DefaultOptionType) => {\n if (isSelectable(option)) {\n onPathSelect(selectValueCells, isLeaf(option, fieldNames), true);\n }\n };\n\n useKeyboard(ref, mergedOptions, fieldNames, activeValueCells, onPathOpen, onKeyboardSelect);\n\n // >>>>> Active Scroll\n React.useEffect(() => {\n for (let i = 0; i < activeValueCells.length; i += 1) {\n const cellPath = activeValueCells.slice(0, i + 1);\n const cellKeyPath = toPathKey(cellPath);\n const ele = containerRef.current?.querySelector<HTMLElement>(\n `li[data-path-key=\"${cellKeyPath.replace(/\\\\{0,2}\"/g, '\\\\\"')}\"]`, // matches unescaped double quotes\n );\n if (ele) {\n scrollIntoParentView(ele);\n }\n }\n }, [activeValueCells]);\n\n // ========================== Render ==========================\n // >>>>> Empty\n const isEmpty = !optionColumns[0]?.options?.length;\n\n const emptyList: DefaultOptionType[] = [\n {\n [fieldNames.value as 'value']: '__EMPTY__',\n [FIX_LABEL as 'label']: notFoundContent,\n disabled: true,\n },\n ];\n\n const columnProps = {\n ...props,\n multiple: !isEmpty && multiple,\n onSelect: onPathSelect,\n onActive: onPathOpen,\n onToggleOpen: toggleOpen,\n checkedSet,\n halfCheckedSet,\n loadingKeys,\n isSelectable,\n };\n\n // >>>>> Columns\n const mergedOptionColumns = isEmpty ? [{ options: emptyList }] : optionColumns;\n\n const columnNodes: React.ReactElement[] = mergedOptionColumns.map((col, index) => {\n const prevValuePath = activeValueCells.slice(0, index);\n const activeValue = activeValueCells[index];\n\n return (\n <Column\n key={index}\n level={index}\n dropdownVisible={dropdownVisible}\n {...columnProps}\n prefixCls={mergedPrefixCls}\n options={col.options}\n searchValue={searchValue}\n prevValuePath={prevValuePath}\n activeValue={activeValue}\n renderItem={renderItem}\n />\n );\n });\n\n // >>>>> Render\n return (\n <div\n className={classNames(`${mergedPrefixCls}-menus`, {\n [`${mergedPrefixCls}-menu-empty`]: isEmpty,\n [`${mergedPrefixCls}-rtl`]: rtl,\n })}\n ref={containerRef}\n >\n {columnNodes}\n </div>\n );\n});\n\nexport default RefOptionList;\n"]}
@@ -0,0 +1,24 @@
1
+ // @ts-nocheck
2
+ import * as React from 'react';
3
+ import CascaderContext from '../context';
4
+ import { useBaseProps } from 'rc-select';
5
+ /**
6
+ * Control the active open options path.
7
+ */
8
+ export default () => {
9
+ const { multiple, open } = useBaseProps();
10
+ const { values } = React.useContext(CascaderContext);
11
+ // Record current dropdown active options
12
+ // This also control the open status
13
+ const [activeValueCells, setActiveValueCells] = React.useState([]);
14
+ React.useEffect(() => {
15
+ if (open && !multiple) {
16
+ const firstValueCells = values[0];
17
+ setActiveValueCells(firstValueCells || []);
18
+ }
19
+ },
20
+ /* eslint-disable react-hooks/exhaustive-deps */
21
+ [open]);
22
+ return [activeValueCells, setActiveValueCells];
23
+ };
24
+ //# sourceMappingURL=useActive.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useActive.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/useActive.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,eAAe,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC;;GAEG;AACH,eAAe,GAA2D,EAAE;IAC1E,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,YAAY,EAAE,CAAC;IAC1C,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAErD,yCAAyC;IACzC,oCAAoC;IACpC,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAc,EAAE,CAAC,CAAC;IAEhF,KAAK,CAAC,SAAS,CACb,GAAG,EAAE;QACH,IAAI,IAAI,IAAI,CAAC,QAAQ,EAAE;YACrB,MAAM,eAAe,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YAClC,mBAAmB,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;SAC5C;IACH,CAAC;IACD,gDAAgD;IAChD,CAAC,IAAI,CAAC,CAEP,CAAC;IAEF,OAAO,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,CAAC;AACjD,CAAC,CAAC","sourcesContent":["// @ts-nocheck\nimport * as React from 'react';\nimport CascaderContext from '../context';\nimport { useBaseProps } from 'rc-select';\n\n/**\n * Control the active open options path.\n */\nexport default (): [React.Key[], (activeValueCells: React.Key[]) => void] => {\n const { multiple, open } = useBaseProps();\n const { values } = React.useContext(CascaderContext);\n\n // Record current dropdown active options\n // This also control the open status\n const [activeValueCells, setActiveValueCells] = React.useState<React.Key[]>([]);\n\n React.useEffect(\n () => {\n if (open && !multiple) {\n const firstValueCells = values[0];\n setActiveValueCells(firstValueCells || []);\n }\n },\n /* eslint-disable react-hooks/exhaustive-deps */\n [open],\n /* eslint-enable react-hooks/exhaustive-deps */\n );\n\n return [activeValueCells, setActiveValueCells];\n};\n"]}
@@ -0,0 +1,145 @@
1
+ import * as React from 'react';
2
+ import { useBaseProps } from 'rc-select';
3
+ import KeyCode from 'rc-util/lib/KeyCode';
4
+ import { SEARCH_MARK } from '../hooks/useSearchOptions';
5
+ export default (ref, options, fieldNames, activeValueCells, setActiveValueCells, onKeyBoardSelect) => {
6
+ const { direction, searchValue, toggleOpen, open } = useBaseProps();
7
+ const rtl = direction === 'rtl';
8
+ const [validActiveValueCells, lastActiveIndex, lastActiveOptions] = React.useMemo(() => {
9
+ let activeIndex = -1;
10
+ let currentOptions = options;
11
+ const mergedActiveIndexes = [];
12
+ const mergedActiveValueCells = [];
13
+ const len = activeValueCells.length;
14
+ // Fill validate active value cells and index
15
+ for (let i = 0; i < len && currentOptions; i += 1) {
16
+ // Mark the active index for current options
17
+ const nextActiveIndex = currentOptions.findIndex((option) => option[fieldNames.value] === activeValueCells[i]);
18
+ if (nextActiveIndex === -1) {
19
+ break;
20
+ }
21
+ activeIndex = nextActiveIndex;
22
+ mergedActiveIndexes.push(activeIndex);
23
+ mergedActiveValueCells.push(activeValueCells[i]);
24
+ currentOptions = currentOptions[activeIndex][fieldNames.children];
25
+ }
26
+ // Fill last active options
27
+ let activeOptions = options;
28
+ for (let i = 0; i < mergedActiveIndexes.length - 1; i += 1) {
29
+ activeOptions = activeOptions[mergedActiveIndexes[i]][fieldNames.children];
30
+ }
31
+ return [mergedActiveValueCells, activeIndex, activeOptions];
32
+ }, [activeValueCells, fieldNames, options]);
33
+ // Update active value cells and scroll to target element
34
+ const internalSetActiveValueCells = (next) => {
35
+ setActiveValueCells(next);
36
+ };
37
+ // Same options offset
38
+ const offsetActiveOption = (offset) => {
39
+ const len = lastActiveOptions.length;
40
+ let currentIndex = lastActiveIndex;
41
+ if (currentIndex === -1 && offset < 0) {
42
+ currentIndex = len;
43
+ }
44
+ for (let i = 0; i < len; i += 1) {
45
+ currentIndex = (currentIndex + offset + len) % len;
46
+ const option = lastActiveOptions[currentIndex];
47
+ if (option && !option.disabled) {
48
+ const value = option[fieldNames.value];
49
+ const nextActiveCells = validActiveValueCells.slice(0, -1).concat(value);
50
+ internalSetActiveValueCells(nextActiveCells);
51
+ return;
52
+ }
53
+ }
54
+ };
55
+ // Different options offset
56
+ const prevColumn = () => {
57
+ if (validActiveValueCells.length > 1) {
58
+ const nextActiveCells = validActiveValueCells.slice(0, -1);
59
+ internalSetActiveValueCells(nextActiveCells);
60
+ }
61
+ else {
62
+ toggleOpen(false);
63
+ }
64
+ };
65
+ const nextColumn = () => {
66
+ var _a;
67
+ const nextOptions = ((_a = lastActiveOptions[lastActiveIndex]) === null || _a === void 0 ? void 0 : _a[fieldNames.children]) || [];
68
+ const nextOption = nextOptions.find((option) => !option.disabled);
69
+ if (nextOption) {
70
+ const nextActiveCells = [...validActiveValueCells, nextOption[fieldNames.value]];
71
+ internalSetActiveValueCells(nextActiveCells);
72
+ }
73
+ };
74
+ React.useImperativeHandle(ref, () => ({
75
+ // scrollTo: treeRef.current?.scrollTo,
76
+ onKeyDown: (event) => {
77
+ const { which } = event;
78
+ switch (which) {
79
+ // >>> Arrow keys
80
+ case KeyCode.UP:
81
+ case KeyCode.DOWN: {
82
+ let offset = 0;
83
+ if (which === KeyCode.UP) {
84
+ offset = -1;
85
+ }
86
+ else if (which === KeyCode.DOWN) {
87
+ offset = 1;
88
+ }
89
+ if (offset !== 0) {
90
+ offsetActiveOption(offset);
91
+ }
92
+ break;
93
+ }
94
+ case KeyCode.LEFT: {
95
+ if (rtl) {
96
+ nextColumn();
97
+ }
98
+ else {
99
+ prevColumn();
100
+ }
101
+ break;
102
+ }
103
+ case KeyCode.RIGHT: {
104
+ if (rtl) {
105
+ prevColumn();
106
+ }
107
+ else {
108
+ nextColumn();
109
+ }
110
+ break;
111
+ }
112
+ case KeyCode.BACKSPACE: {
113
+ if (!searchValue) {
114
+ prevColumn();
115
+ }
116
+ break;
117
+ }
118
+ // >>> Select
119
+ case KeyCode.ENTER: {
120
+ if (validActiveValueCells.length) {
121
+ const option = lastActiveOptions[lastActiveIndex];
122
+ // Search option should revert back of origin options
123
+ const originOptions = (option === null || option === void 0 ? void 0 : option[SEARCH_MARK]) || [];
124
+ if (originOptions.length) {
125
+ onKeyBoardSelect(originOptions.map((opt) => opt[fieldNames.value]), originOptions[originOptions.length - 1]);
126
+ }
127
+ else {
128
+ onKeyBoardSelect(validActiveValueCells, lastActiveOptions[lastActiveIndex]);
129
+ }
130
+ }
131
+ break;
132
+ }
133
+ // >>> Close
134
+ case KeyCode.ESC: {
135
+ toggleOpen(false);
136
+ if (open) {
137
+ event.stopPropagation();
138
+ }
139
+ }
140
+ }
141
+ },
142
+ onKeyUp: () => { },
143
+ }));
144
+ };
145
+ //# sourceMappingURL=useKeyboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useKeyboard.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/OptionList/useKeyboard.ts"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport type { RefOptionListProps } from 'rc-select/lib/OptionList';\nimport { useBaseProps } from 'rc-select';\nimport KeyCode from 'rc-util/lib/KeyCode';\nimport type { DefaultOptionType, InternalFieldNames, SingleValueType } from '../Cascader';\nimport { SEARCH_MARK } from '../hooks/useSearchOptions';\n\nexport default (\n ref: React.Ref<RefOptionListProps>,\n options: DefaultOptionType[],\n fieldNames: InternalFieldNames,\n activeValueCells: React.Key[],\n setActiveValueCells: (activeValueCells: React.Key[]) => void,\n onKeyBoardSelect: (valueCells: SingleValueType, option: DefaultOptionType) => void,\n) => {\n const { direction, searchValue, toggleOpen, open } = useBaseProps();\n const rtl = direction === 'rtl';\n\n const [validActiveValueCells, lastActiveIndex, lastActiveOptions] = React.useMemo(() => {\n let activeIndex = -1;\n let currentOptions = options;\n\n const mergedActiveIndexes: number[] = [];\n const mergedActiveValueCells: React.Key[] = [];\n\n const len = activeValueCells.length;\n\n // Fill validate active value cells and index\n for (let i = 0; i < len && currentOptions; i += 1) {\n // Mark the active index for current options\n const nextActiveIndex = currentOptions.findIndex(\n (option) => option[fieldNames.value] === activeValueCells[i],\n );\n\n if (nextActiveIndex === -1) {\n break;\n }\n\n activeIndex = nextActiveIndex;\n mergedActiveIndexes.push(activeIndex);\n mergedActiveValueCells.push(activeValueCells[i]);\n\n currentOptions = currentOptions[activeIndex][fieldNames.children];\n }\n\n // Fill last active options\n let activeOptions = options;\n for (let i = 0; i < mergedActiveIndexes.length - 1; i += 1) {\n activeOptions = activeOptions[mergedActiveIndexes[i]][fieldNames.children];\n }\n\n return [mergedActiveValueCells, activeIndex, activeOptions];\n }, [activeValueCells, fieldNames, options]);\n\n // Update active value cells and scroll to target element\n const internalSetActiveValueCells = (next: React.Key[]) => {\n setActiveValueCells(next);\n };\n\n // Same options offset\n const offsetActiveOption = (offset: number) => {\n const len = lastActiveOptions.length;\n\n let currentIndex = lastActiveIndex;\n if (currentIndex === -1 && offset < 0) {\n currentIndex = len;\n }\n\n for (let i = 0; i < len; i += 1) {\n currentIndex = (currentIndex + offset + len) % len;\n const option = lastActiveOptions[currentIndex];\n\n if (option && !option.disabled) {\n const value = option[fieldNames.value];\n const nextActiveCells = validActiveValueCells.slice(0, -1).concat(value);\n internalSetActiveValueCells(nextActiveCells);\n return;\n }\n }\n };\n\n // Different options offset\n const prevColumn = () => {\n if (validActiveValueCells.length > 1) {\n const nextActiveCells = validActiveValueCells.slice(0, -1);\n internalSetActiveValueCells(nextActiveCells);\n } else {\n toggleOpen(false);\n }\n };\n\n const nextColumn = () => {\n const nextOptions: DefaultOptionType[] =\n lastActiveOptions[lastActiveIndex]?.[fieldNames.children] || [];\n\n const nextOption = nextOptions.find((option) => !option.disabled);\n\n if (nextOption) {\n const nextActiveCells = [...validActiveValueCells, nextOption[fieldNames.value]];\n internalSetActiveValueCells(nextActiveCells);\n }\n };\n\n React.useImperativeHandle(ref, () => ({\n // scrollTo: treeRef.current?.scrollTo,\n onKeyDown: (event) => {\n const { which } = event;\n\n switch (which) {\n // >>> Arrow keys\n case KeyCode.UP:\n case KeyCode.DOWN: {\n let offset = 0;\n if (which === KeyCode.UP) {\n offset = -1;\n } else if (which === KeyCode.DOWN) {\n offset = 1;\n }\n\n if (offset !== 0) {\n offsetActiveOption(offset);\n }\n\n break;\n }\n\n case KeyCode.LEFT: {\n if (rtl) {\n nextColumn();\n } else {\n prevColumn();\n }\n break;\n }\n\n case KeyCode.RIGHT: {\n if (rtl) {\n prevColumn();\n } else {\n nextColumn();\n }\n break;\n }\n\n case KeyCode.BACKSPACE: {\n if (!searchValue) {\n prevColumn();\n }\n break;\n }\n\n // >>> Select\n case KeyCode.ENTER: {\n if (validActiveValueCells.length) {\n const option = lastActiveOptions[lastActiveIndex];\n\n // Search option should revert back of origin options\n const originOptions: DefaultOptionType[] = option?.[SEARCH_MARK] || [];\n if (originOptions.length) {\n onKeyBoardSelect(\n originOptions.map((opt) => opt[fieldNames.value]),\n originOptions[originOptions.length - 1],\n );\n } else {\n onKeyBoardSelect(validActiveValueCells, lastActiveOptions[lastActiveIndex]);\n }\n }\n break;\n }\n\n // >>> Close\n case KeyCode.ESC: {\n toggleOpen(false);\n\n if (open) {\n event.stopPropagation();\n }\n }\n }\n },\n onKeyUp: () => {},\n }));\n};\n"]}
@@ -0,0 +1,4 @@
1
+ import * as React from 'react';
2
+ const CascaderContext = React.createContext(null);
3
+ export default CascaderContext;
4
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/tntd-cascader/rc-cascader/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AA+B/B,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,CAA8B,IAAI,CAAC,CAAC;AAE/E,eAAe,eAAe,CAAC","sourcesContent":["import * as React from 'react';\nimport type {\n CascaderProps,\n InternalFieldNames,\n DefaultOptionType,\n SingleValueType,\n} from './Cascader';\n\nexport interface RenderItem {\n label: any;\n value: any;\n}\n\nexport interface CascaderContextProps {\n options: CascaderProps['options'];\n fieldNames: InternalFieldNames;\n values: SingleValueType[];\n halfValues: SingleValueType[];\n changeOnSelect?: boolean;\n onSelect: (valuePath: SingleValueType) => void;\n checkable?: boolean | React.ReactNode;\n searchOptions: DefaultOptionType[];\n dropdownPrefixCls?: string;\n loadData?: (selectOptions: DefaultOptionType[]) => void;\n expandTrigger?: 'hover' | 'click';\n expandIcon?: React.ReactNode;\n loadingIcon?: React.ReactNode;\n dropdownMenuColumnStyle?: React.CSSProperties;\n renderItem?: (item: RenderItem) => React.ReactNode;\n}\n\nconst CascaderContext = React.createContext<CascaderContextProps | null>(null);\n\nexport default CascaderContext;\n"]}
@@ -0,0 +1,41 @@
1
+ // @ts-nocheck
2
+ import { toPathOptions } from '../utils/treeUtil';
3
+ import * as React from 'react';
4
+ import { toPathKey } from '../utils/commonUtil';
5
+ export default (rawValues, options, fieldNames, multiple, displayRender) => {
6
+ return React.useMemo(() => {
7
+ const mergedDisplayRender = displayRender ||
8
+ // Default displayRender
9
+ ((labels) => {
10
+ const mergedLabels = multiple ? labels.slice(-1) : labels;
11
+ const SPLIT = ' / ';
12
+ if (mergedLabels.every((label) => ['string', 'number'].includes(typeof label))) {
13
+ return mergedLabels.join(SPLIT);
14
+ }
15
+ // If exist non-string value, use ReactNode instead
16
+ return mergedLabels.reduce((list, label, index) => {
17
+ const keyedLabel = React.isValidElement(label)
18
+ ? React.cloneElement(label, { key: index })
19
+ : label;
20
+ if (index === 0) {
21
+ return [keyedLabel];
22
+ }
23
+ return [...list, SPLIT, keyedLabel];
24
+ }, []);
25
+ });
26
+ return rawValues.map((valueCells) => {
27
+ var _a, _b;
28
+ const valueOptions = toPathOptions(valueCells, options, fieldNames);
29
+ const label = mergedDisplayRender(valueOptions.map(({ option, value }) => { var _a; return (_a = option === null || option === void 0 ? void 0 : option[fieldNames.label]) !== null && _a !== void 0 ? _a : value; }), valueOptions.map(({ option }) => option));
30
+ const value = toPathKey(valueCells);
31
+ return {
32
+ label,
33
+ value,
34
+ key: value,
35
+ valueCells,
36
+ disabled: (_b = (_a = valueOptions[valueOptions.length - 1]) === null || _a === void 0 ? void 0 : _a.option) === null || _b === void 0 ? void 0 : _b.disabled,
37
+ };
38
+ });
39
+ }, [rawValues, options, fieldNames, displayRender, multiple]);
40
+ };
41
+ //# sourceMappingURL=useDisplayValues.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDisplayValues.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useDisplayValues.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAO/B,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,eAAe,CACb,SAA4B,EAC5B,OAA4B,EAC5B,UAA8B,EAC9B,QAAiB,EACjB,aAA6C,EAC7C,EAAE;IACF,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxB,MAAM,mBAAmB,GACvB,aAAa;YACb,wBAAwB;YACxB,CAAC,CAAC,MAAM,EAAE,EAAE;gBACV,MAAM,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gBAC1D,MAAM,KAAK,GAAG,KAAK,CAAC;gBAEpB,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,KAAK,CAAC,CAAC,EAAE;oBAC9E,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACjC;gBAED,mDAAmD;gBACnD,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;oBAChD,MAAM,UAAU,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC;wBAC5C,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;wBAC3C,CAAC,CAAC,KAAK,CAAC;oBAEV,IAAI,KAAK,KAAK,CAAC,EAAE;wBACf,OAAO,CAAC,UAAU,CAAC,CAAC;qBACrB;oBAED,OAAO,CAAC,GAAG,IAAI,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;gBACtC,CAAC,EAAE,EAAE,CAAC,CAAC;YACT,CAAC,CAAC,CAAC;QAEL,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;;YAClC,MAAM,YAAY,GAAG,aAAa,CAAC,UAAU,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;YAEpE,MAAM,KAAK,GAAG,mBAAmB,CAC/B,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,WAAC,OAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,UAAU,CAAC,KAAK,CAAC,mCAAI,KAAK,CAAA,EAAA,CAAC,EAC5E,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CACzC,CAAC;YAEF,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC;YAEpC,OAAO;gBACL,KAAK;gBACL,KAAK;gBACL,GAAG,EAAE,KAAK;gBACV,UAAU;gBACV,QAAQ,EAAE,MAAA,MAAA,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,0CAAE,MAAM,0CAAE,QAAQ;aAClE,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC;AAChE,CAAC,CAAC","sourcesContent":["// @ts-nocheck\nimport { toPathOptions } from '../utils/treeUtil';\nimport * as React from 'react';\nimport type {\n DefaultOptionType,\n SingleValueType,\n CascaderProps,\n InternalFieldNames,\n} from '../Cascader';\nimport { toPathKey } from '../utils/commonUtil';\n\nexport default (\n rawValues: SingleValueType[],\n options: DefaultOptionType[],\n fieldNames: InternalFieldNames,\n multiple: boolean,\n displayRender: CascaderProps['displayRender'],\n) => {\n return React.useMemo(() => {\n const mergedDisplayRender =\n displayRender ||\n // Default displayRender\n ((labels) => {\n const mergedLabels = multiple ? labels.slice(-1) : labels;\n const SPLIT = ' / ';\n\n if (mergedLabels.every((label) => ['string', 'number'].includes(typeof label))) {\n return mergedLabels.join(SPLIT);\n }\n\n // If exist non-string value, use ReactNode instead\n return mergedLabels.reduce((list, label, index) => {\n const keyedLabel = React.isValidElement(label)\n ? React.cloneElement(label, { key: index })\n : label;\n\n if (index === 0) {\n return [keyedLabel];\n }\n\n return [...list, SPLIT, keyedLabel];\n }, []);\n });\n\n return rawValues.map((valueCells) => {\n const valueOptions = toPathOptions(valueCells, options, fieldNames);\n\n const label = mergedDisplayRender(\n valueOptions.map(({ option, value }) => option?.[fieldNames.label] ?? value),\n valueOptions.map(({ option }) => option),\n );\n\n const value = toPathKey(valueCells);\n\n return {\n label,\n value,\n key: value,\n valueCells,\n disabled: valueOptions[valueOptions.length - 1]?.option?.disabled,\n };\n });\n }, [rawValues, options, fieldNames, displayRender, multiple]);\n};\n"]}
@@ -0,0 +1,30 @@
1
+ // @ts-nocheck
2
+ import * as React from 'react';
3
+ import { convertDataToEntities } from 'rc-tree/lib/utils/treeUtil';
4
+ import { VALUE_SPLIT } from '../utils/commonUtil';
5
+ /** Lazy parse options data into conduct-able info to avoid perf issue in single mode */
6
+ export default (options, fieldNames) => {
7
+ const cacheRef = React.useRef({
8
+ options: null,
9
+ info: null,
10
+ });
11
+ const getEntities = React.useCallback(() => {
12
+ if (cacheRef.current.options !== options) {
13
+ cacheRef.current.options = options;
14
+ cacheRef.current.info = convertDataToEntities(options, {
15
+ fieldNames,
16
+ initWrapper: (wrapper) => (Object.assign(Object.assign({}, wrapper), { pathKeyEntities: {} })),
17
+ processEntity: (entity, wrapper) => {
18
+ const pathKey = entity.nodes.map((node) => node[fieldNames.value]).join(VALUE_SPLIT);
19
+ wrapper.pathKeyEntities[pathKey] = entity;
20
+ // Overwrite origin key.
21
+ // this is very hack but we need let conduct logic work with connect path
22
+ entity.key = pathKey;
23
+ },
24
+ });
25
+ }
26
+ return cacheRef.current.info.pathKeyEntities;
27
+ }, [fieldNames, options]);
28
+ return getEntities;
29
+ };
30
+ //# sourceMappingURL=useEntities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEntities.js","sourceRoot":"","sources":["../../../../src/tntd-cascader/rc-cascader/hooks/useEntities.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAGnE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASlD,wFAAwF;AACxF,eAAe,CAAC,OAA4B,EAAE,UAA8B,EAAE,EAAE;IAC9E,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAG1B;QACD,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;IAEH,MAAM,WAAW,GAAgB,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QACtD,IAAI,QAAQ,CAAC,OAAO,CAAC,OAAO,KAAK,OAAO,EAAE;YACxC,QAAQ,CAAC,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;YACnC,QAAQ,CAAC,OAAO,CAAC,IAAI,GAAG,qBAAqB,CAAC,OAAc,EAAE;gBAC5D,UAAU;gBACV,WAAW,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,iCACrB,OAAO,KACV,eAAe,EAAE,EAAE,IACnB;gBACF,aAAa,EAAE,CAAC,MAAM,EAAE,OAAY,EAAE,EAAE;oBACtC,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBAErF,OAAO,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC;oBAE1C,wBAAwB;oBACxB,yEAAyE;oBACzE,MAAM,CAAC,GAAG,GAAG,OAAO,CAAC;gBACvB,CAAC;aACF,CAAQ,CAAC;SACX;QAED,OAAO,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC;IAC/C,CAAC,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC;IAE1B,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC","sourcesContent":["// @ts-nocheck\nimport * as React from 'react';\nimport { convertDataToEntities } from 'rc-tree/lib/utils/treeUtil';\nimport type { DefaultOptionType, InternalFieldNames } from '../Cascader';\nimport type { DataEntity } from 'rc-tree/lib/interface';\nimport { VALUE_SPLIT } from '../utils/commonUtil';\n\nexport interface OptionsInfo {\n keyEntities: Record<string, DataEntity>;\n pathKeyEntities: Record<string, DataEntity>;\n}\n\nexport type GetEntities = () => OptionsInfo['pathKeyEntities'];\n\n/** Lazy parse options data into conduct-able info to avoid perf issue in single mode */\nexport default (options: DefaultOptionType[], fieldNames: InternalFieldNames) => {\n const cacheRef = React.useRef<{\n options: DefaultOptionType[];\n info: OptionsInfo;\n }>({\n options: null,\n info: null,\n });\n\n const getEntities: GetEntities = React.useCallback(() => {\n if (cacheRef.current.options !== options) {\n cacheRef.current.options = options;\n cacheRef.current.info = convertDataToEntities(options as any, {\n fieldNames,\n initWrapper: (wrapper) => ({\n ...wrapper,\n pathKeyEntities: {},\n }),\n processEntity: (entity, wrapper: any) => {\n const pathKey = entity.nodes.map((node) => node[fieldNames.value]).join(VALUE_SPLIT);\n\n wrapper.pathKeyEntities[pathKey] = entity;\n\n // Overwrite origin key.\n // this is very hack but we need let conduct logic work with connect path\n entity.key = pathKey;\n },\n }) as any;\n }\n\n return cacheRef.current.info.pathKeyEntities;\n }, [fieldNames, options]);\n\n return getEntities;\n};\n"]}