tntd 2.7.23 → 2.7.25

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 (380) hide show
  1. package/es/index.js +1 -0
  2. package/es/index.js.map +1 -1
  3. package/es/locale/en_US.js +21 -3
  4. package/es/locale/en_US.js.map +1 -1
  5. package/es/locale/zh_CN.js +4 -1
  6. package/es/locale/zh_CN.js.map +1 -1
  7. package/es/table/context.js.map +1 -1
  8. package/es/table/table.js +3 -2
  9. package/es/table/table.js.map +1 -1
  10. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
  11. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  12. package/es/tntd-rc-select/_util/DisabledContext.js +8 -0
  13. package/es/tntd-rc-select/_util/DisabledContext.js.map +1 -0
  14. package/es/tntd-rc-select/_util/FormItemInputContext.js +3 -0
  15. package/es/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
  16. package/es/tntd-rc-select/_util/PurePanel.js +55 -0
  17. package/es/tntd-rc-select/_util/PurePanel.js.map +1 -0
  18. package/es/tntd-rc-select/_util/SizeContext.js +3 -0
  19. package/es/tntd-rc-select/_util/SizeContext.js.map +1 -0
  20. package/es/tntd-rc-select/_util/context.js +14 -0
  21. package/es/tntd-rc-select/_util/context.js.map +1 -0
  22. package/es/tntd-rc-select/_util/defaultRenderEmpty.js +20 -0
  23. package/es/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
  24. package/es/tntd-rc-select/_util/getIcons.js +52 -0
  25. package/es/tntd-rc-select/_util/getIcons.js.map +1 -0
  26. package/es/tntd-rc-select/_util/interface.js +5 -0
  27. package/es/tntd-rc-select/_util/interface.js.map +1 -0
  28. package/es/tntd-rc-select/_util/motion.js +38 -0
  29. package/es/tntd-rc-select/_util/motion.js.map +1 -0
  30. package/es/tntd-rc-select/_util/type.js +4 -0
  31. package/es/tntd-rc-select/_util/type.js.map +1 -0
  32. package/es/tntd-rc-select/_util/useCompactItemContext.js +24 -0
  33. package/es/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
  34. package/es/tntd-rc-select/_util/warning.js +15 -0
  35. package/es/tntd-rc-select/_util/warning.js.map +1 -0
  36. package/es/tntd-rc-select/img/no-data-s.png +0 -0
  37. package/es/tntd-rc-select/index.js +103 -0
  38. package/es/tntd-rc-select/index.js.map +1 -0
  39. package/es/tntd-rc-select/style/index.less +1657 -0
  40. package/es/tntd-select/_util/DisabledContext.js +8 -0
  41. package/es/tntd-select/_util/DisabledContext.js.map +1 -0
  42. package/es/tntd-select/_util/FormItemInputContext.js +3 -0
  43. package/es/tntd-select/_util/FormItemInputContext.js.map +1 -0
  44. package/es/tntd-select/_util/PurePanel.js +4 -17
  45. package/es/tntd-select/_util/PurePanel.js.map +1 -1
  46. package/es/tntd-select/_util/SizeContext.js +3 -0
  47. package/es/tntd-select/_util/SizeContext.js.map +1 -0
  48. package/es/tntd-select/_util/context.js +14 -0
  49. package/es/tntd-select/_util/context.js.map +1 -0
  50. package/es/tntd-select/_util/defaultRenderEmpty.js +20 -0
  51. package/es/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
  52. package/es/tntd-select/_util/getIcons.js +52 -0
  53. package/es/tntd-select/_util/getIcons.js.map +1 -0
  54. package/es/tntd-select/_util/interface.js +5 -0
  55. package/es/tntd-select/_util/interface.js.map +1 -0
  56. package/es/tntd-select/_util/motion.js +15 -8
  57. package/es/tntd-select/_util/motion.js.map +1 -1
  58. package/es/tntd-select/_util/type.js +4 -0
  59. package/es/tntd-select/_util/type.js.map +1 -0
  60. package/es/tntd-select/_util/useCompactItemContext.js +24 -0
  61. package/es/tntd-select/_util/useCompactItemContext.js.map +1 -0
  62. package/es/tntd-select/_util/warning.js +14 -5
  63. package/es/tntd-select/_util/warning.js.map +1 -1
  64. package/es/tntd-select/index.js +7 -1
  65. package/es/tntd-select/index.js.map +1 -1
  66. package/es/tntd-select/rc-select/BaseSelect.js +429 -0
  67. package/es/tntd-select/rc-select/BaseSelect.js.map +1 -0
  68. package/es/tntd-select/rc-select/OptGroup.js +5 -0
  69. package/es/tntd-select/rc-select/OptGroup.js.map +1 -0
  70. package/es/tntd-select/rc-select/Option.js +5 -0
  71. package/es/tntd-select/rc-select/Option.js.map +1 -0
  72. package/es/tntd-select/rc-select/OptionList.js +257 -0
  73. package/es/tntd-select/rc-select/OptionList.js.map +1 -0
  74. package/es/tntd-select/rc-select/Select.js +428 -0
  75. package/es/tntd-select/rc-select/Select.js.map +1 -0
  76. package/es/tntd-select/rc-select/SelectContext.js +4 -0
  77. package/es/tntd-select/rc-select/SelectContext.js.map +1 -0
  78. package/es/tntd-select/rc-select/SelectTrigger.js +91 -0
  79. package/es/tntd-select/rc-select/SelectTrigger.js.map +1 -0
  80. package/es/tntd-select/rc-select/Selector/Input.js +47 -0
  81. package/es/tntd-select/rc-select/Selector/Input.js.map +1 -0
  82. package/es/tntd-select/rc-select/Selector/MultipleSelector.js +97 -0
  83. package/es/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
  84. package/es/tntd-select/rc-select/Selector/SingleSelector.js +45 -0
  85. package/es/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
  86. package/es/tntd-select/rc-select/Selector/index.js +136 -0
  87. package/es/tntd-select/rc-select/Selector/index.js.map +1 -0
  88. package/es/tntd-select/rc-select/TransBtn.js +22 -0
  89. package/es/tntd-select/rc-select/TransBtn.js.map +1 -0
  90. package/es/tntd-select/rc-select/hooks/useAllowClear.js +25 -0
  91. package/es/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
  92. package/es/tntd-select/rc-select/hooks/useBaseProps.js +10 -0
  93. package/es/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
  94. package/es/tntd-select/rc-select/hooks/useCache.js +34 -0
  95. package/es/tntd-select/rc-select/hooks/useCache.js.map +1 -0
  96. package/es/tntd-select/rc-select/hooks/useDelayReset.js +24 -0
  97. package/es/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
  98. package/es/tntd-select/rc-select/hooks/useFilterOptions.js +55 -0
  99. package/es/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
  100. package/es/tntd-select/rc-select/hooks/useId.js +28 -0
  101. package/es/tntd-select/rc-select/hooks/useId.js.map +1 -0
  102. package/es/tntd-select/rc-select/hooks/useLayoutEffect.js +18 -0
  103. package/es/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
  104. package/es/tntd-select/rc-select/hooks/useLock.js +26 -0
  105. package/es/tntd-select/rc-select/hooks/useLock.js.map +1 -0
  106. package/es/tntd-select/rc-select/hooks/useOptions.js +45 -0
  107. package/es/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
  108. package/es/tntd-select/rc-select/hooks/useRefFunc.js +14 -0
  109. package/es/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
  110. package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js +32 -0
  111. package/es/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
  112. package/es/tntd-select/rc-select/index.js +8 -0
  113. package/es/tntd-select/rc-select/index.js.map +1 -0
  114. package/es/tntd-select/rc-select/interface.js +2 -0
  115. package/es/tntd-select/rc-select/interface.js.map +1 -0
  116. package/es/tntd-select/rc-select/utils/commonUtil.js +32 -0
  117. package/es/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
  118. package/es/tntd-select/rc-select/utils/keyUtil.js +34 -0
  119. package/es/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
  120. package/es/tntd-select/rc-select/utils/legacyUtil.js +32 -0
  121. package/es/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
  122. package/es/tntd-select/rc-select/utils/platformUtil.js +5 -0
  123. package/es/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
  124. package/es/tntd-select/rc-select/utils/valueUtil.js +99 -0
  125. package/es/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
  126. package/es/tntd-select/rc-select/utils/warningPropsUtil.js +100 -0
  127. package/es/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
  128. package/lib/index.d.ts +1 -0
  129. package/lib/index.d.ts.map +1 -1
  130. package/lib/index.js +3 -1
  131. package/lib/index.js.map +1 -1
  132. package/lib/locale/default.d.ts +4 -1
  133. package/lib/locale/default.d.ts.map +1 -1
  134. package/lib/locale/en_US.d.ts +11 -1
  135. package/lib/locale/en_US.d.ts.map +1 -1
  136. package/lib/locale/en_US.js +21 -3
  137. package/lib/locale/en_US.js.map +1 -1
  138. package/lib/locale/zh_CN.d.ts +4 -1
  139. package/lib/locale/zh_CN.d.ts.map +1 -1
  140. package/lib/locale/zh_CN.js +4 -1
  141. package/lib/locale/zh_CN.js.map +1 -1
  142. package/lib/table/context.d.ts +1 -0
  143. package/lib/table/context.d.ts.map +1 -1
  144. package/lib/table/context.js.map +1 -1
  145. package/lib/table/table.d.ts +2 -1
  146. package/lib/table/table.d.ts.map +1 -1
  147. package/lib/table/table.js +3 -2
  148. package/lib/table/table.js.map +1 -1
  149. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +1 -1
  150. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  151. package/lib/tntd-rc-select/_util/DisabledContext.d.ts +10 -0
  152. package/lib/tntd-rc-select/_util/DisabledContext.d.ts.map +1 -0
  153. package/lib/tntd-rc-select/_util/DisabledContext.js +35 -0
  154. package/lib/tntd-rc-select/_util/DisabledContext.js.map +1 -0
  155. package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts +4 -0
  156. package/lib/tntd-rc-select/_util/FormItemInputContext.d.ts.map +1 -0
  157. package/lib/tntd-rc-select/_util/FormItemInputContext.js +29 -0
  158. package/lib/tntd-rc-select/_util/FormItemInputContext.js.map +1 -0
  159. package/lib/tntd-rc-select/_util/PurePanel.d.ts +9 -0
  160. package/lib/tntd-rc-select/_util/PurePanel.d.ts.map +1 -0
  161. package/lib/tntd-rc-select/_util/PurePanel.js +84 -0
  162. package/lib/tntd-rc-select/_util/PurePanel.js.map +1 -0
  163. package/lib/tntd-rc-select/_util/SizeContext.d.ts +4 -0
  164. package/lib/tntd-rc-select/_util/SizeContext.d.ts.map +1 -0
  165. package/lib/tntd-rc-select/_util/SizeContext.js +29 -0
  166. package/lib/tntd-rc-select/_util/SizeContext.js.map +1 -0
  167. package/lib/tntd-rc-select/_util/context.d.ts +42 -0
  168. package/lib/tntd-rc-select/_util/context.d.ts.map +1 -0
  169. package/lib/tntd-rc-select/_util/context.js +20 -0
  170. package/lib/tntd-rc-select/_util/context.js.map +1 -0
  171. package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts +5 -0
  172. package/lib/tntd-rc-select/_util/defaultRenderEmpty.d.ts.map +1 -0
  173. package/lib/tntd-rc-select/_util/defaultRenderEmpty.js +48 -0
  174. package/lib/tntd-rc-select/_util/defaultRenderEmpty.js.map +1 -0
  175. package/lib/tntd-rc-select/_util/getIcons.d.ts +25 -0
  176. package/lib/tntd-rc-select/_util/getIcons.d.ts.map +1 -0
  177. package/lib/tntd-rc-select/_util/getIcons.js +78 -0
  178. package/lib/tntd-rc-select/_util/getIcons.js.map +1 -0
  179. package/lib/tntd-rc-select/_util/interface.d.ts +25 -0
  180. package/lib/tntd-rc-select/_util/interface.d.ts.map +1 -0
  181. package/lib/tntd-rc-select/_util/interface.js +9 -0
  182. package/lib/tntd-rc-select/_util/interface.js.map +1 -0
  183. package/lib/tntd-rc-select/_util/motion.d.ts +9 -0
  184. package/lib/tntd-rc-select/_util/motion.d.ts.map +1 -0
  185. package/lib/tntd-rc-select/_util/motion.js +42 -0
  186. package/lib/tntd-rc-select/_util/motion.js.map +1 -0
  187. package/lib/tntd-rc-select/_util/type.d.ts +10 -0
  188. package/lib/tntd-rc-select/_util/type.d.ts.map +1 -0
  189. package/lib/tntd-rc-select/_util/type.js +9 -0
  190. package/lib/tntd-rc-select/_util/type.js.map +1 -0
  191. package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts +9 -0
  192. package/lib/tntd-rc-select/_util/useCompactItemContext.d.ts.map +1 -0
  193. package/lib/tntd-rc-select/_util/useCompactItemContext.js +54 -0
  194. package/lib/tntd-rc-select/_util/useCompactItemContext.js.map +1 -0
  195. package/lib/tntd-rc-select/_util/warning.d.ts +4 -0
  196. package/lib/tntd-rc-select/_util/warning.d.ts.map +1 -0
  197. package/lib/tntd-rc-select/_util/warning.js +40 -0
  198. package/lib/tntd-rc-select/_util/warning.js.map +1 -0
  199. package/lib/tntd-rc-select/img/no-data-s.png +0 -0
  200. package/lib/tntd-rc-select/index.d.ts +44 -0
  201. package/lib/tntd-rc-select/index.d.ts.map +1 -0
  202. package/lib/tntd-rc-select/index.js +131 -0
  203. package/lib/tntd-rc-select/index.js.map +1 -0
  204. package/lib/tntd-rc-select/style/index.less +1657 -0
  205. package/lib/tntd-select/_util/DisabledContext.d.ts +10 -0
  206. package/lib/tntd-select/_util/DisabledContext.d.ts.map +1 -0
  207. package/lib/tntd-select/_util/DisabledContext.js +35 -0
  208. package/lib/tntd-select/_util/DisabledContext.js.map +1 -0
  209. package/lib/tntd-select/_util/FormItemInputContext.d.ts +4 -0
  210. package/lib/tntd-select/_util/FormItemInputContext.d.ts.map +1 -0
  211. package/lib/tntd-select/_util/FormItemInputContext.js +29 -0
  212. package/lib/tntd-select/_util/FormItemInputContext.js.map +1 -0
  213. package/lib/tntd-select/_util/PurePanel.d.ts +3 -2
  214. package/lib/tntd-select/_util/PurePanel.d.ts.map +1 -1
  215. package/lib/tntd-select/_util/PurePanel.js +4 -19
  216. package/lib/tntd-select/_util/PurePanel.js.map +1 -1
  217. package/lib/tntd-select/_util/SizeContext.d.ts +4 -0
  218. package/lib/tntd-select/_util/SizeContext.d.ts.map +1 -0
  219. package/lib/tntd-select/_util/SizeContext.js +29 -0
  220. package/lib/tntd-select/_util/SizeContext.js.map +1 -0
  221. package/lib/tntd-select/_util/context.d.ts +42 -0
  222. package/lib/tntd-select/_util/context.d.ts.map +1 -0
  223. package/lib/tntd-select/_util/context.js +20 -0
  224. package/lib/tntd-select/_util/context.js.map +1 -0
  225. package/lib/tntd-select/_util/defaultRenderEmpty.d.ts +5 -0
  226. package/lib/tntd-select/_util/defaultRenderEmpty.d.ts.map +1 -0
  227. package/lib/tntd-select/_util/defaultRenderEmpty.js +48 -0
  228. package/lib/tntd-select/_util/defaultRenderEmpty.js.map +1 -0
  229. package/lib/tntd-select/_util/getIcons.d.ts +25 -0
  230. package/lib/tntd-select/_util/getIcons.d.ts.map +1 -0
  231. package/lib/tntd-select/_util/getIcons.js +78 -0
  232. package/lib/tntd-select/_util/getIcons.js.map +1 -0
  233. package/lib/tntd-select/_util/interface.d.ts +25 -0
  234. package/lib/tntd-select/_util/interface.d.ts.map +1 -0
  235. package/lib/tntd-select/_util/interface.js +9 -0
  236. package/lib/tntd-select/_util/interface.js.map +1 -0
  237. package/lib/tntd-select/_util/motion.d.ts +5 -4
  238. package/lib/tntd-select/_util/motion.d.ts.map +1 -1
  239. package/lib/tntd-select/_util/motion.js +16 -8
  240. package/lib/tntd-select/_util/motion.js.map +1 -1
  241. package/lib/tntd-select/_util/type.d.ts +10 -0
  242. package/lib/tntd-select/_util/type.d.ts.map +1 -0
  243. package/lib/tntd-select/_util/type.js +9 -0
  244. package/lib/tntd-select/_util/type.js.map +1 -0
  245. package/lib/tntd-select/_util/useCompactItemContext.d.ts +9 -0
  246. package/lib/tntd-select/_util/useCompactItemContext.d.ts.map +1 -0
  247. package/lib/tntd-select/_util/useCompactItemContext.js +54 -0
  248. package/lib/tntd-select/_util/useCompactItemContext.js.map +1 -0
  249. package/lib/tntd-select/_util/warning.d.ts +3 -4
  250. package/lib/tntd-select/_util/warning.d.ts.map +1 -1
  251. package/lib/tntd-select/_util/warning.js +13 -5
  252. package/lib/tntd-select/_util/warning.js.map +1 -1
  253. package/lib/tntd-select/index.d.ts.map +1 -1
  254. package/lib/tntd-select/index.js +7 -1
  255. package/lib/tntd-select/index.js.map +1 -1
  256. package/lib/tntd-select/rc-select/BaseSelect.d.ts +114 -0
  257. package/lib/tntd-select/rc-select/BaseSelect.d.ts.map +1 -0
  258. package/lib/tntd-select/rc-select/BaseSelect.js +459 -0
  259. package/lib/tntd-select/rc-select/BaseSelect.js.map +1 -0
  260. package/lib/tntd-select/rc-select/OptGroup.d.ts +13 -0
  261. package/lib/tntd-select/rc-select/OptGroup.d.ts.map +1 -0
  262. package/lib/tntd-select/rc-select/OptGroup.js +7 -0
  263. package/lib/tntd-select/rc-select/OptGroup.js.map +1 -0
  264. package/lib/tntd-select/rc-select/Option.d.ts +15 -0
  265. package/lib/tntd-select/rc-select/Option.d.ts.map +1 -0
  266. package/lib/tntd-select/rc-select/Option.js +7 -0
  267. package/lib/tntd-select/rc-select/Option.js.map +1 -0
  268. package/lib/tntd-select/rc-select/OptionList.d.ts +11 -0
  269. package/lib/tntd-select/rc-select/OptionList.d.ts.map +1 -0
  270. package/lib/tntd-select/rc-select/OptionList.js +285 -0
  271. package/lib/tntd-select/rc-select/OptionList.js.map +1 -0
  272. package/lib/tntd-select/rc-select/Select.d.ts +115 -0
  273. package/lib/tntd-select/rc-select/Select.d.ts.map +1 -0
  274. package/lib/tntd-select/rc-select/Select.js +456 -0
  275. package/lib/tntd-select/rc-select/Select.js.map +1 -0
  276. package/lib/tntd-select/rc-select/SelectContext.d.ts +23 -0
  277. package/lib/tntd-select/rc-select/SelectContext.d.ts.map +1 -0
  278. package/lib/tntd-select/rc-select/SelectContext.js +29 -0
  279. package/lib/tntd-select/rc-select/SelectContext.js.map +1 -0
  280. package/lib/tntd-select/rc-select/SelectTrigger.d.ts +31 -0
  281. package/lib/tntd-select/rc-select/SelectTrigger.d.ts.map +1 -0
  282. package/lib/tntd-select/rc-select/SelectTrigger.js +119 -0
  283. package/lib/tntd-select/rc-select/SelectTrigger.js.map +1 -0
  284. package/lib/tntd-select/rc-select/Selector/Input.d.ts +27 -0
  285. package/lib/tntd-select/rc-select/Selector/Input.d.ts.map +1 -0
  286. package/lib/tntd-select/rc-select/Selector/Input.js +75 -0
  287. package/lib/tntd-select/rc-select/Selector/Input.js.map +1 -0
  288. package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts +17 -0
  289. package/lib/tntd-select/rc-select/Selector/MultipleSelector.d.ts.map +1 -0
  290. package/lib/tntd-select/rc-select/Selector/MultipleSelector.js +125 -0
  291. package/lib/tntd-select/rc-select/Selector/MultipleSelector.js.map +1 -0
  292. package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts +9 -0
  293. package/lib/tntd-select/rc-select/Selector/SingleSelector.d.ts.map +1 -0
  294. package/lib/tntd-select/rc-select/Selector/SingleSelector.js +73 -0
  295. package/lib/tntd-select/rc-select/Selector/SingleSelector.js.map +1 -0
  296. package/lib/tntd-select/rc-select/Selector/index.d.ts +83 -0
  297. package/lib/tntd-select/rc-select/Selector/index.d.ts.map +1 -0
  298. package/lib/tntd-select/rc-select/Selector/index.js +164 -0
  299. package/lib/tntd-select/rc-select/Selector/index.js.map +1 -0
  300. package/lib/tntd-select/rc-select/TransBtn.d.ts +13 -0
  301. package/lib/tntd-select/rc-select/TransBtn.d.ts.map +1 -0
  302. package/lib/tntd-select/rc-select/TransBtn.js +50 -0
  303. package/lib/tntd-select/rc-select/TransBtn.js.map +1 -0
  304. package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts +9 -0
  305. package/lib/tntd-select/rc-select/hooks/useAllowClear.d.ts.map +1 -0
  306. package/lib/tntd-select/rc-select/hooks/useAllowClear.js +32 -0
  307. package/lib/tntd-select/rc-select/hooks/useAllowClear.js.map +1 -0
  308. package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts +14 -0
  309. package/lib/tntd-select/rc-select/hooks/useBaseProps.d.ts.map +1 -0
  310. package/lib/tntd-select/rc-select/hooks/useBaseProps.js +37 -0
  311. package/lib/tntd-select/rc-select/hooks/useBaseProps.js.map +1 -0
  312. package/lib/tntd-select/rc-select/hooks/useCache.d.ts +8 -0
  313. package/lib/tntd-select/rc-select/hooks/useCache.d.ts.map +1 -0
  314. package/lib/tntd-select/rc-select/hooks/useCache.js +59 -0
  315. package/lib/tntd-select/rc-select/hooks/useCache.js.map +1 -0
  316. package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts +6 -0
  317. package/lib/tntd-select/rc-select/hooks/useDelayReset.d.ts.map +1 -0
  318. package/lib/tntd-select/rc-select/hooks/useDelayReset.js +50 -0
  319. package/lib/tntd-select/rc-select/hooks/useDelayReset.js.map +1 -0
  320. package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts +4 -0
  321. package/lib/tntd-select/rc-select/hooks/useFilterOptions.d.ts.map +1 -0
  322. package/lib/tntd-select/rc-select/hooks/useFilterOptions.js +80 -0
  323. package/lib/tntd-select/rc-select/hooks/useFilterOptions.js.map +1 -0
  324. package/lib/tntd-select/rc-select/hooks/useId.d.ts +6 -0
  325. package/lib/tntd-select/rc-select/hooks/useId.d.ts.map +1 -0
  326. package/lib/tntd-select/rc-select/hooks/useId.js +59 -0
  327. package/lib/tntd-select/rc-select/hooks/useId.js.map +1 -0
  328. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts +6 -0
  329. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.d.ts.map +1 -0
  330. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js +44 -0
  331. package/lib/tntd-select/rc-select/hooks/useLayoutEffect.js.map +1 -0
  332. package/lib/tntd-select/rc-select/hooks/useLock.d.ts +8 -0
  333. package/lib/tntd-select/rc-select/hooks/useLock.d.ts.map +1 -0
  334. package/lib/tntd-select/rc-select/hooks/useLock.js +52 -0
  335. package/lib/tntd-select/rc-select/hooks/useLock.js.map +1 -0
  336. package/lib/tntd-select/rc-select/hooks/useOptions.d.ts +12 -0
  337. package/lib/tntd-select/rc-select/hooks/useOptions.d.ts.map +1 -0
  338. package/lib/tntd-select/rc-select/hooks/useOptions.js +71 -0
  339. package/lib/tntd-select/rc-select/hooks/useOptions.js.map +1 -0
  340. package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts +6 -0
  341. package/lib/tntd-select/rc-select/hooks/useRefFunc.d.ts.map +1 -0
  342. package/lib/tntd-select/rc-select/hooks/useRefFunc.js +40 -0
  343. package/lib/tntd-select/rc-select/hooks/useRefFunc.js.map +1 -0
  344. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts +2 -0
  345. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.d.ts.map +1 -0
  346. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js +58 -0
  347. package/lib/tntd-select/rc-select/hooks/useSelectTriggerControl.js.map +1 -0
  348. package/lib/tntd-select/rc-select/index.d.ts +11 -0
  349. package/lib/tntd-select/rc-select/index.d.ts.map +1 -0
  350. package/lib/tntd-select/rc-select/index.js +17 -0
  351. package/lib/tntd-select/rc-select/index.js.map +1 -0
  352. package/lib/tntd-select/rc-select/interface.d.ts +23 -0
  353. package/lib/tntd-select/rc-select/interface.d.ts.map +1 -0
  354. package/lib/tntd-select/rc-select/interface.js +3 -0
  355. package/lib/tntd-select/rc-select/interface.js.map +1 -0
  356. package/lib/tntd-select/rc-select/utils/commonUtil.d.ts +10 -0
  357. package/lib/tntd-select/rc-select/utils/commonUtil.d.ts.map +1 -0
  358. package/lib/tntd-select/rc-select/utils/commonUtil.js +39 -0
  359. package/lib/tntd-select/rc-select/utils/commonUtil.js.map +1 -0
  360. package/lib/tntd-select/rc-select/utils/keyUtil.d.ts +3 -0
  361. package/lib/tntd-select/rc-select/utils/keyUtil.d.ts.map +1 -0
  362. package/lib/tntd-select/rc-select/utils/keyUtil.js +41 -0
  363. package/lib/tntd-select/rc-select/utils/keyUtil.js.map +1 -0
  364. package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts +4 -0
  365. package/lib/tntd-select/rc-select/utils/legacyUtil.d.ts.map +1 -0
  366. package/lib/tntd-select/rc-select/utils/legacyUtil.js +62 -0
  367. package/lib/tntd-select/rc-select/utils/legacyUtil.js.map +1 -0
  368. package/lib/tntd-select/rc-select/utils/platformUtil.d.ts +2 -0
  369. package/lib/tntd-select/rc-select/utils/platformUtil.d.ts.map +1 -0
  370. package/lib/tntd-select/rc-select/utils/platformUtil.js +9 -0
  371. package/lib/tntd-select/rc-select/utils/platformUtil.js.map +1 -0
  372. package/lib/tntd-select/rc-select/utils/valueUtil.d.ts +24 -0
  373. package/lib/tntd-select/rc-select/utils/valueUtil.d.ts.map +1 -0
  374. package/lib/tntd-select/rc-select/utils/valueUtil.js +109 -0
  375. package/lib/tntd-select/rc-select/utils/valueUtil.js.map +1 -0
  376. package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts +5 -0
  377. package/lib/tntd-select/rc-select/utils/warningPropsUtil.d.ts.map +1 -0
  378. package/lib/tntd-select/rc-select/utils/warningPropsUtil.js +130 -0
  379. package/lib/tntd-select/rc-select/utils/warningPropsUtil.js.map +1 -0
  380. package/package.json +1 -1
@@ -0,0 +1,47 @@
1
+ import * as React from 'react';
2
+ import classNames from 'classnames';
3
+ import { composeRef } from 'rc-util/lib/ref';
4
+ import { warning } from 'rc-util/lib/warning';
5
+ const Input = ({ prefixCls, id, inputElement, disabled, tabIndex, autoFocus, autoComplete, editable, activeDescendantId, value, maxLength, onKeyDown, onMouseDown, onChange, onPaste, onCompositionStart, onCompositionEnd, open, attrs, }, ref) => {
6
+ var _a;
7
+ let inputNode = inputElement || React.createElement("input", null);
8
+ const { ref: originRef, props: originProps } = inputNode;
9
+ const { onKeyDown: onOriginKeyDown, onChange: onOriginChange, onMouseDown: onOriginMouseDown, onCompositionStart: onOriginCompositionStart, onCompositionEnd: onOriginCompositionEnd, style, } = originProps;
10
+ warning(!('maxLength' in inputNode.props), `Passing 'maxLength' to input element directly may not work because input in BaseSelect is controlled.`);
11
+ inputNode = React.cloneElement(inputNode, Object.assign(Object.assign(Object.assign(Object.assign({ type: 'search' }, originProps), {
12
+ // Override over origin props
13
+ id, ref: composeRef(ref, originRef), disabled,
14
+ tabIndex, autoComplete: autoComplete || 'off', autoFocus, className: classNames(`${prefixCls}-selection-search-input`, (_a = inputNode === null || inputNode === void 0 ? void 0 : inputNode.props) === null || _a === void 0 ? void 0 : _a.className), role: 'combobox', 'aria-expanded': open || false, 'aria-haspopup': 'listbox', 'aria-owns': `${id}_list`, 'aria-autocomplete': 'list', 'aria-controls': `${id}_list`, 'aria-activedescendant': open ? activeDescendantId : undefined }), attrs), { value: editable ? value : '', maxLength, readOnly: !editable, unselectable: !editable ? 'on' : null, style: Object.assign(Object.assign({}, style), { opacity: editable ? null : 0 }), onKeyDown: (event) => {
15
+ onKeyDown(event);
16
+ if (onOriginKeyDown) {
17
+ onOriginKeyDown(event);
18
+ }
19
+ }, onMouseDown: (event) => {
20
+ onMouseDown(event);
21
+ if (onOriginMouseDown) {
22
+ onOriginMouseDown(event);
23
+ }
24
+ }, onChange: (event) => {
25
+ onChange(event);
26
+ if (onOriginChange) {
27
+ onOriginChange(event);
28
+ }
29
+ }, onCompositionStart(event) {
30
+ onCompositionStart(event);
31
+ if (onOriginCompositionStart) {
32
+ onOriginCompositionStart(event);
33
+ }
34
+ },
35
+ onCompositionEnd(event) {
36
+ onCompositionEnd(event);
37
+ if (onOriginCompositionEnd) {
38
+ onOriginCompositionEnd(event);
39
+ }
40
+ },
41
+ onPaste }));
42
+ return inputNode;
43
+ };
44
+ const RefInput = React.forwardRef(Input);
45
+ RefInput.displayName = 'Input';
46
+ export default RefInput;
47
+ //# sourceMappingURL=Input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Input.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/Input.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport classNames from 'classnames';\nimport { composeRef } from 'rc-util/lib/ref';\nimport { warning } from 'rc-util/lib/warning';\n\ntype InputRef = HTMLInputElement | HTMLTextAreaElement;\n\ninterface InputProps {\n prefixCls: string;\n id: string;\n inputElement: React.ReactElement;\n disabled: boolean;\n autoFocus: boolean;\n autoComplete: string;\n editable: boolean;\n activeDescendantId?: string;\n value: string;\n maxLength?: number;\n open: boolean;\n tabIndex: number;\n /** Pass accessibility props to input */\n attrs: Record<string, unknown>;\n\n onKeyDown: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onMouseDown: React.MouseEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onChange: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onPaste: React.ClipboardEventHandler<HTMLInputElement | HTMLTextAreaElement | HTMLElement>;\n onCompositionStart: React.CompositionEventHandler<\n HTMLInputElement | HTMLTextAreaElement | HTMLElement\n >;\n onCompositionEnd: React.CompositionEventHandler<\n HTMLInputElement | HTMLTextAreaElement | HTMLElement\n >;\n}\n\nconst Input: React.RefForwardingComponent<InputRef, InputProps> = (\n {\n prefixCls,\n id,\n inputElement,\n disabled,\n tabIndex,\n autoFocus,\n autoComplete,\n editable,\n activeDescendantId,\n value,\n maxLength,\n onKeyDown,\n onMouseDown,\n onChange,\n onPaste,\n onCompositionStart,\n onCompositionEnd,\n open,\n attrs,\n },\n ref,\n) => {\n let inputNode: React.ComponentElement<any, any> = inputElement || <input />;\n\n const { ref: originRef, props: originProps } = inputNode;\n\n const {\n onKeyDown: onOriginKeyDown,\n onChange: onOriginChange,\n onMouseDown: onOriginMouseDown,\n onCompositionStart: onOriginCompositionStart,\n onCompositionEnd: onOriginCompositionEnd,\n style,\n } = originProps;\n\n warning(\n !('maxLength' in inputNode.props),\n `Passing 'maxLength' to input element directly may not work because input in BaseSelect is controlled.`,\n );\n\n inputNode = React.cloneElement(inputNode, {\n type: 'search',\n ...originProps,\n\n // Override over origin props\n id,\n ref: composeRef(ref, originRef as any),\n disabled,\n tabIndex,\n autoComplete: autoComplete || 'off',\n\n autoFocus,\n className: classNames(`${prefixCls}-selection-search-input`, inputNode?.props?.className),\n\n role: 'combobox',\n 'aria-expanded': open || false,\n 'aria-haspopup': 'listbox',\n 'aria-owns': `${id}_list`,\n 'aria-autocomplete': 'list',\n 'aria-controls': `${id}_list`,\n 'aria-activedescendant': open ? activeDescendantId : undefined,\n ...attrs,\n value: editable ? value : '',\n maxLength,\n readOnly: !editable,\n unselectable: !editable ? 'on' : null,\n\n style: { ...style, opacity: editable ? null : 0 },\n\n onKeyDown: (event: React.KeyboardEvent<HTMLElement>) => {\n onKeyDown(event);\n if (onOriginKeyDown) {\n onOriginKeyDown(event);\n }\n },\n onMouseDown: (event: React.MouseEvent<HTMLElement>) => {\n onMouseDown(event);\n if (onOriginMouseDown) {\n onOriginMouseDown(event);\n }\n },\n onChange: (event: React.ChangeEvent<HTMLElement>) => {\n onChange(event);\n if (onOriginChange) {\n onOriginChange(event);\n }\n },\n onCompositionStart(event: React.CompositionEvent<HTMLElement>) {\n onCompositionStart(event);\n if (onOriginCompositionStart) {\n onOriginCompositionStart(event);\n }\n },\n onCompositionEnd(event: React.CompositionEvent<HTMLElement>) {\n onCompositionEnd(event);\n if (onOriginCompositionEnd) {\n onOriginCompositionEnd(event);\n }\n },\n onPaste,\n });\n\n return inputNode;\n};\n\nconst RefInput = React.forwardRef<InputRef, InputProps>(Input);\nRefInput.displayName = 'Input';\n\nexport default RefInput;\n"]}
@@ -0,0 +1,97 @@
1
+ import * as React from 'react';
2
+ import { useState } from 'react';
3
+ import classNames from 'classnames';
4
+ import pickAttrs from 'rc-util/lib/pickAttrs';
5
+ import Overflow from 'rc-overflow';
6
+ import TransBtn from '../TransBtn';
7
+ import Input from './Input';
8
+ import useLayoutEffect from '../hooks/useLayoutEffect';
9
+ import { getTitle } from '../utils/commonUtil';
10
+ function itemKey(value) {
11
+ var _a;
12
+ return (_a = value.key) !== null && _a !== void 0 ? _a : value.value;
13
+ }
14
+ const onPreventMouseDown = (event) => {
15
+ event.preventDefault();
16
+ event.stopPropagation();
17
+ };
18
+ const SelectSelector = (props) => {
19
+ const { id, prefixCls, values, open, searchValue, autoClearSearchValue, inputRef, placeholder, disabled, mode, showSearch, autoFocus, autoComplete, activeDescendantId, tabIndex, removeIcon, maxTagCount, maxTagTextLength, maxTagPlaceholder = (omittedValues) => `+ ${omittedValues.length} ...`, tagRender, onToggleOpen, onRemove, onInputChange, onInputPaste, onInputKeyDown, onInputMouseDown, onInputCompositionStart, onInputCompositionEnd, } = props;
20
+ const measureRef = React.useRef(null);
21
+ const [inputWidth, setInputWidth] = useState(0);
22
+ const [focused, setFocused] = useState(false);
23
+ const selectionPrefixCls = `${prefixCls}-selection`;
24
+ // ===================== Search ======================
25
+ const inputValue = open || (mode === "multiple" && autoClearSearchValue === false) || mode === 'tags' ? searchValue : '';
26
+ const inputEditable = mode === 'tags' || (mode === "multiple" && autoClearSearchValue === false) || (showSearch && (open || focused));
27
+ // We measure width and set to the input immediately
28
+ useLayoutEffect(() => {
29
+ setInputWidth(measureRef.current.scrollWidth);
30
+ }, [inputValue]);
31
+ // ===================== Render ======================
32
+ // >>> Render Selector Node. Includes Item & Rest
33
+ function defaultRenderSelector(item, content, itemDisabled, closable, onClose) {
34
+ return (React.createElement("span", { className: classNames(`${selectionPrefixCls}-item`, {
35
+ [`${selectionPrefixCls}-item-disabled`]: itemDisabled,
36
+ }), title: getTitle(item) },
37
+ React.createElement("span", { className: `${selectionPrefixCls}-item-content` }, content),
38
+ closable && (React.createElement(TransBtn, { className: `${selectionPrefixCls}-item-remove`, onMouseDown: onPreventMouseDown, onClick: onClose, customizeIcon: removeIcon }, "\u00D7"))));
39
+ }
40
+ function customizeRenderSelector(value, content, itemDisabled, closable, onClose) {
41
+ const onMouseDown = (e) => {
42
+ onPreventMouseDown(e);
43
+ onToggleOpen(!open);
44
+ };
45
+ return (React.createElement("span", { onMouseDown: onMouseDown }, tagRender({
46
+ label: content,
47
+ value,
48
+ disabled: itemDisabled,
49
+ closable,
50
+ onClose,
51
+ })));
52
+ }
53
+ function renderItem(valueItem) {
54
+ const { disabled: itemDisabled, label, value } = valueItem;
55
+ const closable = !disabled && !itemDisabled;
56
+ let displayLabel = label;
57
+ if (typeof maxTagTextLength === 'number') {
58
+ if (typeof label === 'string' || typeof label === 'number') {
59
+ const strLabel = String(displayLabel);
60
+ if (strLabel.length > maxTagTextLength) {
61
+ displayLabel = `${strLabel.slice(0, maxTagTextLength)}...`;
62
+ }
63
+ }
64
+ }
65
+ const onClose = (event) => {
66
+ if (event)
67
+ event.stopPropagation();
68
+ onRemove(valueItem);
69
+ };
70
+ return typeof tagRender === 'function'
71
+ ? customizeRenderSelector(value, displayLabel, itemDisabled, closable, onClose)
72
+ : defaultRenderSelector(valueItem, displayLabel, itemDisabled, closable, onClose);
73
+ }
74
+ function renderRest(omittedValues) {
75
+ const content = typeof maxTagPlaceholder === 'function'
76
+ ? maxTagPlaceholder(omittedValues)
77
+ : maxTagPlaceholder;
78
+ return defaultRenderSelector({ title: content }, content, false);
79
+ }
80
+ // >>> Input Node
81
+ const inputNode = (React.createElement("div", { className: `${selectionPrefixCls}-search`, style: { width: inputWidth }, onFocus: () => {
82
+ setFocused(true);
83
+ }, onBlur: () => {
84
+ setFocused(false);
85
+ } },
86
+ React.createElement(Input, { ref: inputRef, open: open, prefixCls: prefixCls, id: id, inputElement: null, disabled: disabled, autoFocus: autoFocus, autoComplete: autoComplete, editable: inputEditable, activeDescendantId: activeDescendantId, value: inputValue, onKeyDown: onInputKeyDown, onMouseDown: onInputMouseDown, onChange: onInputChange, onPaste: onInputPaste, onCompositionStart: onInputCompositionStart, onCompositionEnd: onInputCompositionEnd, tabIndex: tabIndex, attrs: pickAttrs(props, true) }),
87
+ React.createElement("span", { ref: measureRef, className: `${selectionPrefixCls}-search-mirror`, "aria-hidden": true },
88
+ inputValue,
89
+ "\u00A0")));
90
+ // >>> Selections
91
+ const selectionNode = (React.createElement(Overflow, { prefixCls: `${selectionPrefixCls}-overflow`, data: values, renderItem: renderItem, renderRest: renderRest, suffix: inputNode, itemKey: itemKey, maxCount: maxTagCount }));
92
+ return (React.createElement(React.Fragment, null,
93
+ selectionNode,
94
+ !values.length && !inputValue && (React.createElement("span", { className: `${selectionPrefixCls}-placeholder` }, placeholder))));
95
+ };
96
+ export default SelectSelector;
97
+ //# sourceMappingURL=MultipleSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MultipleSelector.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/MultipleSelector.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport { useState } from 'react';\nimport classNames from 'classnames';\nimport pickAttrs from 'rc-util/lib/pickAttrs';\nimport Overflow from 'rc-overflow';\nimport TransBtn from '../TransBtn';\nimport type { InnerSelectorProps } from '.';\nimport Input from './Input';\nimport useLayoutEffect from '../hooks/useLayoutEffect';\nimport type { DisplayValueType, RenderNode, CustomTagProps, RawValueType } from '../BaseSelect';\nimport { getTitle } from '../utils/commonUtil';\n\nfunction itemKey(value: DisplayValueType) {\n return value.key ?? value.value;\n}\n\ninterface SelectorProps extends InnerSelectorProps {\n // Icon\n removeIcon?: RenderNode;\n\n // Tags\n maxTagCount?: number | 'responsive';\n maxTagTextLength?: number;\n maxTagPlaceholder?: React.ReactNode | ((omittedValues: DisplayValueType[]) => React.ReactNode);\n tokenSeparators?: string[];\n tagRender?: (props: CustomTagProps) => React.ReactElement;\n onToggleOpen: (open?: boolean) => void;\n\n // Motion\n choiceTransitionName?: string;\n\n // Event\n onRemove: (value: DisplayValueType) => void;\n}\n\nconst onPreventMouseDown = (event: React.MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n};\nconst SelectSelector: React.FC<SelectorProps> = (props) => {\n const {\n id,\n prefixCls,\n\n values,\n open,\n searchValue,\n autoClearSearchValue,\n inputRef,\n placeholder,\n disabled,\n mode,\n showSearch,\n autoFocus,\n autoComplete,\n activeDescendantId,\n tabIndex,\n\n removeIcon,\n\n maxTagCount,\n maxTagTextLength,\n maxTagPlaceholder = (omittedValues: DisplayValueType[]) => `+ ${omittedValues.length} ...`,\n tagRender,\n onToggleOpen,\n\n onRemove,\n onInputChange,\n onInputPaste,\n onInputKeyDown,\n onInputMouseDown,\n onInputCompositionStart,\n onInputCompositionEnd,\n } = props;\n\n const measureRef = React.useRef<HTMLSpanElement>(null);\n const [inputWidth, setInputWidth] = useState(0);\n const [focused, setFocused] = useState(false);\n\n const selectionPrefixCls = `${prefixCls}-selection`;\n\n // ===================== Search ======================\n const inputValue = open || (mode === \"multiple\" && autoClearSearchValue === false) || mode === 'tags' ? searchValue : '';\n const inputEditable: boolean = mode === 'tags' || (mode === \"multiple\" && autoClearSearchValue === false) || (showSearch && (open || focused));\n\n // We measure width and set to the input immediately\n useLayoutEffect(() => {\n setInputWidth(measureRef.current.scrollWidth);\n }, [inputValue]);\n\n // ===================== Render ======================\n // >>> Render Selector Node. Includes Item & Rest\n function defaultRenderSelector(\n item: DisplayValueType,\n content: React.ReactNode,\n itemDisabled: boolean,\n closable?: boolean,\n onClose?: React.MouseEventHandler,\n ) {\n return (\n <span\n className={classNames(`${selectionPrefixCls}-item`, {\n [`${selectionPrefixCls}-item-disabled`]: itemDisabled,\n })}\n title={getTitle(item)}\n >\n <span className={`${selectionPrefixCls}-item-content`}>{content}</span>\n {closable && (\n <TransBtn\n className={`${selectionPrefixCls}-item-remove`}\n onMouseDown={onPreventMouseDown}\n onClick={onClose}\n customizeIcon={removeIcon}\n >\n ×\n </TransBtn>\n )}\n </span>\n );\n }\n\n function customizeRenderSelector(\n value: RawValueType,\n content: React.ReactNode,\n itemDisabled: boolean,\n closable: boolean,\n onClose: React.MouseEventHandler,\n ) {\n const onMouseDown = (e: React.MouseEvent) => {\n onPreventMouseDown(e);\n onToggleOpen(!open);\n };\n\n return (\n <span onMouseDown={onMouseDown}>\n {tagRender({\n label: content,\n value,\n disabled: itemDisabled,\n closable,\n onClose,\n })}\n </span>\n );\n }\n\n function renderItem(valueItem: DisplayValueType) {\n const { disabled: itemDisabled, label, value } = valueItem;\n const closable = !disabled && !itemDisabled;\n\n let displayLabel: React.ReactNode = label;\n\n if (typeof maxTagTextLength === 'number') {\n if (typeof label === 'string' || typeof label === 'number') {\n const strLabel = String(displayLabel);\n\n if (strLabel.length > maxTagTextLength) {\n displayLabel = `${strLabel.slice(0, maxTagTextLength)}...`;\n }\n }\n }\n\n const onClose = (event?: React.MouseEvent) => {\n if (event) event.stopPropagation();\n onRemove(valueItem);\n };\n\n return typeof tagRender === 'function'\n ? customizeRenderSelector(value, displayLabel, itemDisabled, closable, onClose)\n : defaultRenderSelector(valueItem, displayLabel, itemDisabled, closable, onClose);\n }\n\n function renderRest(omittedValues: DisplayValueType[]) {\n const content =\n typeof maxTagPlaceholder === 'function'\n ? maxTagPlaceholder(omittedValues)\n : maxTagPlaceholder;\n\n return defaultRenderSelector({ title: content }, content, false);\n }\n\n // >>> Input Node\n const inputNode = (\n <div\n className={`${selectionPrefixCls}-search`}\n style={{ width: inputWidth }}\n onFocus={() => {\n setFocused(true);\n }}\n onBlur={() => {\n setFocused(false);\n }}\n >\n <Input\n ref={inputRef}\n open={open}\n prefixCls={prefixCls}\n id={id}\n inputElement={null}\n disabled={disabled}\n autoFocus={autoFocus}\n autoComplete={autoComplete}\n editable={inputEditable}\n activeDescendantId={activeDescendantId}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onMouseDown={onInputMouseDown}\n onChange={onInputChange}\n onPaste={onInputPaste}\n onCompositionStart={onInputCompositionStart}\n onCompositionEnd={onInputCompositionEnd}\n tabIndex={tabIndex}\n attrs={pickAttrs(props, true)}\n />\n\n {/* Measure Node */}\n <span ref={measureRef} className={`${selectionPrefixCls}-search-mirror`} aria-hidden>\n {inputValue}&nbsp;\n </span>\n </div>\n );\n\n // >>> Selections\n const selectionNode = (\n <Overflow\n prefixCls={`${selectionPrefixCls}-overflow`}\n data={values}\n renderItem={renderItem}\n renderRest={renderRest}\n suffix={inputNode}\n itemKey={itemKey}\n maxCount={maxTagCount}\n />\n );\n\n return (\n <>\n {selectionNode}\n\n {!values.length && !inputValue && (\n <span className={`${selectionPrefixCls}-placeholder`}>{placeholder}</span>\n )}\n </>\n );\n};\n\nexport default SelectSelector;\n"]}
@@ -0,0 +1,45 @@
1
+ import * as React from 'react';
2
+ import pickAttrs from 'rc-util/lib/pickAttrs';
3
+ import Input from './Input';
4
+ import { getTitle } from '../utils/commonUtil';
5
+ const SingleSelector = (props) => {
6
+ const { inputElement, prefixCls, id, inputRef, disabled, autoFocus, autoComplete, activeDescendantId, mode, open, values, placeholder, tabIndex, showSearch, searchValue, activeValue, maxLength, onInputKeyDown, onInputMouseDown, onInputChange, onInputPaste, onInputCompositionStart, onInputCompositionEnd, title, } = props;
7
+ const [inputChanged, setInputChanged] = React.useState(false);
8
+ const combobox = mode === 'combobox';
9
+ const inputEditable = combobox || showSearch;
10
+ const item = values[0];
11
+ let inputValue = searchValue || '';
12
+ if (combobox && activeValue && !inputChanged) {
13
+ inputValue = activeValue;
14
+ }
15
+ React.useEffect(() => {
16
+ if (combobox) {
17
+ setInputChanged(false);
18
+ }
19
+ }, [combobox, activeValue]);
20
+ // Not show text when closed expect combobox mode
21
+ const hasTextInput = mode !== 'combobox' && !open && !showSearch ? false : !!inputValue;
22
+ // Get title of selection item
23
+ const selectionTitle = title === undefined ? getTitle(item) : title;
24
+ const renderPlaceholder = () => {
25
+ if (item) {
26
+ return null;
27
+ }
28
+ const hiddenStyle = hasTextInput ? { visibility: 'hidden' } : undefined;
29
+ return (React.createElement("span", { className: `${prefixCls}-selection-placeholder`, style: hiddenStyle }, placeholder));
30
+ };
31
+ return (React.createElement(React.Fragment, null,
32
+ React.createElement("span", { className: `${prefixCls}-selection-search` },
33
+ React.createElement(Input, { ref: inputRef, prefixCls: prefixCls, id: id, open: open, inputElement: inputElement, disabled: disabled, autoFocus: autoFocus, autoComplete: autoComplete, editable: inputEditable, activeDescendantId: activeDescendantId, value: inputValue, onKeyDown: onInputKeyDown, onMouseDown: onInputMouseDown, onChange: (e) => {
34
+ setInputChanged(true);
35
+ onInputChange(e);
36
+ }, onPaste: onInputPaste, onCompositionStart: onInputCompositionStart, onCompositionEnd: onInputCompositionEnd, tabIndex: tabIndex, attrs: pickAttrs(props, true), maxLength: combobox ? maxLength : undefined })),
37
+ (!combobox && item) ? (React.createElement("span", { className: `${prefixCls}-selection-item`, title: selectionTitle,
38
+ // 当 Select 已经选中选项时,还需 selection 隐藏但留在原地占位
39
+ // https://github.com/ant-design/ant-design/issues/27688
40
+ // https://github.com/ant-design/ant-design/issues/41530
41
+ style: hasTextInput ? { visibility: 'hidden' } : undefined }, item.label)) : null,
42
+ renderPlaceholder()));
43
+ };
44
+ export default SingleSelector;
45
+ //# sourceMappingURL=SingleSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SingleSelector.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/SingleSelector.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport pickAttrs from 'rc-util/lib/pickAttrs';\nimport Input from './Input';\nimport type { InnerSelectorProps } from '.';\nimport { getTitle } from '../utils/commonUtil';\n\ninterface SelectorProps extends InnerSelectorProps {\n inputElement: React.ReactElement;\n activeValue: string;\n}\n\nconst SingleSelector: React.FC<SelectorProps> = (props) => {\n const {\n inputElement,\n prefixCls,\n id,\n inputRef,\n disabled,\n autoFocus,\n autoComplete,\n activeDescendantId,\n mode,\n open,\n values,\n placeholder,\n tabIndex,\n\n showSearch,\n searchValue,\n activeValue,\n maxLength,\n\n onInputKeyDown,\n onInputMouseDown,\n onInputChange,\n onInputPaste,\n onInputCompositionStart,\n onInputCompositionEnd,\n title,\n } = props;\n\n const [inputChanged, setInputChanged] = React.useState(false);\n\n const combobox = mode === 'combobox';\n const inputEditable = combobox || showSearch;\n const item = values[0];\n\n let inputValue: string = searchValue || '';\n if (combobox && activeValue && !inputChanged) {\n inputValue = activeValue;\n }\n\n React.useEffect(() => {\n if (combobox) {\n setInputChanged(false);\n }\n }, [combobox, activeValue]);\n\n // Not show text when closed expect combobox mode\n const hasTextInput = mode !== 'combobox' && !open && !showSearch ? false : !!inputValue;\n\n // Get title of selection item\n const selectionTitle = title === undefined ? getTitle(item) : title;\n\n const renderPlaceholder = () => {\n if (item) {\n return null;\n }\n const hiddenStyle = hasTextInput ? { visibility: 'hidden' } as React.CSSProperties : undefined;\n return (\n <span\n className={`${prefixCls}-selection-placeholder`}\n style={hiddenStyle}\n >\n {placeholder}\n </span>\n );\n };\n\n return (\n <>\n <span className={`${prefixCls}-selection-search`}>\n <Input\n ref={inputRef}\n prefixCls={prefixCls}\n id={id}\n open={open}\n inputElement={inputElement}\n disabled={disabled}\n autoFocus={autoFocus}\n autoComplete={autoComplete}\n editable={inputEditable}\n activeDescendantId={activeDescendantId}\n value={inputValue}\n onKeyDown={onInputKeyDown}\n onMouseDown={onInputMouseDown}\n onChange={(e) => {\n setInputChanged(true);\n onInputChange(e as any);\n }}\n onPaste={onInputPaste}\n onCompositionStart={onInputCompositionStart}\n onCompositionEnd={onInputCompositionEnd}\n tabIndex={tabIndex}\n attrs={pickAttrs(props, true)}\n maxLength={combobox ? maxLength : undefined}\n />\n </span>\n\n {/* Display value */}\n {(!combobox && item) ? (\n <span\n className={`${prefixCls}-selection-item`}\n title={selectionTitle}\n // 当 Select 已经选中选项时,还需 selection 隐藏但留在原地占位\n // https://github.com/ant-design/ant-design/issues/27688\n // https://github.com/ant-design/ant-design/issues/41530\n style={hasTextInput ? { visibility: 'hidden' } as React.CSSProperties : undefined}\n >\n {item.label}\n </span>\n ) : null}\n\n {/* Display placeholder */}\n {renderPlaceholder()}\n </>\n );\n};\n\nexport default SingleSelector;\n"]}
@@ -0,0 +1,136 @@
1
+ /**
2
+ * Cursor rule:
3
+ * 1. Only `showSearch` enabled
4
+ * 2. Only `open` is `true`
5
+ * 3. When typing, set `open` to `true` which hit rule of 2
6
+ *
7
+ * Accessibility:
8
+ * - https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html
9
+ */
10
+ import * as React from 'react';
11
+ import { useRef } from 'react';
12
+ import KeyCode from 'rc-util/lib/KeyCode';
13
+ import MultipleSelector from './MultipleSelector';
14
+ import SingleSelector from './SingleSelector';
15
+ import useLock from '../hooks/useLock';
16
+ import { isValidateOpenKey } from '../utils/keyUtil';
17
+ const Selector = (props, ref) => {
18
+ const inputRef = useRef(null);
19
+ const compositionStatusRef = useRef(false);
20
+ const { prefixCls, open, mode, showSearch, tokenWithEnter, autoClearSearchValue, onSearch, onSearchSubmit, onToggleOpen, onInputKeyDown, domRef, } = props;
21
+ // ======================= Ref =======================
22
+ React.useImperativeHandle(ref, () => ({
23
+ focus: () => {
24
+ inputRef.current.focus();
25
+ },
26
+ blur: () => {
27
+ inputRef.current.blur();
28
+ },
29
+ }));
30
+ // ====================== Input ======================
31
+ const [getInputMouseDown, setInputMouseDown] = useLock(0);
32
+ const onInternalInputKeyDown = (event) => {
33
+ const { which } = event;
34
+ if (which === KeyCode.UP || which === KeyCode.DOWN) {
35
+ event.preventDefault();
36
+ }
37
+ if (onInputKeyDown) {
38
+ onInputKeyDown(event);
39
+ }
40
+ if (which === KeyCode.ENTER && mode === 'tags' && !compositionStatusRef.current && !open) {
41
+ // When menu isn't open, OptionList won't trigger a value change
42
+ // So when enter is pressed, the tag's input value should be emitted here to let selector know
43
+ onSearchSubmit === null || onSearchSubmit === void 0 ? void 0 : onSearchSubmit(event.target.value);
44
+ }
45
+ if (isValidateOpenKey(which)) {
46
+ onToggleOpen(true);
47
+ }
48
+ };
49
+ /**
50
+ * We can not use `findDOMNode` sine it will get warning,
51
+ * have to use timer to check if is input element.
52
+ */
53
+ const onInternalInputMouseDown = () => {
54
+ setInputMouseDown(true);
55
+ };
56
+ // When paste come, ignore next onChange
57
+ const pastedTextRef = useRef(null);
58
+ const triggerOnSearch = (value) => {
59
+ if (onSearch(value, true, compositionStatusRef.current) !== false) {
60
+ onToggleOpen(true);
61
+ }
62
+ };
63
+ const onInputCompositionStart = () => {
64
+ compositionStatusRef.current = true;
65
+ };
66
+ const onInputCompositionEnd = (e) => {
67
+ compositionStatusRef.current = false;
68
+ // Trigger search again to support `tokenSeparators` with typewriting
69
+ if (mode !== 'combobox') {
70
+ triggerOnSearch(e.target.value);
71
+ }
72
+ };
73
+ const onInputChange = (event) => {
74
+ let { target: { value }, } = event;
75
+ // Pasted text should replace back to origin content
76
+ if (tokenWithEnter && pastedTextRef.current && /[\r\n]/.test(pastedTextRef.current)) {
77
+ // CRLF will be treated as a single space for input element
78
+ const replacedText = pastedTextRef.current
79
+ .replace(/[\r\n]+$/, '')
80
+ .replace(/\r\n/g, ' ')
81
+ .replace(/[\r\n]/g, ' ');
82
+ value = value.replace(replacedText, pastedTextRef.current);
83
+ }
84
+ pastedTextRef.current = null;
85
+ triggerOnSearch(value);
86
+ };
87
+ const onInputPaste = (e) => {
88
+ const { clipboardData } = e;
89
+ const value = clipboardData.getData('text');
90
+ pastedTextRef.current = value;
91
+ };
92
+ const onClick = ({ target }) => {
93
+ if (target !== inputRef.current) {
94
+ // Should focus input if click the selector
95
+ const isIE = document.body.style.msTouchAction !== undefined;
96
+ if (isIE) {
97
+ setTimeout(() => {
98
+ inputRef.current.focus();
99
+ });
100
+ }
101
+ else {
102
+ inputRef.current.focus();
103
+ }
104
+ }
105
+ };
106
+ const onMouseDown = (event) => {
107
+ const inputMouseDown = getInputMouseDown();
108
+ // when mode is combobox, don't prevent default behavior
109
+ // https://github.com/ant-design/ant-design/issues/37320
110
+ if (event.target !== inputRef.current && !inputMouseDown && mode !== 'combobox') {
111
+ event.preventDefault();
112
+ }
113
+ if ((mode !== 'combobox' && (!showSearch || !inputMouseDown)) || !open) {
114
+ if (open && autoClearSearchValue !== false) {
115
+ onSearch('', true, false);
116
+ }
117
+ onToggleOpen();
118
+ }
119
+ };
120
+ // ================= Inner Selector ==================
121
+ const sharedProps = {
122
+ inputRef,
123
+ onInputKeyDown: onInternalInputKeyDown,
124
+ onInputMouseDown: onInternalInputMouseDown,
125
+ onInputChange,
126
+ onInputPaste,
127
+ onInputCompositionStart,
128
+ onInputCompositionEnd,
129
+ };
130
+ const selectNode = mode === 'multiple' || mode === 'tags' ? (React.createElement(MultipleSelector, Object.assign({}, props, sharedProps))) : (React.createElement(SingleSelector, Object.assign({}, props, sharedProps)));
131
+ return (React.createElement("div", { ref: domRef, className: `${prefixCls}-selector`, onClick: onClick, onMouseDown: onMouseDown }, selectNode));
132
+ };
133
+ const ForwardSelector = React.forwardRef(Selector);
134
+ ForwardSelector.displayName = 'Selector';
135
+ export default ForwardSelector;
136
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/Selector/index.tsx"],"names":[],"mappings":"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","sourcesContent":["/**\n * Cursor rule:\n * 1. Only `showSearch` enabled\n * 2. Only `open` is `true`\n * 3. When typing, set `open` to `true` which hit rule of 2\n *\n * Accessibility:\n * - https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html\n */\n\nimport * as React from 'react';\nimport { useRef } from 'react';\nimport KeyCode from 'rc-util/lib/KeyCode';\nimport type { ScrollTo } from 'rc-virtual-list/lib/List';\nimport MultipleSelector from './MultipleSelector';\nimport SingleSelector from './SingleSelector';\nimport useLock from '../hooks/useLock';\nimport type { CustomTagProps, DisplayValueType, Mode, RenderNode } from '../BaseSelect';\nimport { isValidateOpenKey } from '../utils/keyUtil';\n\nexport interface InnerSelectorProps {\n prefixCls: string;\n id: string;\n mode: Mode;\n title?: string;\n\n inputRef: React.Ref<HTMLInputElement | HTMLTextAreaElement>;\n placeholder?: React.ReactNode;\n disabled?: boolean;\n autoFocus?: boolean;\n autoComplete?: string;\n values: DisplayValueType[];\n showSearch?: boolean;\n searchValue: string;\n autoClearSearchValue?: boolean;\n activeDescendantId?: string;\n open: boolean;\n tabIndex?: number;\n maxLength?: number;\n\n onInputKeyDown: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputMouseDown: React.MouseEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputChange: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputPaste: React.ClipboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputCompositionStart: React.CompositionEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n onInputCompositionEnd: React.CompositionEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n}\n\nexport interface RefSelectorProps {\n focus: () => void;\n blur: () => void;\n scrollTo?: ScrollTo;\n}\n\nexport interface SelectorProps {\n id: string;\n prefixCls: string;\n showSearch?: boolean;\n open: boolean;\n /** Display in the Selector value, it's not same as `value` prop */\n values: DisplayValueType[];\n mode: Mode;\n searchValue: string;\n activeValue: string;\n autoClearSearchValue: boolean;\n inputElement: JSX.Element;\n maxLength?: number;\n\n autoFocus?: boolean;\n activeDescendantId?: string;\n tabIndex?: number;\n disabled?: boolean;\n placeholder?: React.ReactNode;\n removeIcon?: RenderNode;\n\n // Tags\n maxTagCount?: number | 'responsive';\n maxTagTextLength?: number;\n maxTagPlaceholder?: React.ReactNode | ((omittedValues: DisplayValueType[]) => React.ReactNode);\n tagRender?: (props: CustomTagProps) => React.ReactElement;\n\n /** Check if `tokenSeparators` contains `\\n` or `\\r\\n` */\n tokenWithEnter?: boolean;\n\n // Motion\n choiceTransitionName?: string;\n\n onToggleOpen: (open?: boolean) => void;\n /** `onSearch` returns go next step boolean to check if need do toggle open */\n onSearch: (searchText: string, fromTyping: boolean, isCompositing: boolean) => boolean;\n onSearchSubmit?: (searchText: string) => void;\n onRemove: (value: DisplayValueType) => void;\n onInputKeyDown?: React.KeyboardEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n\n /**\n * @private get real dom for trigger align.\n * This may be removed after React provides replacement of `findDOMNode`\n */\n domRef: React.Ref<HTMLDivElement>;\n}\n\nconst Selector: React.RefForwardingComponent<RefSelectorProps, SelectorProps> = (props, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const compositionStatusRef = useRef<boolean>(false);\n\n const {\n prefixCls,\n open,\n mode,\n showSearch,\n tokenWithEnter,\n\n autoClearSearchValue,\n\n onSearch,\n onSearchSubmit,\n onToggleOpen,\n onInputKeyDown,\n\n domRef,\n } = props;\n\n // ======================= Ref =======================\n React.useImperativeHandle(ref, () => ({\n focus: () => {\n inputRef.current.focus();\n },\n blur: () => {\n inputRef.current.blur();\n },\n }));\n\n // ====================== Input ======================\n const [getInputMouseDown, setInputMouseDown] = useLock(0);\n\n const onInternalInputKeyDown: React.KeyboardEventHandler<HTMLInputElement> = (event) => {\n const { which } = event;\n\n if (which === KeyCode.UP || which === KeyCode.DOWN) {\n event.preventDefault();\n }\n\n if (onInputKeyDown) {\n onInputKeyDown(event);\n }\n\n if (which === KeyCode.ENTER && mode === 'tags' && !compositionStatusRef.current && !open) {\n // When menu isn't open, OptionList won't trigger a value change\n // So when enter is pressed, the tag's input value should be emitted here to let selector know\n onSearchSubmit?.((event.target as HTMLInputElement).value);\n }\n\n if (isValidateOpenKey(which)) {\n onToggleOpen(true);\n }\n };\n\n /**\n * We can not use `findDOMNode` sine it will get warning,\n * have to use timer to check if is input element.\n */\n const onInternalInputMouseDown: React.MouseEventHandler<HTMLInputElement> = () => {\n setInputMouseDown(true);\n };\n\n // When paste come, ignore next onChange\n const pastedTextRef = useRef<string>(null);\n\n const triggerOnSearch = (value: string) => {\n if (onSearch(value, true, compositionStatusRef.current) !== false) {\n onToggleOpen(true);\n }\n };\n\n const onInputCompositionStart = () => {\n compositionStatusRef.current = true;\n };\n\n const onInputCompositionEnd: React.CompositionEventHandler<HTMLInputElement> = (e) => {\n compositionStatusRef.current = false;\n\n // Trigger search again to support `tokenSeparators` with typewriting\n if (mode !== 'combobox') {\n triggerOnSearch((e.target as HTMLInputElement).value);\n }\n };\n\n const onInputChange: React.ChangeEventHandler<HTMLInputElement> = (event) => {\n let {\n target: { value },\n } = event;\n\n // Pasted text should replace back to origin content\n if (tokenWithEnter && pastedTextRef.current && /[\\r\\n]/.test(pastedTextRef.current)) {\n // CRLF will be treated as a single space for input element\n const replacedText = pastedTextRef.current\n .replace(/[\\r\\n]+$/, '')\n .replace(/\\r\\n/g, ' ')\n .replace(/[\\r\\n]/g, ' ');\n value = value.replace(replacedText, pastedTextRef.current);\n }\n\n pastedTextRef.current = null;\n\n triggerOnSearch(value);\n };\n\n const onInputPaste: React.ClipboardEventHandler = (e) => {\n const { clipboardData } = e;\n const value = clipboardData.getData('text');\n\n pastedTextRef.current = value;\n };\n\n const onClick = ({ target }) => {\n if (target !== inputRef.current) {\n // Should focus input if click the selector\n const isIE = (document.body.style as any).msTouchAction !== undefined;\n if (isIE) {\n setTimeout(() => {\n inputRef.current.focus();\n });\n } else {\n inputRef.current.focus();\n }\n }\n };\n\n const onMouseDown: React.MouseEventHandler<HTMLElement> = (event) => {\n const inputMouseDown = getInputMouseDown();\n\n // when mode is combobox, don't prevent default behavior\n // https://github.com/ant-design/ant-design/issues/37320\n if (event.target !== inputRef.current && !inputMouseDown && mode !== 'combobox') {\n event.preventDefault();\n }\n\n if ((mode !== 'combobox' && (!showSearch || !inputMouseDown)) || !open) {\n if (open && autoClearSearchValue !== false) {\n onSearch('', true, false);\n }\n onToggleOpen();\n }\n };\n\n // ================= Inner Selector ==================\n const sharedProps = {\n inputRef,\n onInputKeyDown: onInternalInputKeyDown,\n onInputMouseDown: onInternalInputMouseDown,\n onInputChange,\n onInputPaste,\n onInputCompositionStart,\n onInputCompositionEnd,\n };\n\n const selectNode =\n mode === 'multiple' || mode === 'tags' ? (\n <MultipleSelector {...props} {...sharedProps} />\n ) : (\n <SingleSelector {...props} {...sharedProps} />\n );\n\n return (\n <div\n ref={domRef}\n className={`${prefixCls}-selector`}\n onClick={onClick}\n onMouseDown={onMouseDown}\n >\n {selectNode}\n </div>\n );\n};\n\nconst ForwardSelector = React.forwardRef<RefSelectorProps, SelectorProps>(Selector);\nForwardSelector.displayName = 'Selector';\n\nexport default ForwardSelector;\n"]}
@@ -0,0 +1,22 @@
1
+ import * as React from 'react';
2
+ import classNames from 'classnames';
3
+ const TransBtn = ({ className, customizeIcon, customizeIconProps, onMouseDown, onClick, children, }) => {
4
+ let icon;
5
+ if (typeof customizeIcon === 'function') {
6
+ icon = customizeIcon(customizeIconProps);
7
+ }
8
+ else {
9
+ icon = customizeIcon;
10
+ }
11
+ return (React.createElement("span", { className: className, onMouseDown: (event) => {
12
+ event.preventDefault();
13
+ if (onMouseDown) {
14
+ onMouseDown(event);
15
+ }
16
+ }, style: {
17
+ userSelect: 'none',
18
+ WebkitUserSelect: 'none',
19
+ }, unselectable: "on", onClick: onClick, "aria-hidden": true }, icon !== undefined ? (icon) : (React.createElement("span", { className: classNames(className.split(/\s+/).map((cls) => `${cls}-icon`)) }, children))));
20
+ };
21
+ export default TransBtn;
22
+ //# sourceMappingURL=TransBtn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TransBtn.js","sourceRoot":"","sources":["../../../src/tntd-select/rc-select/TransBtn.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,UAAU,MAAM,YAAY,CAAC;AAYpC,MAAM,QAAQ,GAA4B,CAAC,EACzC,SAAS,EACT,aAAa,EACb,kBAAkB,EAClB,WAAW,EACX,OAAO,EACP,QAAQ,GACT,EAAE,EAAE;IACH,IAAI,IAAqB,CAAC;IAE1B,IAAI,OAAO,aAAa,KAAK,UAAU,EAAE;QACvC,IAAI,GAAG,aAAa,CAAC,kBAAkB,CAAC,CAAC;KAC1C;SAAM;QACL,IAAI,GAAG,aAAa,CAAC;KACtB;IAED,OAAO,CACL,8BACE,SAAS,EAAE,SAAS,EACpB,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE;YACrB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,WAAW,EAAE;gBACf,WAAW,CAAC,KAAK,CAAC,CAAC;aACpB;QACH,CAAC,EACD,KAAK,EAAE;YACL,UAAU,EAAE,MAAM;YAClB,gBAAgB,EAAE,MAAM;SACzB,EACD,YAAY,EAAC,IAAI,EACjB,OAAO,EAAE,OAAO,yBAGf,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CACpB,IAAI,CACL,CAAC,CAAC,CAAC,CACF,8BAAM,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,CAAC,IAC5E,QAAQ,CACJ,CACR,CACI,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC","sourcesContent":["import * as React from 'react';\nimport classNames from 'classnames';\nimport type { RenderNode } from './BaseSelect';\n\nexport interface TransBtnProps {\n className: string;\n customizeIcon: RenderNode;\n customizeIconProps?: any;\n onMouseDown?: React.MouseEventHandler<HTMLSpanElement>;\n onClick?: React.MouseEventHandler<HTMLSpanElement>;\n children?: React.ReactNode;\n}\n\nconst TransBtn: React.FC<TransBtnProps> = ({\n className,\n customizeIcon,\n customizeIconProps,\n onMouseDown,\n onClick,\n children,\n}) => {\n let icon: React.ReactNode;\n\n if (typeof customizeIcon === 'function') {\n icon = customizeIcon(customizeIconProps);\n } else {\n icon = customizeIcon;\n }\n\n return (\n <span\n className={className}\n onMouseDown={(event) => {\n event.preventDefault();\n if (onMouseDown) {\n onMouseDown(event);\n }\n }}\n style={{\n userSelect: 'none',\n WebkitUserSelect: 'none',\n }}\n unselectable=\"on\"\n onClick={onClick}\n aria-hidden\n >\n {icon !== undefined ? (\n icon\n ) : (\n <span className={classNames(className.split(/\\s+/).map((cls) => `${cls}-icon`))}>\n {children}\n </span>\n )}\n </span>\n );\n};\n\nexport default TransBtn;\n"]}
@@ -0,0 +1,25 @@
1
+ import TransBtn from '../TransBtn';
2
+ import React from 'react';
3
+ export function useAllowClear(prefixCls, onClearMouseDown, displayValues, allowClear, clearIcon, disabled = false, mergedSearchValue, mode) {
4
+ const mergedClearIcon = React.useMemo(() => {
5
+ if (typeof allowClear === "object") {
6
+ return allowClear.clearIcon;
7
+ }
8
+ if (!!clearIcon)
9
+ return clearIcon;
10
+ }, [allowClear, clearIcon]);
11
+ const mergedAllowClear = React.useMemo(() => {
12
+ if (!disabled &&
13
+ !!allowClear &&
14
+ (displayValues.length || mergedSearchValue) &&
15
+ !(mode === 'combobox' && mergedSearchValue === '')) {
16
+ return true;
17
+ }
18
+ return false;
19
+ }, [allowClear, disabled, displayValues.length, mergedSearchValue, mode]);
20
+ return {
21
+ allowClear: mergedAllowClear,
22
+ clearIcon: (React.createElement(TransBtn, { className: `${prefixCls}-clear`, onMouseDown: onClearMouseDown, customizeIcon: mergedClearIcon }, "\u00D7"))
23
+ };
24
+ }
25
+ //# sourceMappingURL=useAllowClear.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAllowClear.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useAllowClear.tsx"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,aAAa,CAAC;AAGnC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,UAAU,aAAa,CACzB,SAAS,EACT,gBAAgB,EAChB,aAAiC,EACjC,UAAgD,EAChD,SAAqB,EACrB,QAAQ,GAAG,KAAK,EAChB,iBAA0B,EAC1B,IAAW;IAEX,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACvC,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;YAChC,OAAO,UAAU,CAAC,SAAS,CAAC;SAC/B;QACD,IAAI,CAAC,CAAC,SAAS;YAAE,OAAO,SAAS,CAAC;IACtC,CAAC,EAAE,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;IAG5B,MAAM,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxC,IACI,CAAC,QAAQ;YACT,CAAC,CAAC,UAAU;YACZ,CAAC,aAAa,CAAC,MAAM,IAAI,iBAAiB,CAAC;YAC3C,CAAC,CAAC,IAAI,KAAK,UAAU,IAAI,iBAAiB,KAAK,EAAE,CAAC,EACpD;YACE,OAAO,IAAI,CAAC;SACf;QACD,OAAO,KAAK,CAAC;IACjB,CAAC,EAAE,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,CAAC,MAAM,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC,CAAC;IAE1E,OAAO;QACH,UAAU,EAAE,gBAAgB;QAC5B,SAAS,EAAE,CACP,oBAAC,QAAQ,IACL,SAAS,EAAE,GAAG,SAAS,QAAQ,EAC/B,WAAW,EAAE,gBAAgB,EAC7B,aAAa,EAAE,eAAe,aAGvB,CACd;KACJ,CAAC;AACN,CAAC","sourcesContent":["import TransBtn from '../TransBtn';\nimport type { DisplayValueType, Mode } from '../interface';\nimport type { ReactNode } from 'react';\nimport React from 'react';\n\nexport function useAllowClear(\n prefixCls,\n onClearMouseDown,\n displayValues: DisplayValueType[],\n allowClear?: boolean | { clearIcon?: ReactNode },\n clearIcon?: ReactNode,\n disabled = false,\n mergedSearchValue?: string,\n mode?: Mode\n) {\n const mergedClearIcon = React.useMemo(() => {\n if (typeof allowClear === \"object\") {\n return allowClear.clearIcon;\n }\n if (!!clearIcon) return clearIcon;\n }, [allowClear, clearIcon]);\n\n\n const mergedAllowClear = React.useMemo(() => {\n if (\n !disabled &&\n !!allowClear &&\n (displayValues.length || mergedSearchValue) &&\n !(mode === 'combobox' && mergedSearchValue === '')\n ) {\n return true;\n }\n return false;\n }, [allowClear, disabled, displayValues.length, mergedSearchValue, mode]);\n\n return {\n allowClear: mergedAllowClear,\n clearIcon: (\n <TransBtn\n className={`${prefixCls}-clear`}\n onMouseDown={onClearMouseDown}\n customizeIcon={mergedClearIcon}\n >\n ×\n </TransBtn>\n )\n };\n}\n"]}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * BaseSelect provide some parsed data into context.
3
+ * You can use this hooks to get them.
4
+ */
5
+ import * as React from 'react';
6
+ export const BaseSelectContext = React.createContext(null);
7
+ export default function useBaseProps() {
8
+ return React.useContext(BaseSelectContext);
9
+ }
10
+ //# sourceMappingURL=useBaseProps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useBaseProps.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useBaseProps.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAS/B,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,aAAa,CAAyB,IAAI,CAAC,CAAC;AAEnF,MAAM,CAAC,OAAO,UAAU,YAAY;IAClC,OAAO,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;AAC7C,CAAC","sourcesContent":["/**\n * BaseSelect provide some parsed data into context.\n * You can use this hooks to get them.\n */\n\nimport * as React from 'react';\nimport type { BaseSelectProps } from '../BaseSelect';\n\nexport interface BaseSelectContextProps extends BaseSelectProps {\n triggerOpen: boolean;\n multiple: boolean;\n toggleOpen: (open?: boolean) => void;\n}\n\nexport const BaseSelectContext = React.createContext<BaseSelectContextProps>(null);\n\nexport default function useBaseProps() {\n return React.useContext(BaseSelectContext);\n}\n"]}
@@ -0,0 +1,34 @@
1
+ import * as React from 'react';
2
+ /**
3
+ * Cache `value` related LabeledValue & options.
4
+ */
5
+ export default (labeledValues, valueOptions) => {
6
+ const cacheRef = React.useRef({
7
+ values: new Map(),
8
+ options: new Map(),
9
+ });
10
+ const filledLabeledValues = React.useMemo(() => {
11
+ const { values: prevValueCache, options: prevOptionCache } = cacheRef.current;
12
+ // Fill label by cache
13
+ const patchedValues = labeledValues.map((item) => {
14
+ var _a;
15
+ if (item.label === undefined) {
16
+ return Object.assign(Object.assign({}, item), { label: (_a = prevValueCache.get(item.value)) === null || _a === void 0 ? void 0 : _a.label });
17
+ }
18
+ return item;
19
+ });
20
+ // Refresh cache
21
+ const valueCache = new Map();
22
+ const optionCache = new Map();
23
+ patchedValues.forEach((item) => {
24
+ valueCache.set(item.value, item);
25
+ optionCache.set(item.value, valueOptions.get(item.value) || prevOptionCache.get(item.value));
26
+ });
27
+ cacheRef.current.values = valueCache;
28
+ cacheRef.current.options = optionCache;
29
+ return patchedValues;
30
+ }, [labeledValues, valueOptions]);
31
+ const getOption = React.useCallback((val) => valueOptions.get(val) || cacheRef.current.options.get(val), [valueOptions]);
32
+ return [filledLabeledValues, getOption];
33
+ };
34
+ //# sourceMappingURL=useCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCache.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useCache.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B;;GAEG;AACH,eAAe,CACb,aAAiC,EACjC,YAAkD,EACc,EAAE;IAClE,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,EAAE,IAAI,GAAG,EAAkC;QACjD,OAAO,EAAE,IAAI,GAAG,EAAmC;KACpD,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC7C,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,QAAQ,CAAC,OAAO,CAAC;QAE9E,sBAAsB;QACtB,MAAM,aAAa,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;;YAC/C,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;gBAC5B,uCACK,IAAI,KACP,KAAK,EAAE,MAAA,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,0CAAE,KAAK,IAC5C;aACH;YAED,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;QAEH,gBAAgB;QAChB,MAAM,UAAU,GAAG,IAAI,GAAG,EAAkC,CAAC;QAC7D,MAAM,WAAW,GAAG,IAAI,GAAG,EAAmC,CAAC;QAE/D,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7B,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YACjC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/F,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC;QACrC,QAAQ,CAAC,OAAO,CAAC,OAAO,GAAG,WAAW,CAAC;QAEvC,OAAO,aAAa,CAAC;IACvB,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC;IAElC,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW,CACjC,CAAC,GAAiB,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EACjF,CAAC,YAAY,CAAC,CACf,CAAC;IAEF,OAAO,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;AAC1C,CAAC,CAAC","sourcesContent":["import * as React from 'react';\nimport type { RawValueType } from '../BaseSelect';\nimport type { DefaultOptionType, LabelInValueType } from '../Select';\n\n/**\n * Cache `value` related LabeledValue & options.\n */\nexport default (\n labeledValues: LabelInValueType[],\n valueOptions: Map<RawValueType, DefaultOptionType>,\n): [LabelInValueType[], (val: RawValueType) => DefaultOptionType] => {\n const cacheRef = React.useRef({\n values: new Map<RawValueType, LabelInValueType>(),\n options: new Map<RawValueType, DefaultOptionType>(),\n });\n\n const filledLabeledValues = React.useMemo(() => {\n const { values: prevValueCache, options: prevOptionCache } = cacheRef.current;\n\n // Fill label by cache\n const patchedValues = labeledValues.map((item) => {\n if (item.label === undefined) {\n return {\n ...item,\n label: prevValueCache.get(item.value)?.label,\n };\n }\n\n return item;\n });\n\n // Refresh cache\n const valueCache = new Map<RawValueType, LabelInValueType>();\n const optionCache = new Map<RawValueType, DefaultOptionType>();\n\n patchedValues.forEach((item) => {\n valueCache.set(item.value, item);\n optionCache.set(item.value, valueOptions.get(item.value) || prevOptionCache.get(item.value));\n });\n\n cacheRef.current.values = valueCache;\n cacheRef.current.options = optionCache;\n\n return patchedValues;\n }, [labeledValues, valueOptions]);\n\n const getOption = React.useCallback(\n (val: RawValueType) => valueOptions.get(val) || cacheRef.current.options.get(val),\n [valueOptions],\n );\n\n return [filledLabeledValues, getOption];\n};\n"]}
@@ -0,0 +1,24 @@
1
+ import * as React from 'react';
2
+ /**
3
+ * Similar with `useLock`, but this hook will always execute last value.
4
+ * When set to `true`, it will keep `true` for a short time even if `false` is set.
5
+ */
6
+ export default function useDelayReset(timeout = 10) {
7
+ const [bool, setBool] = React.useState(false);
8
+ const delayRef = React.useRef(null);
9
+ const cancelLatest = () => {
10
+ window.clearTimeout(delayRef.current);
11
+ };
12
+ React.useEffect(() => cancelLatest, []);
13
+ const delaySetBool = (value, callback) => {
14
+ cancelLatest();
15
+ delayRef.current = window.setTimeout(() => {
16
+ setBool(value);
17
+ if (callback) {
18
+ callback();
19
+ }
20
+ }, timeout);
21
+ };
22
+ return [bool, delaySetBool, cancelLatest];
23
+ }
24
+ //# sourceMappingURL=useDelayReset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDelayReset.js","sourceRoot":"","sources":["../../../../src/tntd-select/rc-select/hooks/useDelayReset.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B;;;GAGG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CACnC,UAAkB,EAAE;IAEpB,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAU,KAAK,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAS,IAAI,CAAC,CAAC;IAE5C,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;IAExC,MAAM,YAAY,GAAG,CAAC,KAAc,EAAE,QAAoB,EAAE,EAAE;QAC5D,YAAY,EAAE,CAAC;QAEf,QAAQ,CAAC,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YACxC,OAAO,CAAC,KAAK,CAAC,CAAC;YACf,IAAI,QAAQ,EAAE;gBACZ,QAAQ,EAAE,CAAC;aACZ;QACH,CAAC,EAAE,OAAO,CAAC,CAAC;IACd,CAAC,CAAC;IAEF,OAAO,CAAC,IAAI,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;AAC5C,CAAC","sourcesContent":["import * as React from 'react';\n\n/**\n * Similar with `useLock`, but this hook will always execute last value.\n * When set to `true`, it will keep `true` for a short time even if `false` is set.\n */\nexport default function useDelayReset(\n timeout: number = 10,\n): [boolean, (val: boolean, callback?: () => void) => void, () => void] {\n const [bool, setBool] = React.useState<boolean>(false);\n const delayRef = React.useRef<number>(null);\n\n const cancelLatest = () => {\n window.clearTimeout(delayRef.current);\n };\n\n React.useEffect(() => cancelLatest, []);\n\n const delaySetBool = (value: boolean, callback: () => void) => {\n cancelLatest();\n\n delayRef.current = window.setTimeout(() => {\n setBool(value);\n if (callback) {\n callback();\n }\n }, timeout);\n };\n\n return [bool, delaySetBool, cancelLatest];\n}\n"]}