tntd 2.0.8 → 2.0.10

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 (613) hide show
  1. package/es/affix/index.js +1 -2
  2. package/es/alert/index.js +1 -2
  3. package/es/anchor/index.js +1 -2
  4. package/es/array-input/icon.js +24 -6
  5. package/es/array-input/index.js +228 -119
  6. package/es/auth-context/index.js +1 -2
  7. package/es/auto-complete/index.js +1 -2
  8. package/es/avatar/index.js +1 -2
  9. package/es/back-top/index.js +1 -2
  10. package/es/badge/index.js +1 -2
  11. package/es/breadcrumb/index.js +1 -2
  12. package/es/button/index.js +1 -2
  13. package/es/calendar/index.js +1 -2
  14. package/es/card/index.js +1 -2
  15. package/es/carousel/index.js +1 -2
  16. package/es/cascader/index.js +1 -2
  17. package/es/checkbox/index.js +1 -2
  18. package/es/col/index.js +1 -2
  19. package/es/collapse/index.js +1 -2
  20. package/es/columns/index.js +72 -30
  21. package/es/columns/style/index.js +1 -2
  22. package/es/comment/index.js +1 -2
  23. package/es/config-provider/config-provider.js +1 -2
  24. package/es/config-provider/index.js +1 -2
  25. package/es/date-picker/index.js +1 -2
  26. package/es/descriptions/index.js +1 -2
  27. package/es/development-login/LoginModal.js +89 -48
  28. package/es/development-login/index.js +17 -8
  29. package/es/divider/index.js +1 -2
  30. package/es/drawer/drawer.js +31 -22
  31. package/es/drawer/drawer.js.map +1 -1
  32. package/es/drawer/index.js +1 -2
  33. package/es/dropdown/index.js +1 -2
  34. package/es/ellipsis/Svg/CopySVG.js +63 -17
  35. package/es/ellipsis/Svg/TickSVG.js +41 -12
  36. package/es/ellipsis/index.js +111 -68
  37. package/es/empty/empty.js +65 -51
  38. package/es/empty/empty.stories.js +5 -6
  39. package/es/empty/index.js +1 -2
  40. package/es/exception/exception.js +32 -19
  41. package/es/exception/index.js +1 -2
  42. package/es/form/index.js +1 -2
  43. package/es/handle/index.js +120 -63
  44. package/es/handle/index.js.map +1 -1
  45. package/es/icon/index.js +1 -2
  46. package/es/icon-list/index.js +1 -120
  47. package/es/img/Contain.js +66 -39
  48. package/es/img/Cover.js +109 -72
  49. package/es/img/index.js +55 -32
  50. package/es/index.js +3 -2
  51. package/es/index.js.map +1 -1
  52. package/es/input/index.js +1 -2
  53. package/es/input-number/index.js +1 -2
  54. package/es/layout/index.js +1 -2
  55. package/es/list/index.js +1 -2
  56. package/es/loading-button/index.js +40 -28
  57. package/es/locale/default.js +5 -4
  58. package/es/locale/default.js.map +1 -1
  59. package/es/locale/en_US.js +31 -27
  60. package/es/locale/en_US.js.map +1 -1
  61. package/es/locale/index.js +1 -2
  62. package/es/locale/zh_CN.js +31 -27
  63. package/es/locale/zh_CN.js.map +1 -1
  64. package/es/locale-provider/index.js +1 -2
  65. package/es/mention/index.js +1 -2
  66. package/es/mentions/index.js +1 -2
  67. package/es/menu/index.js +1 -2
  68. package/es/message/index.js +1 -2
  69. package/es/modal/index.js +1 -2
  70. package/es/notification/index.js +2 -3
  71. package/es/notification/index.js.map +1 -1
  72. package/es/page/Box.js +58 -33
  73. package/es/page/index.js +139 -88
  74. package/es/page/utils.js +17 -14
  75. package/es/page-header/index.js +1 -2
  76. package/es/pagination/index.js +1 -2
  77. package/es/popconfirm/index.js +1 -2
  78. package/es/popover/index.js +1 -2
  79. package/es/prev-locale.js +52 -47
  80. package/es/progress/index.js +1 -2
  81. package/es/query-form/Field/Checkbox.js +24 -17
  82. package/es/query-form/Field/Select.js +62 -40
  83. package/es/query-form/Field/SelectInput.js +77 -45
  84. package/es/query-form/Field/fieldsMap.js +20 -20
  85. package/es/query-form/Field/index.js +113 -66
  86. package/es/query-form/createActions.js +54 -46
  87. package/es/query-form/index.js +359 -247
  88. package/es/query-form/useForm.js +3 -4
  89. package/es/query-list-scene/List.js +343 -258
  90. package/es/query-list-scene/QueryForm.js +141 -95
  91. package/es/query-list-scene/QueryListScene.js +31 -21
  92. package/es/query-list-scene/Title.js +6 -4
  93. package/es/query-list-scene/Toolbar.js +25 -15
  94. package/es/query-list-scene/createActions.js +63 -60
  95. package/es/query-list-scene/index.js +1 -2
  96. package/es/query-list-scene/index.less +1 -1
  97. package/es/query-list-scene/useActions.js +3 -4
  98. package/es/radio/index.js +1 -2
  99. package/es/rate/index.js +1 -2
  100. package/es/render-empty/index.js +1 -2
  101. package/es/render-empty/render-empty.js +21 -16
  102. package/es/result/index.js +1 -2
  103. package/es/row/index.js +1 -2
  104. package/es/select/index.js +1 -2
  105. package/es/skeleton/index.js +1 -2
  106. package/es/slider/index.js +1 -2
  107. package/es/spin/index.js +1 -2
  108. package/es/statistic/index.js +1 -2
  109. package/es/steps/index.js +1 -2
  110. package/es/steps/steps.js +59 -35
  111. package/es/svg-components/illustration-403.js +208 -58
  112. package/es/svg-components/illustration-404.js +292 -75
  113. package/es/svg-components/illustration-500.js +323 -83
  114. package/es/svg-components/illustration-empty.js +56 -15
  115. package/es/svg-components/illustration-failure.js +114 -36
  116. package/es/svg-components/illustration-no-access.js +116 -35
  117. package/es/svg-components/illustration-no-chart.js +136 -37
  118. package/es/svg-components/illustration-no-result.js +94 -32
  119. package/es/svg-components/illustration-offline.js +133 -43
  120. package/es/svg-components/illustration-success.js +139 -43
  121. package/es/svg-components/index.js +1 -2
  122. package/es/switch/index.js +1 -2
  123. package/es/table/assets/image-loading-background.js +47 -17
  124. package/es/table/assets/image-loading.js +28 -5
  125. package/es/table/constants.js +1 -2
  126. package/es/table/context.js +1 -2
  127. package/es/table/hooks/index.js +1 -2
  128. package/es/table/hooks/use-column-setting.js +14 -16
  129. package/es/table/index.js +1 -2
  130. package/es/table/table.js +76 -48
  131. package/es/table/table.stories.js +150 -139
  132. package/es/table/utils.js +21 -18
  133. package/es/tabs/index.js +1 -2
  134. package/es/tag/index.js +1 -2
  135. package/es/time-picker/index.js +1 -2
  136. package/es/timeline/index.js +1 -2
  137. package/es/title/index.js +38 -20
  138. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +9 -5
  139. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +1 -2
  140. package/es/tntd-cascader/AntdCascader/component/SizeContext.js +1 -2
  141. package/es/tntd-cascader/AntdCascader/component/context.js +9 -9
  142. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +24 -10
  143. package/es/tntd-cascader/AntdCascader/component/getIcons.js +81 -50
  144. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +22 -20
  145. package/es/tntd-cascader/AntdCascader/config/utils.js +19 -18
  146. package/es/tntd-cascader/AntdCascader/config/warning.js +14 -11
  147. package/es/tntd-cascader/AntdCascader/index.js +212 -119
  148. package/es/tntd-cascader/AntdCascader/interface.js +1 -2
  149. package/es/tntd-cascader/index.js +1 -2
  150. package/es/tntd-cascader/rc-cascader/Cascader.js +279 -235
  151. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +21 -11
  152. package/es/tntd-cascader/rc-cascader/OptionList/Column.js +185 -116
  153. package/es/tntd-cascader/rc-cascader/OptionList/index.js +197 -128
  154. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +24 -19
  155. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +173 -137
  156. package/es/tntd-cascader/rc-cascader/context.js +1 -2
  157. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +50 -37
  158. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +27 -24
  159. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +16 -17
  160. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +8 -8
  161. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +27 -23
  162. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +58 -41
  163. package/es/tntd-cascader/rc-cascader/index.js +1 -2
  164. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +37 -27
  165. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +32 -33
  166. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +33 -25
  167. package/es/tntd-icon/fonts/iconfont.js +41 -53
  168. package/es/tntd-icon/index.js +27 -17
  169. package/es/tntd-layout/ActionsContext.js +3 -4
  170. package/es/tntd-layout/AppList.js +149 -79
  171. package/es/tntd-layout/Application.js +46 -29
  172. package/es/tntd-layout/Avatar.js +84 -42
  173. package/es/tntd-layout/CompatibleLanguage.js +106 -56
  174. package/es/tntd-layout/EnterpriseLayout/Avatar.js +97 -47
  175. package/es/tntd-layout/EnterpriseLayout/Language.js +62 -34
  176. package/es/tntd-layout/EnterpriseLayout/Theme.js +49 -24
  177. package/es/tntd-layout/EnterpriseLayout/index.js +17 -9
  178. package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +244 -154
  179. package/es/tntd-layout/GlobalNavigation/index.js +90 -50
  180. package/es/tntd-layout/Header.js +59 -26
  181. package/es/tntd-layout/HeaderActions.js +87 -34
  182. package/es/tntd-layout/HeaderNavs.js +54 -35
  183. package/es/tntd-layout/HeaderTabs.js +197 -140
  184. package/es/tntd-layout/Iconfont.js +1 -2
  185. package/es/tntd-layout/Language.js +61 -33
  186. package/es/tntd-layout/Layout.js +181 -78
  187. package/es/tntd-layout/Logo.js +61 -42
  188. package/es/tntd-layout/OrgAppList.js +228 -142
  189. package/es/tntd-layout/SideMenu.js +268 -161
  190. package/es/tntd-layout/Theme.js +53 -29
  191. package/es/tntd-layout/createActions.js +28 -29
  192. package/es/tntd-layout/images/index.js +31 -32
  193. package/es/tntd-layout/index.js +100 -60
  194. package/es/tntd-layout/paaslayout/CompactSideMenu.js +124 -65
  195. package/es/tntd-layout/paaslayout/Header.js +37 -14
  196. package/es/tntd-layout/paaslayout/Logo.js +2 -3
  197. package/es/tntd-layout/paaslayout/SideMenu.js +124 -63
  198. package/es/tntd-layout/paaslayout/index.js +168 -79
  199. package/es/tntd-layout/storage.js +20 -13
  200. package/es/tntd-modal/index.js +79 -32
  201. package/es/tntd-second-page/index.js +55 -0
  202. package/es/tntd-second-page/index.js.map +1 -0
  203. package/es/tntd-second-page/index.less +105 -0
  204. package/es/tntd-select/DropDownWrap.js +77 -52
  205. package/es/tntd-select/index.js +612 -486
  206. package/es/tooltip/index.js +1 -2
  207. package/es/transfer/index.js +1 -2
  208. package/es/tree/index.js +1 -2
  209. package/es/tree-select/index.js +1 -2
  210. package/es/typography/index.js +1 -2
  211. package/es/upload/index.js +1 -2
  212. package/es/utils/checkAuth.js +25 -21
  213. package/es/utils/findMenuInfoByPath.js +36 -30
  214. package/es/utils/index.js +75 -60
  215. package/es/version/index.js +1 -2
  216. package/lib/affix/index.d.ts +3 -3
  217. package/lib/affix/index.js +29 -22
  218. package/lib/affix/index.js.map +1 -1
  219. package/lib/alert/index.d.ts +3 -3
  220. package/lib/alert/index.js +29 -22
  221. package/lib/alert/index.js.map +1 -1
  222. package/lib/anchor/index.d.ts +3 -3
  223. package/lib/anchor/index.js +29 -22
  224. package/lib/anchor/index.js.map +1 -1
  225. package/lib/array-input/icon.js +38 -11
  226. package/lib/array-input/index.js +304 -150
  227. package/lib/auth-context/index.js +13 -4
  228. package/lib/auto-complete/index.d.ts +3 -3
  229. package/lib/auto-complete/index.js +29 -22
  230. package/lib/auto-complete/index.js.map +1 -1
  231. package/lib/avatar/index.d.ts +3 -3
  232. package/lib/avatar/index.js +29 -22
  233. package/lib/avatar/index.js.map +1 -1
  234. package/lib/back-top/index.d.ts +3 -3
  235. package/lib/back-top/index.js +29 -22
  236. package/lib/back-top/index.js.map +1 -1
  237. package/lib/badge/index.d.ts +3 -3
  238. package/lib/badge/index.js +29 -22
  239. package/lib/badge/index.js.map +1 -1
  240. package/lib/breadcrumb/index.d.ts +3 -3
  241. package/lib/breadcrumb/index.js +29 -22
  242. package/lib/breadcrumb/index.js.map +1 -1
  243. package/lib/button/index.d.ts +3 -3
  244. package/lib/button/index.js +29 -22
  245. package/lib/button/index.js.map +1 -1
  246. package/lib/calendar/index.d.ts +3 -3
  247. package/lib/calendar/index.js +29 -22
  248. package/lib/calendar/index.js.map +1 -1
  249. package/lib/card/index.d.ts +3 -3
  250. package/lib/card/index.js +29 -22
  251. package/lib/card/index.js.map +1 -1
  252. package/lib/carousel/index.d.ts +3 -3
  253. package/lib/carousel/index.js +29 -22
  254. package/lib/carousel/index.js.map +1 -1
  255. package/lib/cascader/index.d.ts +3 -3
  256. package/lib/cascader/index.js +29 -22
  257. package/lib/cascader/index.js.map +1 -1
  258. package/lib/checkbox/index.d.ts +3 -3
  259. package/lib/checkbox/index.js +29 -22
  260. package/lib/checkbox/index.js.map +1 -1
  261. package/lib/col/index.d.ts +3 -3
  262. package/lib/col/index.js +29 -22
  263. package/lib/col/index.js.map +1 -1
  264. package/lib/collapse/index.d.ts +3 -3
  265. package/lib/collapse/index.js +31 -23
  266. package/lib/collapse/index.js.map +1 -1
  267. package/lib/columns/index.js +95 -41
  268. package/lib/columns/style/index.js +1 -2
  269. package/lib/comment/index.d.ts +3 -3
  270. package/lib/comment/index.js +29 -22
  271. package/lib/comment/index.js.map +1 -1
  272. package/lib/config-provider/config-provider.d.ts +1 -1
  273. package/lib/config-provider/config-provider.js +14 -8
  274. package/lib/config-provider/config-provider.js.map +1 -1
  275. package/lib/config-provider/index.d.ts +3 -3
  276. package/lib/config-provider/index.js +29 -22
  277. package/lib/config-provider/index.js.map +1 -1
  278. package/lib/date-picker/index.d.ts +3 -3
  279. package/lib/date-picker/index.js +29 -22
  280. package/lib/date-picker/index.js.map +1 -1
  281. package/lib/descriptions/index.d.ts +3 -3
  282. package/lib/descriptions/index.js +29 -22
  283. package/lib/descriptions/index.js.map +1 -1
  284. package/lib/development-login/LoginModal.js +136 -80
  285. package/lib/development-login/index.js +53 -35
  286. package/lib/divider/index.d.ts +3 -3
  287. package/lib/divider/index.js +29 -22
  288. package/lib/divider/index.js.map +1 -1
  289. package/lib/drawer/drawer.d.ts +3 -3
  290. package/lib/drawer/drawer.d.ts.map +1 -1
  291. package/lib/drawer/drawer.js +51 -32
  292. package/lib/drawer/drawer.js.map +1 -1
  293. package/lib/drawer/index.d.ts +2 -2
  294. package/lib/drawer/index.js +26 -20
  295. package/lib/drawer/index.js.map +1 -1
  296. package/lib/dropdown/index.d.ts +3 -3
  297. package/lib/dropdown/index.js +29 -22
  298. package/lib/dropdown/index.js.map +1 -1
  299. package/lib/ellipsis/Svg/CopySVG.js +74 -21
  300. package/lib/ellipsis/Svg/TickSVG.js +52 -16
  301. package/lib/ellipsis/index.js +159 -105
  302. package/lib/empty/empty.d.ts +2 -2
  303. package/lib/empty/empty.js +107 -76
  304. package/lib/empty/empty.js.map +1 -1
  305. package/lib/empty/empty.stories.js +37 -18
  306. package/lib/empty/index.d.ts +1 -1
  307. package/lib/empty/index.js +24 -19
  308. package/lib/empty/index.js.map +1 -1
  309. package/lib/exception/exception.js +53 -31
  310. package/lib/exception/exception.js.map +1 -1
  311. package/lib/exception/index.js +22 -18
  312. package/lib/form/index.d.ts +3 -3
  313. package/lib/form/index.js +29 -22
  314. package/lib/form/index.js.map +1 -1
  315. package/lib/handle/index.d.ts.map +1 -1
  316. package/lib/handle/index.js +164 -96
  317. package/lib/handle/index.js.map +1 -1
  318. package/lib/icon/index.d.ts +3 -3
  319. package/lib/icon/index.js +29 -22
  320. package/lib/icon/index.js.map +1 -1
  321. package/lib/icon-list/index.js +7 -121
  322. package/lib/img/Contain.js +80 -44
  323. package/lib/img/Cover.js +139 -78
  324. package/lib/img/index.js +92 -60
  325. package/lib/index.d.ts +2 -1
  326. package/lib/index.d.ts.map +1 -1
  327. package/lib/index.js +694 -180
  328. package/lib/index.js.map +1 -1
  329. package/lib/input/index.d.ts +3 -3
  330. package/lib/input/index.js +29 -22
  331. package/lib/input/index.js.map +1 -1
  332. package/lib/input-number/index.d.ts +3 -3
  333. package/lib/input-number/index.js +29 -22
  334. package/lib/input-number/index.js.map +1 -1
  335. package/lib/layout/index.d.ts +3 -3
  336. package/lib/layout/index.js +29 -22
  337. package/lib/layout/index.js.map +1 -1
  338. package/lib/list/index.d.ts +3 -3
  339. package/lib/list/index.js +29 -22
  340. package/lib/list/index.js.map +1 -1
  341. package/lib/loading-button/index.js +75 -55
  342. package/lib/locale/default.d.ts +3 -0
  343. package/lib/locale/default.d.ts.map +1 -1
  344. package/lib/locale/default.js +17 -10
  345. package/lib/locale/default.js.map +1 -1
  346. package/lib/locale/en_US.d.ts +3 -0
  347. package/lib/locale/en_US.d.ts.map +1 -1
  348. package/lib/locale/en_US.js +41 -32
  349. package/lib/locale/en_US.js.map +1 -1
  350. package/lib/locale/index.js +39 -18
  351. package/lib/locale/zh_CN.d.ts +3 -0
  352. package/lib/locale/zh_CN.d.ts.map +1 -1
  353. package/lib/locale/zh_CN.js +41 -32
  354. package/lib/locale/zh_CN.js.map +1 -1
  355. package/lib/locale-provider/index.d.ts +3 -3
  356. package/lib/locale-provider/index.js +29 -22
  357. package/lib/locale-provider/index.js.map +1 -1
  358. package/lib/mention/index.d.ts +3 -3
  359. package/lib/mention/index.js +29 -22
  360. package/lib/mention/index.js.map +1 -1
  361. package/lib/mentions/index.d.ts +3 -3
  362. package/lib/mentions/index.js +29 -22
  363. package/lib/mentions/index.js.map +1 -1
  364. package/lib/menu/index.d.ts +3 -3
  365. package/lib/menu/index.js +29 -22
  366. package/lib/menu/index.js.map +1 -1
  367. package/lib/message/index.d.ts +3 -3
  368. package/lib/message/index.js +30 -22
  369. package/lib/message/index.js.map +1 -1
  370. package/lib/modal/index.d.ts +3 -3
  371. package/lib/modal/index.js +30 -22
  372. package/lib/modal/index.js.map +1 -1
  373. package/lib/notification/index.d.ts +4 -4
  374. package/lib/notification/index.js +29 -22
  375. package/lib/notification/index.js.map +1 -1
  376. package/lib/page/Box.js +79 -40
  377. package/lib/page/index.js +180 -99
  378. package/lib/page/utils.js +29 -15
  379. package/lib/page-header/index.d.ts +3 -3
  380. package/lib/page-header/index.js +29 -22
  381. package/lib/page-header/index.js.map +1 -1
  382. package/lib/pagination/index.d.ts +3 -3
  383. package/lib/pagination/index.js +29 -22
  384. package/lib/pagination/index.js.map +1 -1
  385. package/lib/popconfirm/index.d.ts +3 -3
  386. package/lib/popconfirm/index.js +29 -22
  387. package/lib/popconfirm/index.js.map +1 -1
  388. package/lib/popover/index.d.ts +3 -3
  389. package/lib/popover/index.js +29 -22
  390. package/lib/popover/index.js.map +1 -1
  391. package/lib/prev-locale.js +76 -53
  392. package/lib/progress/index.d.ts +3 -3
  393. package/lib/progress/index.js +29 -22
  394. package/lib/progress/index.js.map +1 -1
  395. package/lib/query-form/Field/Checkbox.js +37 -22
  396. package/lib/query-form/Field/Select.js +97 -68
  397. package/lib/query-form/Field/SelectInput.js +110 -73
  398. package/lib/query-form/Field/fieldsMap.d.ts +2 -2
  399. package/lib/query-form/Field/fieldsMap.js +45 -32
  400. package/lib/query-form/Field/index.js +171 -95
  401. package/lib/query-form/createActions.js +60 -50
  402. package/lib/query-form/index.d.ts +1 -1
  403. package/lib/query-form/index.d.ts.map +1 -1
  404. package/lib/query-form/index.js +446 -286
  405. package/lib/query-form/useForm.js +15 -11
  406. package/lib/query-list-scene/List.d.ts +2 -2
  407. package/lib/query-list-scene/List.d.ts.map +1 -1
  408. package/lib/query-list-scene/List.js +414 -292
  409. package/lib/query-list-scene/QueryForm.js +191 -104
  410. package/lib/query-list-scene/QueryListScene.js +87 -31
  411. package/lib/query-list-scene/Title.js +19 -9
  412. package/lib/query-list-scene/Toolbar.js +38 -20
  413. package/lib/query-list-scene/createActions.d.ts +4 -4
  414. package/lib/query-list-scene/createActions.js +85 -64
  415. package/lib/query-list-scene/index.d.ts +4 -4
  416. package/lib/query-list-scene/index.js +38 -24
  417. package/lib/query-list-scene/index.less +1 -1
  418. package/lib/query-list-scene/useActions.d.ts +4 -4
  419. package/lib/query-list-scene/useActions.js +15 -11
  420. package/lib/radio/index.d.ts +3 -3
  421. package/lib/radio/index.js +29 -22
  422. package/lib/radio/index.js.map +1 -1
  423. package/lib/rate/index.d.ts +3 -3
  424. package/lib/rate/index.js +29 -22
  425. package/lib/rate/index.js.map +1 -1
  426. package/lib/render-empty/index.js +10 -4
  427. package/lib/render-empty/render-empty.js +36 -22
  428. package/lib/render-empty/render-empty.js.map +1 -1
  429. package/lib/result/index.d.ts +3 -3
  430. package/lib/result/index.js +29 -22
  431. package/lib/result/index.js.map +1 -1
  432. package/lib/row/index.d.ts +3 -3
  433. package/lib/row/index.js +29 -22
  434. package/lib/row/index.js.map +1 -1
  435. package/lib/select/index.d.ts +3 -3
  436. package/lib/select/index.js +29 -22
  437. package/lib/select/index.js.map +1 -1
  438. package/lib/skeleton/index.d.ts +3 -3
  439. package/lib/skeleton/index.js +29 -22
  440. package/lib/skeleton/index.js.map +1 -1
  441. package/lib/slider/index.d.ts +3 -3
  442. package/lib/slider/index.js +29 -22
  443. package/lib/slider/index.js.map +1 -1
  444. package/lib/spin/index.d.ts +3 -3
  445. package/lib/spin/index.js +29 -22
  446. package/lib/spin/index.js.map +1 -1
  447. package/lib/statistic/index.d.ts +3 -3
  448. package/lib/statistic/index.js +29 -22
  449. package/lib/statistic/index.js.map +1 -1
  450. package/lib/steps/index.d.ts +1 -1
  451. package/lib/steps/index.js +24 -19
  452. package/lib/steps/index.js.map +1 -1
  453. package/lib/steps/steps.d.ts +3 -3
  454. package/lib/steps/steps.js +89 -59
  455. package/lib/steps/steps.js.map +1 -1
  456. package/lib/svg-components/illustration-403.js +223 -84
  457. package/lib/svg-components/illustration-404.js +307 -101
  458. package/lib/svg-components/illustration-500.js +338 -109
  459. package/lib/svg-components/illustration-empty.js +71 -41
  460. package/lib/svg-components/illustration-failure.js +129 -62
  461. package/lib/svg-components/illustration-no-access.js +131 -61
  462. package/lib/svg-components/illustration-no-chart.js +151 -63
  463. package/lib/svg-components/illustration-no-result.js +109 -58
  464. package/lib/svg-components/illustration-offline.js +148 -69
  465. package/lib/svg-components/illustration-success.js +154 -69
  466. package/lib/svg-components/index.js +86 -26
  467. package/lib/switch/index.d.ts +3 -3
  468. package/lib/switch/index.js +29 -22
  469. package/lib/switch/index.js.map +1 -1
  470. package/lib/table/assets/image-loading-background.js +62 -43
  471. package/lib/table/assets/image-loading.js +43 -31
  472. package/lib/table/constants.js +6 -3
  473. package/lib/table/context.d.ts +1 -1
  474. package/lib/table/context.js +9 -4
  475. package/lib/table/context.js.map +1 -1
  476. package/lib/table/hooks/index.js +15 -16
  477. package/lib/table/hooks/use-column-setting.d.ts +1 -1
  478. package/lib/table/hooks/use-column-setting.js +45 -20
  479. package/lib/table/hooks/use-column-setting.js.map +1 -1
  480. package/lib/table/index.d.ts +1 -1
  481. package/lib/table/index.js +24 -19
  482. package/lib/table/index.js.map +1 -1
  483. package/lib/table/table.d.ts +3 -3
  484. package/lib/table/table.js +140 -89
  485. package/lib/table/table.js.map +1 -1
  486. package/lib/table/table.stories.js +191 -154
  487. package/lib/table/utils.d.ts +1 -1
  488. package/lib/table/utils.js +33 -25
  489. package/lib/table/utils.js.map +1 -1
  490. package/lib/tabs/index.d.ts +3 -3
  491. package/lib/tabs/index.js +29 -22
  492. package/lib/tabs/index.js.map +1 -1
  493. package/lib/tag/index.d.ts +3 -3
  494. package/lib/tag/index.js +29 -22
  495. package/lib/tag/index.js.map +1 -1
  496. package/lib/time-picker/index.d.ts +3 -3
  497. package/lib/time-picker/index.js +29 -22
  498. package/lib/time-picker/index.js.map +1 -1
  499. package/lib/timeline/index.d.ts +3 -3
  500. package/lib/timeline/index.js +29 -22
  501. package/lib/timeline/index.js.map +1 -1
  502. package/lib/title/index.js +55 -26
  503. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +25 -31
  504. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +14 -26
  505. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +14 -26
  506. package/lib/tntd-cascader/AntdCascader/component/context.js +24 -16
  507. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +44 -39
  508. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  509. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +99 -75
  510. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +40 -50
  511. package/lib/tntd-cascader/AntdCascader/config/utils.js +38 -27
  512. package/lib/tntd-cascader/AntdCascader/config/warning.js +28 -36
  513. package/lib/tntd-cascader/AntdCascader/index.js +269 -162
  514. package/lib/tntd-cascader/AntdCascader/interface.js +16 -6
  515. package/lib/tntd-cascader/img/no-data-s.png +0 -0
  516. package/lib/tntd-cascader/index.js +14 -8
  517. package/lib/tntd-cascader/rc-cascader/Cascader.js +390 -284
  518. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +40 -41
  519. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +226 -152
  520. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +267 -163
  521. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +55 -48
  522. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +229 -166
  523. package/lib/tntd-cascader/rc-cascader/context.js +16 -27
  524. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +79 -63
  525. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +49 -49
  526. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +34 -41
  527. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +21 -33
  528. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +42 -51
  529. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +90 -65
  530. package/lib/tntd-cascader/rc-cascader/index.js +12 -7
  531. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +60 -38
  532. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +50 -39
  533. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +43 -32
  534. package/lib/tntd-icon/fonts/iconfont.js +41 -53
  535. package/lib/tntd-icon/index.js +51 -25
  536. package/lib/tntd-layout/ActionsContext.js +11 -4
  537. package/lib/tntd-layout/AppList.js +245 -221
  538. package/lib/tntd-layout/Application.js +137 -111
  539. package/lib/tntd-layout/Avatar.js +154 -135
  540. package/lib/tntd-layout/CompatibleLanguage.js +201 -180
  541. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +173 -146
  542. package/lib/tntd-layout/EnterpriseLayout/Language.js +104 -90
  543. package/lib/tntd-layout/EnterpriseLayout/Theme.js +99 -102
  544. package/lib/tntd-layout/EnterpriseLayout/index.js +36 -17
  545. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +413 -277
  546. package/lib/tntd-layout/GlobalNavigation/index.js +159 -115
  547. package/lib/tntd-layout/Header.js +111 -136
  548. package/lib/tntd-layout/HeaderActions.js +134 -104
  549. package/lib/tntd-layout/HeaderNavs.js +117 -106
  550. package/lib/tntd-layout/HeaderTabs.js +286 -310
  551. package/lib/tntd-layout/Iconfont.js +16 -7
  552. package/lib/tntd-layout/Language.js +100 -76
  553. package/lib/tntd-layout/Layout.js +253 -171
  554. package/lib/tntd-layout/Logo.js +91 -139
  555. package/lib/tntd-layout/OrgAppList.js +301 -383
  556. package/lib/tntd-layout/SideMenu.js +331 -392
  557. package/lib/tntd-layout/Theme.js +127 -93
  558. package/lib/tntd-layout/createActions.js +50 -34
  559. package/lib/tntd-layout/images/avatar/empty.png +0 -0
  560. package/lib/tntd-layout/images/avatar/female1.png +0 -0
  561. package/lib/tntd-layout/images/avatar/female2.png +0 -0
  562. package/lib/tntd-layout/images/avatar/female3.png +0 -0
  563. package/lib/tntd-layout/images/avatar/female4.png +0 -0
  564. package/lib/tntd-layout/images/avatar/female5.png +0 -0
  565. package/lib/tntd-layout/images/avatar/female6.png +0 -0
  566. package/lib/tntd-layout/images/avatar/male1.png +0 -0
  567. package/lib/tntd-layout/images/avatar/male2.png +0 -0
  568. package/lib/tntd-layout/images/avatar/male3.png +0 -0
  569. package/lib/tntd-layout/images/avatar/male4.png +0 -0
  570. package/lib/tntd-layout/images/avatar/male5.png +0 -0
  571. package/lib/tntd-layout/images/avatar/male6.png +0 -0
  572. package/lib/tntd-layout/images/index.js +96 -66
  573. package/lib/tntd-layout/index.js +165 -95
  574. package/lib/tntd-layout/paaslayout/CompactSideMenu.js +178 -177
  575. package/lib/tntd-layout/paaslayout/Header.js +84 -79
  576. package/lib/tntd-layout/paaslayout/Logo.js +32 -30
  577. package/lib/tntd-layout/paaslayout/SideMenu.js +182 -147
  578. package/lib/tntd-layout/paaslayout/index.js +251 -141
  579. package/lib/tntd-layout/storage.js +88 -30
  580. package/lib/tntd-modal/index.js +117 -62
  581. package/lib/tntd-second-page/index.d.ts +17 -0
  582. package/lib/tntd-second-page/index.d.ts.map +1 -0
  583. package/lib/tntd-second-page/index.js +72 -0
  584. package/lib/tntd-second-page/index.js.map +1 -0
  585. package/lib/tntd-second-page/index.less +105 -0
  586. package/lib/tntd-select/DropDownWrap.js +123 -78
  587. package/lib/tntd-select/index.d.ts +1 -1
  588. package/lib/tntd-select/index.js +697 -520
  589. package/lib/tooltip/index.d.ts +3 -3
  590. package/lib/tooltip/index.js +29 -22
  591. package/lib/tooltip/index.js.map +1 -1
  592. package/lib/transfer/index.d.ts +3 -3
  593. package/lib/transfer/index.js +29 -22
  594. package/lib/transfer/index.js.map +1 -1
  595. package/lib/tree/index.d.ts +3 -3
  596. package/lib/tree/index.js +29 -22
  597. package/lib/tree/index.js.map +1 -1
  598. package/lib/tree-select/index.d.ts +3 -3
  599. package/lib/tree-select/index.js +29 -22
  600. package/lib/tree-select/index.js.map +1 -1
  601. package/lib/typography/index.d.ts +3 -3
  602. package/lib/typography/index.js +29 -22
  603. package/lib/typography/index.js.map +1 -1
  604. package/lib/upload/index.d.ts +3 -3
  605. package/lib/upload/index.js +29 -22
  606. package/lib/upload/index.js.map +1 -1
  607. package/lib/utils/checkAuth.js +40 -23
  608. package/lib/utils/findMenuInfoByPath.js +47 -34
  609. package/lib/utils/index.js +144 -79
  610. package/lib/version/index.d.ts +3 -3
  611. package/lib/version/index.js +29 -22
  612. package/lib/version/index.js.map +1 -1
  613. package/package.json +10 -5
@@ -1,510 +1,636 @@
1
- var __rest = (this && this.__rest) || function (s, e) {
2
- var t = {};
3
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
- t[p] = s[p];
5
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
- t[p[i]] = s[p[i]];
9
- }
10
- return t;
1
+ var __rest = this && this.__rest || function (s, e) {
2
+ var t = {};
3
+
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
5
+
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
8
+ }
9
+ return t;
11
10
  };
11
+
12
12
  import React, { PureComponent } from 'react';
13
13
  import Select from '../select';
14
14
  import Empty from '../empty';
15
- import DropDownWrap from './DropDownWrap';
16
- // 页面实际渲染的下拉菜单数量,实际为 2 * ITEM_ELEMENT_NUMBER
17
- const ITEM_ELEMENT_NUMBER = 30;
18
- // Select size 配置
15
+ import DropDownWrap from './DropDownWrap'; // 页面实际渲染的下拉菜单数量,实际为 2 * ITEM_ELEMENT_NUMBER
16
+
17
+ const ITEM_ELEMENT_NUMBER = 30; // Select size 配置
18
+
19
19
  const ITEM_HEIGHT_CFG = {
20
- small: 24,
21
- large: 40,
22
- default: 32,
20
+ small: 24,
21
+ large: 40,
22
+ default: 32
23
23
  };
24
24
  const ARROW_CODE = {
25
- 40: 'down',
26
- 38: 'up',
25
+ 40: 'down',
26
+ 38: 'up'
27
27
  };
28
28
  const DROPDOWN_HEIGHT = 224;
29
29
  const Option = Select.Option;
30
+
30
31
  class SuperSelect extends PureComponent {
31
- constructor(props) {
32
- super(props);
33
- Object.defineProperty(this, "turnChildren", {
34
- enumerable: true,
35
- configurable: true,
36
- writable: true,
37
- value: (children) => {
38
- if (!children)
39
- return [];
40
- let arr = [];
41
- if (children && children.props) {
42
- arr.push(children);
43
- }
44
- else {
45
- children.forEach((item) => {
46
- if (item) {
47
- if (item instanceof Array) {
48
- arr = arr.concat(item);
49
- }
50
- else {
51
- arr.push(item);
52
- }
53
- }
54
- });
55
- }
56
- return arr;
57
- }
58
- });
59
- Object.defineProperty(this, "formulaWidth", {
60
- enumerable: true,
61
- configurable: true,
62
- writable: true,
63
- value: () => {
64
- // 获取dom设置宽度
65
- const { children: arr2, dropdownMatchSelectWidth = true, maxWidth } = this.props;
66
- const selectDom = document.getElementById(this.id);
67
- const selectWidth = selectDom.clientWidth || selectDom.offsetWidth;
68
- let arr = [];
69
- let formulaMaxWidth = 10;
70
- if (!dropdownMatchSelectWidth) {
71
- formulaMaxWidth = maxWidth || 10;
72
- }
73
- if (!dropdownMatchSelectWidth && !maxWidth) {
74
- const children = this.turnChildren(arr2);
75
- for (let i = 0; i < children.length; i++) {
76
- const val = children[i].props.children;
77
- const textWidth = this.getTextPixelWith(val);
78
- arr.push(textWidth.toFixed(2));
79
- }
80
- if (arr.length > 0) {
81
- formulaMaxWidth = Math.max(...arr);
82
- }
83
- }
84
- this.setState({
85
- selectWidth,
86
- maxWidth: formulaMaxWidth,
87
- });
88
- }
89
- });
90
- // 获取单行文本的像素宽度
91
- Object.defineProperty(this, "getTextPixelWith", {
92
- enumerable: true,
93
- configurable: true,
94
- writable: true,
95
- value: (text, fontStyle = '14px') => {
96
- let canvas = document.createElement('canvas'); // 创建 canvas 画布
97
- let context = canvas.getContext('2d'); // 获取 canvas 绘图上下文环境
98
- context.font = fontStyle; // 设置字体样式,使用前设置好对应的 font 样式才能准确获取文字的像素长度
99
- let dimension = context.measureText(text); // 测量文字
100
- return dimension.width;
101
- }
102
- });
103
- Object.defineProperty(this, "getItemStyle", {
104
- enumerable: true,
105
- configurable: true,
106
- writable: true,
107
- value: (i) => ({
108
- position: 'absolute',
109
- top: this.ITEM_HEIGHT * i,
110
- width: '100%',
111
- height: this.ITEM_HEIGHT,
112
- })
113
- });
114
- Object.defineProperty(this, "addEvent", {
115
- enumerable: true,
116
- configurable: true,
117
- writable: true,
118
- value: () => {
119
- this.scrollEle = document.querySelector(`.${this.dropdownClassName}`);
120
- // 下拉菜单未展开时元素不存在
121
- if (!this.scrollEle)
122
- return;
123
- this.scrollEle.addEventListener('scroll', this.onScroll, false);
124
- this.inputEle = document.querySelector(`#${this.id}`);
125
- if (!this.inputEle)
126
- return;
127
- this.inputEle.addEventListener('keydown', this.onKeyDown, false);
128
- }
129
- });
130
- // 模拟 antd select 按下 上下箭头 键时滚动列表
131
- Object.defineProperty(this, "onKeyDown", {
132
- enumerable: true,
133
- configurable: true,
134
- writable: true,
135
- value: (e) => {
136
- const { keyCode } = e || {};
137
- setTimeout(() => {
138
- const activeItem = document.querySelector(`.${this.dropdownClassName} .ant-select-dropdown-menu-item-active`);
139
- if (!activeItem)
140
- return;
141
- const { offsetTop } = activeItem;
142
- const isUp = ARROW_CODE[keyCode] === 'up';
143
- const isDown = ARROW_CODE[keyCode] === 'down';
144
- // 在所有列表第一行按上键
145
- if (offsetTop - this.prevTop > DROPDOWN_HEIGHT && isUp) {
146
- this.scrollEle.scrollTo(0, this.allHeight - DROPDOWN_HEIGHT);
147
- this.prevTop = this.allHeight;
148
- return;
149
- }
150
- // 在所有列表中最后一行按下键
151
- if (this.prevTop > offsetTop + DROPDOWN_HEIGHT && isDown) {
152
- this.scrollEle.scrollTo(0, 0);
153
- this.prevTop = 0;
154
- return;
155
- }
156
- this.prevTop = offsetTop;
157
- // 向下滚动到下拉框最后一行时,向下滚动一行的高度
158
- if (offsetTop > this.scrollEle.scrollTop + DROPDOWN_HEIGHT - this.ITEM_HEIGHT + 10 &&
159
- isDown) {
160
- this.scrollEle.scrollTo(0, this.scrollTop + this.ITEM_HEIGHT);
161
- return;
162
- }
163
- // 向上滚动到下拉框第一一行时,向上滚动一行的高度
164
- if (offsetTop < this.scrollEle.scrollTop && isUp) {
165
- this.scrollEle.scrollTo(0, this.scrollTop - this.ITEM_HEIGHT);
166
- }
167
- }, 100);
168
- }
169
- });
170
- Object.defineProperty(this, "onScroll", {
171
- enumerable: true,
172
- configurable: true,
173
- writable: true,
174
- value: () => this.throttleByHeight(this.onScrollReal)
175
- });
176
- Object.defineProperty(this, "onScrollReal", {
177
- enumerable: true,
178
- configurable: true,
179
- writable: true,
180
- value: () => {
181
- this.allList = this.getUseChildrenList();
182
- const { startIndex, endIndex } = this.getStartAndEndIndex();
183
- this.prevScrollTop = this.scrollTop;
184
- // 重新渲染列表组件 Wrap
185
- const allHeight = this.allList.length * this.ITEM_HEIGHT || 100;
186
- this.wrap.reactList(allHeight, startIndex, endIndex);
187
- }
188
- });
189
- Object.defineProperty(this, "throttleByHeight", {
190
- enumerable: true,
191
- configurable: true,
192
- writable: true,
193
- value: () => {
194
- this.scrollTop = this.scrollEle.scrollTop;
195
- // 滚动的高度
196
- let delta = this.prevScrollTop - this.scrollTop;
197
- delta = delta < 0 ? 0 - delta : delta;
198
- delta > this.reactDelta && this.onScrollReal();
199
- }
200
- });
201
- // 列表可展示所有 children
202
- Object.defineProperty(this, "getUseChildrenList", {
203
- enumerable: true,
204
- configurable: true,
205
- writable: true,
206
- value: () => this.state.filterChildren || this.state.children
207
- });
208
- Object.defineProperty(this, "getStartAndEndIndex", {
209
- enumerable: true,
210
- configurable: true,
211
- writable: true,
212
- value: () => {
213
- // 滚动后显示在列表可视区中的第一个 item 的 index
214
- const showIndex = Number((this.scrollTop / this.ITEM_HEIGHT).toFixed(0));
215
- const startIndex = showIndex - ITEM_ELEMENT_NUMBER < 0 ? 0 : showIndex - ITEM_ELEMENT_NUMBER / 2;
216
- const endIndex = showIndex + ITEM_ELEMENT_NUMBER;
217
- return { startIndex, endIndex };
218
- }
219
- });
220
- // 须使用 setTimeout 确保在 dom 加载完成之后添加事件
221
- Object.defineProperty(this, "setSuperDrowDownMenu", {
222
- enumerable: true,
223
- configurable: true,
224
- writable: true,
225
- value: (visible) => {
226
- if (!visible)
227
- return;
228
- this.allList = this.getUseChildrenList();
229
- if (!this.eventTimer || !this.scrollEle) {
230
- this.eventTimer = setTimeout(() => this.addEvent(), 0);
231
- }
232
- else {
233
- const allHeight = this.allList.length * this.ITEM_HEIGHT || 100;
234
- // 下拉列表单独重新渲染
235
- const { startIndex, endIndex } = this.getStartAndEndIndex();
236
- setTimeout(() => {
237
- this.wrap && this.wrap.reactList(allHeight, startIndex, endIndex);
238
- }, 0);
239
- }
240
- }
241
- });
242
- Object.defineProperty(this, "onDropdownVisibleChange", {
243
- enumerable: true,
244
- configurable: true,
245
- writable: true,
246
- value: (visible) => {
247
- const { onDropdownVisibleChange } = this.props;
248
- onDropdownVisibleChange && onDropdownVisibleChange(visible);
249
- const { value, children } = this.state;
250
- // 关闭下拉框前清空筛选条件,防止下次打开任然显示筛选后的 options
251
- if (!visible) {
252
- // 定时器确保关闭后再设置 filterChildren,防止列表刷新闪烁
253
- setTimeout(() => {
254
- this.setState({ filterChildren: null });
255
- this.setDefaultScrollTop(value);
256
- }, 100);
257
- // this.removeEvent();
258
- }
259
- else {
260
- // this.addEvent();
261
- if (value) {
262
- // 如果已有 value, 设置默认滚动位置
263
- this.setDefaultScrollTop();
264
- // 设置下拉列表显示数据
265
- this.setSuperDrowDownMenu(visible);
266
- }
267
- else if (!value && value !== 0 && children && children.length > 0) {
268
- // 无数据时,下拉回归至第一个
269
- const val = children[0].props.value;
270
- this.setDefaultScrollTop(val);
271
- }
272
- }
273
- }
274
- });
275
- Object.defineProperty(this, "onDeselect", {
276
- enumerable: true,
277
- configurable: true,
278
- writable: true,
279
- value: (value) => {
280
- const { onDeselect } = this.props;
281
- onDeselect && onDeselect(value);
282
- }
283
- });
284
- // 在搜索重新计算下拉滚动条高度
285
- Object.defineProperty(this, "onChange", {
286
- enumerable: true,
287
- configurable: true,
288
- writable: true,
289
- value: (value, opt) => {
290
- const { showSearch, onChange, autoClearSearchValue, maxCount, mode } = this.props;
291
- if (showSearch || this.isMultiple) {
292
- // 搜索模式下选择后是否需要重置搜索状态
293
- if (autoClearSearchValue !== false) {
294
- this.setState({ filterChildren: null }, () => {
295
- // 搜索成功后重新设置列表的总高度
296
- this.setSuperDrowDownMenu(true);
297
- });
298
- }
299
- }
300
- if (mode === 'multiple') {
301
- if (value.length <= maxCount) {
302
- this.setState({ value });
303
- }
304
- }
305
- else {
306
- this.setState({ value });
307
- }
308
- onChange && onChange(value, opt);
309
- if (mode !== 'multiple') {
310
- this.select && this.select.blur();
311
- }
312
- }
313
- });
314
- Object.defineProperty(this, "onSearch", {
315
- enumerable: true,
316
- configurable: true,
317
- writable: true,
318
- value: (v) => {
319
- const { showSearch, onSearch, filterOption, children: arr } = this.props;
320
- let children = this.turnChildren(arr);
321
- if (showSearch && filterOption !== false) {
322
- // 须根据 filterOption(如有该自定义函数)手动 filter 搜索匹配的列表
323
- let filterChildren = null;
324
- if (typeof filterOption === 'function') {
325
- filterChildren = children.filter((item) => filterOption(v, item));
326
- }
327
- else if (filterOption === undefined) {
328
- filterChildren = children.filter((item) => this.filterOption(v, item));
329
- }
330
- // 搜索框有值,去除disabled=true的children
331
- let newFilterChild = [];
332
- filterChildren &&
333
- filterChildren.forEach((item, index) => {
334
- if (!item.props.disabled) {
335
- newFilterChild.push(item);
336
- }
337
- });
338
- filterChildren = newFilterChild;
339
- // 设置下拉列表显示数据
340
- this.setState({ filterChildren: v === '' ? null : filterChildren }, () => {
341
- setTimeout(() => {
342
- // 搜索后需要重置滚动位置到0,防止上次 scrollTop 位置无数据
343
- if (filterChildren) {
344
- this.scrollTop = 0;
345
- this.scrollEle.scrollTo(0, 0);
346
- }
347
- // 搜索成功后需要重新设置列表的总高度
348
- this.setSuperDrowDownMenu(true);
349
- }, 0);
350
- });
351
- }
352
- onSearch && onSearch(v);
353
- }
354
- });
355
- Object.defineProperty(this, "filterOption", {
356
- enumerable: true,
357
- configurable: true,
358
- writable: true,
359
- value: (v, option) => {
360
- // 自定义过滤对应的 option 属性配置
361
- const filterProps = this.props.optionFilterProp || 'value';
362
- return `${option.props[filterProps]}`.indexOf(v) >= 0;
363
- }
364
- });
365
- Object.defineProperty(this, "setDefaultScrollTop", {
366
- enumerable: true,
367
- configurable: true,
368
- writable: true,
369
- value: (data) => {
370
- const { value } = this.state;
371
- const { children: arr } = this.props;
372
- const children = this.turnChildren(arr);
373
- let val = data || data === 0 ? data : value;
374
- for (let i = 0; i < children.length; i++) {
375
- const item = children[i];
376
- const itemValue = item.props.value;
377
- if (itemValue === val || (Array.isArray(val) && val.includes(itemValue))) {
378
- const targetScrollTop = i * this.ITEM_HEIGHT;
379
- setTimeout(() => {
380
- if (!this.scrollEle) {
381
- this.addEvent();
382
- }
383
- this.scrollEle && this.scrollEle.scrollTo(0, targetScrollTop);
384
- }, 100);
385
- return;
386
- }
387
- }
388
- }
389
- });
390
- Object.defineProperty(this, "removeEvent", {
391
- enumerable: true,
392
- configurable: true,
393
- writable: true,
394
- value: () => {
395
- if (!this.scrollEle)
396
- return;
397
- this.scrollEle.removeEventListener('scroll', this.onScroll, false);
398
- if (!this.inputEle)
399
- return;
400
- this.inputEle.removeEventListener('keydown', this.onKeyDown, false);
32
+ constructor(props) {
33
+ super(props);
34
+ Object.defineProperty(this, "turnChildren", {
35
+ enumerable: true,
36
+ configurable: true,
37
+ writable: true,
38
+ value: children => {
39
+ if (!children) return [];
40
+ let arr = [];
41
+
42
+ if (children && children.props) {
43
+ arr.push(children);
44
+ } else {
45
+ children.forEach(item => {
46
+ if (item) {
47
+ if (item instanceof Array) {
48
+ arr = arr.concat(item);
49
+ } else {
50
+ arr.push(item);
51
+ }
401
52
  }
53
+ });
54
+ }
55
+
56
+ return arr;
57
+ }
58
+ });
59
+ Object.defineProperty(this, "formulaWidth", {
60
+ enumerable: true,
61
+ configurable: true,
62
+ writable: true,
63
+ value: () => {
64
+ // 获取dom设置宽度
65
+ const {
66
+ children: arr2,
67
+ dropdownMatchSelectWidth = true,
68
+ maxWidth
69
+ } = this.props;
70
+ const selectDom = document.getElementById(this.id);
71
+ const selectWidth = selectDom.clientWidth || selectDom.offsetWidth;
72
+ let arr = [];
73
+ let formulaMaxWidth = 10;
74
+
75
+ if (!dropdownMatchSelectWidth) {
76
+ formulaMaxWidth = maxWidth || 10;
77
+ }
78
+
79
+ if (!dropdownMatchSelectWidth && !maxWidth) {
80
+ const children = this.turnChildren(arr2);
81
+
82
+ for (let i = 0; i < children.length; i++) {
83
+ const val = children[i].props.children;
84
+ const textWidth = this.getTextPixelWith(val);
85
+ arr.push(textWidth.toFixed(2));
86
+ }
87
+
88
+ if (arr.length > 0) {
89
+ formulaMaxWidth = Math.max(...arr);
90
+ }
91
+ }
92
+
93
+ this.setState({
94
+ selectWidth,
95
+ maxWidth: formulaMaxWidth
402
96
  });
403
- const { mode, defaultValue, value, optionHeight, children: arr } = props;
404
- this.isMultiple = ['tags', 'multiple'].includes(mode);
405
- const children = this.turnChildren(arr);
406
- // 设置默认 value
407
- let defaultV = this.isMultiple ? [] : '';
408
- defaultV = value || defaultValue || defaultV;
409
- this.state = {
410
- children: children || [],
411
- filterChildren: null,
412
- value: defaultV,
413
- maxWidth: null,
414
- selectWidth: null,
415
- };
416
- // 下拉菜单项行高
417
- this.ITEM_HEIGHT = optionHeight || ITEM_HEIGHT_CFG[props.size || 'default'];
418
- // 可视区 dom 高度
419
- this.visibleDomHeight = this.ITEM_HEIGHT * ITEM_ELEMENT_NUMBER;
420
- // 滚动时重新渲染的 scrollTop 判断值,大于 reactDelta 则刷新下拉列表
421
- this.reactDelta = this.visibleDomHeight / 3;
422
- // 是否拖动滚动条快速滚动状态
423
- this.isStopReact = false;
424
- // 上一次滚动的 scrollTop 值
425
- this.prevScrollTop = 0;
426
- // 上一次按下方向键时 scrollTop
427
- this.prevTop = 0;
428
- this.scrollTop = 0;
429
- // className
430
- this.dropdownClassName = `dc${+new Date()}`;
431
- this.id = `sid${+new Date()}`;
432
- }
433
- componentDidMount() {
434
- // defaultOpens=true 时添加滚动事件
97
+ }
98
+ }); // 获取单行文本的像素宽度
99
+
100
+ Object.defineProperty(this, "getTextPixelWith", {
101
+ enumerable: true,
102
+ configurable: true,
103
+ writable: true,
104
+ value: (text, fontStyle = '14px') => {
105
+ let canvas = document.createElement('canvas'); // 创建 canvas 画布
106
+
107
+ let context = canvas.getContext('2d'); // 获取 canvas 绘图上下文环境
108
+
109
+ context.font = fontStyle; // 设置字体样式,使用前设置好对应的 font 样式才能准确获取文字的像素长度
110
+
111
+ let dimension = context.measureText(text); // 测量文字
112
+
113
+ return dimension.width;
114
+ }
115
+ });
116
+ Object.defineProperty(this, "getItemStyle", {
117
+ enumerable: true,
118
+ configurable: true,
119
+ writable: true,
120
+ value: i => ({
121
+ position: 'absolute',
122
+ top: this.ITEM_HEIGHT * i,
123
+ width: '100%',
124
+ height: this.ITEM_HEIGHT
125
+ })
126
+ });
127
+ Object.defineProperty(this, "addEvent", {
128
+ enumerable: true,
129
+ configurable: true,
130
+ writable: true,
131
+ value: () => {
132
+ this.scrollEle = document.querySelector(`.${this.dropdownClassName}`); // 下拉菜单未展开时元素不存在
133
+
134
+ if (!this.scrollEle) return;
135
+ this.scrollEle.addEventListener('scroll', this.onScroll, false);
136
+ this.inputEle = document.querySelector(`#${this.id}`);
137
+ if (!this.inputEle) return;
138
+ this.inputEle.addEventListener('keydown', this.onKeyDown, false);
139
+ }
140
+ }); // 模拟 antd select 按下 上下箭头 键时滚动列表
141
+
142
+ Object.defineProperty(this, "onKeyDown", {
143
+ enumerable: true,
144
+ configurable: true,
145
+ writable: true,
146
+ value: e => {
147
+ const {
148
+ keyCode
149
+ } = e || {};
435
150
  setTimeout(() => {
436
- this.addEvent();
437
- }, 500);
438
- const { children: arr } = this.props;
439
- const children = this.turnChildren(arr);
440
- // if (children && children.length > 0) {
441
- this.formulaWidth();
442
- // }
443
- }
444
- componentDidUpdate(prevProps) {
445
- const { mode, defaultValue, value, children } = this.props;
446
- let arr = this.turnChildren(children);
447
- if (prevProps.children !== children) {
448
- this.isMultiple = ['tags', 'multiple'].includes(mode);
151
+ const activeItem = document.querySelector(`.${this.dropdownClassName} .ant-select-dropdown-menu-item-active`);
152
+ if (!activeItem) return;
153
+ const {
154
+ offsetTop
155
+ } = activeItem;
156
+ const isUp = ARROW_CODE[keyCode] === 'up';
157
+ const isDown = ARROW_CODE[keyCode] === 'down'; // 在所有列表第一行按上键
158
+
159
+ if (offsetTop - this.prevTop > DROPDOWN_HEIGHT && isUp) {
160
+ this.scrollEle.scrollTo(0, this.allHeight - DROPDOWN_HEIGHT);
161
+ this.prevTop = this.allHeight;
162
+ return;
163
+ } // 在所有列表中最后一行按下键
164
+
165
+
166
+ if (this.prevTop > offsetTop + DROPDOWN_HEIGHT && isDown) {
167
+ this.scrollEle.scrollTo(0, 0);
168
+ this.prevTop = 0;
169
+ return;
170
+ }
171
+
172
+ this.prevTop = offsetTop; // 向下滚动到下拉框最后一行时,向下滚动一行的高度
173
+
174
+ if (offsetTop > this.scrollEle.scrollTop + DROPDOWN_HEIGHT - this.ITEM_HEIGHT + 10 && isDown) {
175
+ this.scrollEle.scrollTo(0, this.scrollTop + this.ITEM_HEIGHT);
176
+ return;
177
+ } // 向上滚动到下拉框第一一行时,向上滚动一行的高度
178
+
179
+
180
+ if (offsetTop < this.scrollEle.scrollTop && isUp) {
181
+ this.scrollEle.scrollTo(0, this.scrollTop - this.ITEM_HEIGHT);
182
+ }
183
+ }, 100);
184
+ }
185
+ });
186
+ Object.defineProperty(this, "onScroll", {
187
+ enumerable: true,
188
+ configurable: true,
189
+ writable: true,
190
+ value: () => this.throttleByHeight(this.onScrollReal)
191
+ });
192
+ Object.defineProperty(this, "onScrollReal", {
193
+ enumerable: true,
194
+ configurable: true,
195
+ writable: true,
196
+ value: () => {
197
+ this.allList = this.getUseChildrenList();
198
+ const {
199
+ startIndex,
200
+ endIndex
201
+ } = this.getStartAndEndIndex();
202
+ this.prevScrollTop = this.scrollTop; // 重新渲染列表组件 Wrap
203
+
204
+ const allHeight = this.allList.length * this.ITEM_HEIGHT || 100;
205
+ this.wrap.reactList(allHeight, startIndex, endIndex);
206
+ }
207
+ });
208
+ Object.defineProperty(this, "throttleByHeight", {
209
+ enumerable: true,
210
+ configurable: true,
211
+ writable: true,
212
+ value: () => {
213
+ this.scrollTop = this.scrollEle.scrollTop; // 滚动的高度
214
+
215
+ let delta = this.prevScrollTop - this.scrollTop;
216
+ delta = delta < 0 ? 0 - delta : delta;
217
+ delta > this.reactDelta && this.onScrollReal();
218
+ }
219
+ }); // 列表可展示所有 children
220
+
221
+ Object.defineProperty(this, "getUseChildrenList", {
222
+ enumerable: true,
223
+ configurable: true,
224
+ writable: true,
225
+ value: () => this.state.filterChildren || this.state.children
226
+ });
227
+ Object.defineProperty(this, "getStartAndEndIndex", {
228
+ enumerable: true,
229
+ configurable: true,
230
+ writable: true,
231
+ value: () => {
232
+ // 滚动后显示在列表可视区中的第一个 item 的 index
233
+ const showIndex = Number((this.scrollTop / this.ITEM_HEIGHT).toFixed(0));
234
+ const startIndex = showIndex - ITEM_ELEMENT_NUMBER < 0 ? 0 : showIndex - ITEM_ELEMENT_NUMBER / 2;
235
+ const endIndex = showIndex + ITEM_ELEMENT_NUMBER;
236
+ return {
237
+ startIndex,
238
+ endIndex
239
+ };
240
+ }
241
+ }); // 须使用 setTimeout 确保在 dom 加载完成之后添加事件
242
+
243
+ Object.defineProperty(this, "setSuperDrowDownMenu", {
244
+ enumerable: true,
245
+ configurable: true,
246
+ writable: true,
247
+ value: visible => {
248
+ if (!visible) return;
249
+ this.allList = this.getUseChildrenList();
250
+
251
+ if (!this.eventTimer || !this.scrollEle) {
252
+ this.eventTimer = setTimeout(() => this.addEvent(), 0);
253
+ } else {
254
+ const allHeight = this.allList.length * this.ITEM_HEIGHT || 100; // 下拉列表单独重新渲染
255
+
256
+ const {
257
+ startIndex,
258
+ endIndex
259
+ } = this.getStartAndEndIndex();
260
+ setTimeout(() => {
261
+ this.wrap && this.wrap.reactList(allHeight, startIndex, endIndex);
262
+ }, 0);
263
+ }
264
+ }
265
+ });
266
+ Object.defineProperty(this, "onDropdownVisibleChange", {
267
+ enumerable: true,
268
+ configurable: true,
269
+ writable: true,
270
+ value: visible => {
271
+ const {
272
+ onDropdownVisibleChange
273
+ } = this.props;
274
+ onDropdownVisibleChange && onDropdownVisibleChange(visible);
275
+ const {
276
+ value,
277
+ children
278
+ } = this.state; // 关闭下拉框前清空筛选条件,防止下次打开任然显示筛选后的 options
279
+
280
+ if (!visible) {
281
+ // 定时器确保关闭后再设置 filterChildren,防止列表刷新闪烁
282
+ setTimeout(() => {
449
283
  this.setState({
450
- children: arr || [],
451
- filterChildren: null,
284
+ filterChildren: null
452
285
  });
453
- if (arr && arr.length > 0) {
454
- this.formulaWidth();
455
- }
286
+ this.setDefaultScrollTop(value);
287
+ }, 100); // this.removeEvent();
288
+ } else {
289
+ // this.addEvent();
290
+ if (value) {
291
+ // 如果已有 value, 设置默认滚动位置
292
+ this.setDefaultScrollTop(); // 设置下拉列表显示数据
293
+
294
+ this.setSuperDrowDownMenu(visible);
295
+ } else if (!value && value !== 0 && children && children.length > 0) {
296
+ // 无数据时,下拉回归至第一个
297
+ const val = children[0].props.value;
298
+ this.setDefaultScrollTop(val);
299
+ }
456
300
  }
457
- if (prevProps.value !== value) {
458
- // 更新时设置默认 value
459
- let defaultV = this.isMultiple ? [] : '';
460
- defaultV = value || defaultValue || defaultV;
461
- this.setState({ value: defaultV });
301
+ }
302
+ });
303
+ Object.defineProperty(this, "onDeselect", {
304
+ enumerable: true,
305
+ configurable: true,
306
+ writable: true,
307
+ value: value => {
308
+ const {
309
+ onDeselect
310
+ } = this.props;
311
+ onDeselect && onDeselect(value);
312
+ }
313
+ }); // 在搜索重新计算下拉滚动条高度
314
+
315
+ Object.defineProperty(this, "onChange", {
316
+ enumerable: true,
317
+ configurable: true,
318
+ writable: true,
319
+ value: (value, opt) => {
320
+ const {
321
+ showSearch,
322
+ onChange,
323
+ autoClearSearchValue,
324
+ maxCount,
325
+ mode
326
+ } = this.props;
327
+
328
+ if (showSearch || this.isMultiple) {
329
+ // 搜索模式下选择后是否需要重置搜索状态
330
+ if (autoClearSearchValue !== false) {
331
+ this.setState({
332
+ filterChildren: null
333
+ }, () => {
334
+ // 搜索成功后重新设置列表的总高度
335
+ this.setSuperDrowDownMenu(true);
336
+ });
337
+ }
462
338
  }
463
- }
464
- componentWillUnmount() {
465
- this.removeEvent();
466
- }
467
- render() {
468
- const { maxWidth, selectWidth } = this.state;
469
- let _a = this.props, { dropdownStyle, optionLabelProp, dropdownClassName } = _a, props = __rest(_a, ["dropdownStyle", "optionLabelProp", "dropdownClassName"]);
470
- this.allList = this.getUseChildrenList();
471
- this.allHeight = this.allList.length * this.ITEM_HEIGHT || 100;
472
- const { startIndex, endIndex } = this.getStartAndEndIndex();
473
- let dynamicWidth = maxWidth;
474
- if (this.allList.length === 0 || maxWidth < selectWidth) {
475
- dynamicWidth = selectWidth;
339
+
340
+ if (mode === 'multiple') {
341
+ if (value.length <= maxCount) {
342
+ this.setState({
343
+ value
344
+ });
345
+ }
346
+ } else {
347
+ this.setState({
348
+ value
349
+ });
350
+ }
351
+
352
+ onChange && onChange(value, opt);
353
+
354
+ if (mode !== 'multiple') {
355
+ this.select && this.select.blur();
476
356
  }
477
- dropdownStyle = Object.assign(Object.assign({ maxHeight: `${DROPDOWN_HEIGHT}px` }, dropdownStyle), { overflow: 'auto', position: 'relative', maxWidth: dynamicWidth });
478
- const { value } = this.state;
479
- // 判断处于 antd Form 中时不自动设置 value
480
- const _props = Object.assign({}, props);
481
- // 先删除 value,再手动赋值,防止空 value 影响 placeholder
482
- delete _props.value;
483
- // value 为空字符会隐藏 placeholder,改为 undefined
484
- if (typeof value === 'string' && !value) {
485
- _props.value = undefined;
357
+ }
358
+ });
359
+ Object.defineProperty(this, "onSearch", {
360
+ enumerable: true,
361
+ configurable: true,
362
+ writable: true,
363
+ value: v => {
364
+ const {
365
+ showSearch,
366
+ onSearch,
367
+ filterOption,
368
+ children: arr
369
+ } = this.props;
370
+ let children = this.turnChildren(arr);
371
+
372
+ if (showSearch && filterOption !== false) {
373
+ // 须根据 filterOption(如有该自定义函数)手动 filter 搜索匹配的列表
374
+ let filterChildren = null;
375
+
376
+ if (typeof filterOption === 'function') {
377
+ filterChildren = children.filter(item => filterOption(v, item));
378
+ } else if (filterOption === undefined) {
379
+ filterChildren = children.filter(item => this.filterOption(v, item));
380
+ } // 搜索框有值,去除disabled=true的children
381
+
382
+
383
+ let newFilterChild = [];
384
+ filterChildren && filterChildren.forEach((item, index) => {
385
+ if (!item.props.disabled) {
386
+ newFilterChild.push(item);
387
+ }
388
+ });
389
+ filterChildren = newFilterChild; // 设置下拉列表显示数据
390
+
391
+ this.setState({
392
+ filterChildren: v === '' ? null : filterChildren
393
+ }, () => {
394
+ setTimeout(() => {
395
+ // 搜索后需要重置滚动位置到0,防止上次 scrollTop 位置无数据
396
+ if (filterChildren) {
397
+ this.scrollTop = 0;
398
+ this.scrollEle.scrollTo(0, 0);
399
+ } // 搜索成功后需要重新设置列表的总高度
400
+
401
+
402
+ this.setSuperDrowDownMenu(true);
403
+ }, 0);
404
+ });
486
405
  }
487
- else {
488
- _props.value = value;
406
+
407
+ onSearch && onSearch(v);
408
+ }
409
+ });
410
+ Object.defineProperty(this, "filterOption", {
411
+ enumerable: true,
412
+ configurable: true,
413
+ writable: true,
414
+ value: (v, option) => {
415
+ // 自定义过滤对应的 option 属性配置
416
+ const filterProps = this.props.optionFilterProp || 'value';
417
+ return `${option.props[filterProps]}`.indexOf(v) >= 0;
418
+ }
419
+ });
420
+ Object.defineProperty(this, "setDefaultScrollTop", {
421
+ enumerable: true,
422
+ configurable: true,
423
+ writable: true,
424
+ value: data => {
425
+ const {
426
+ value
427
+ } = this.state;
428
+ const {
429
+ children: arr
430
+ } = this.props;
431
+ const children = this.turnChildren(arr);
432
+ let val = data || data === 0 ? data : value;
433
+
434
+ for (let i = 0; i < children.length; i++) {
435
+ const item = children[i];
436
+ const itemValue = item.props.value;
437
+
438
+ if (itemValue === val || Array.isArray(val) && val.includes(itemValue)) {
439
+ const targetScrollTop = i * this.ITEM_HEIGHT;
440
+ setTimeout(() => {
441
+ if (!this.scrollEle) {
442
+ this.addEvent();
443
+ }
444
+
445
+ this.scrollEle && this.scrollEle.scrollTo(0, targetScrollTop);
446
+ }, 100);
447
+ return;
448
+ }
489
449
  }
490
- optionLabelProp = optionLabelProp || 'children';
491
- return (React.createElement(Select, Object.assign({}, _props, { id: this.id, onSearch: this.onSearch, onChange: this.onChange, dropdownClassName: `${this.dropdownClassName} ${dropdownClassName || ''}`, optionLabelProp: optionLabelProp, dropdownStyle: dropdownStyle, onDropdownVisibleChange: this.onDropdownVisibleChange, onDeselect: this.onDeselect, ref: (ele) => (this.select = ele), dropdownRender: (menu, props) => {
492
- if (this.allList.length === 0) {
493
- return (React.createElement("div", { style: { padding: '5px 12px' } },
494
- React.createElement(Empty, { image: Empty.PRESENTED_IMAGE_SIMPLE })));
495
- }
496
- return (React.createElement(DropDownWrap, Object.assign({}, {
497
- startIndex,
498
- endIndex,
499
- allHeight: this.allHeight,
500
- menu,
501
- itemHeight: this.ITEM_HEIGHT,
502
- }, { ref: (ele) => {
503
- this.wrap = ele;
504
- } })));
505
- } }), this.allList));
450
+ }
451
+ });
452
+ Object.defineProperty(this, "removeEvent", {
453
+ enumerable: true,
454
+ configurable: true,
455
+ writable: true,
456
+ value: () => {
457
+ if (!this.scrollEle) return;
458
+ this.scrollEle.removeEventListener('scroll', this.onScroll, false);
459
+ if (!this.inputEle) return;
460
+ this.inputEle.removeEventListener('keydown', this.onKeyDown, false);
461
+ }
462
+ });
463
+ const {
464
+ mode,
465
+ defaultValue,
466
+ value,
467
+ optionHeight,
468
+ children: arr
469
+ } = props;
470
+ this.isMultiple = ['tags', 'multiple'].includes(mode);
471
+ const children = this.turnChildren(arr); // 设置默认 value
472
+
473
+ let defaultV = this.isMultiple ? [] : '';
474
+ defaultV = value || defaultValue || defaultV;
475
+ this.state = {
476
+ children: children || [],
477
+ filterChildren: null,
478
+ value: defaultV,
479
+ maxWidth: null,
480
+ selectWidth: null
481
+ }; // 下拉菜单项行高
482
+
483
+ this.ITEM_HEIGHT = optionHeight || ITEM_HEIGHT_CFG[props.size || 'default']; // 可视区 dom 高度
484
+
485
+ this.visibleDomHeight = this.ITEM_HEIGHT * ITEM_ELEMENT_NUMBER; // 滚动时重新渲染的 scrollTop 判断值,大于 reactDelta 则刷新下拉列表
486
+
487
+ this.reactDelta = this.visibleDomHeight / 3; // 是否拖动滚动条快速滚动状态
488
+
489
+ this.isStopReact = false; // 上一次滚动的 scrollTop 值
490
+
491
+ this.prevScrollTop = 0; // 上一次按下方向键时 scrollTop 值
492
+
493
+ this.prevTop = 0;
494
+ this.scrollTop = 0; // className
495
+
496
+ this.dropdownClassName = `dc${+new Date()}`;
497
+ this.id = `sid${+new Date()}`;
498
+ }
499
+
500
+ componentDidMount() {
501
+ // defaultOpens=true 时添加滚动事件
502
+ setTimeout(() => {
503
+ this.addEvent();
504
+ }, 500);
505
+ const {
506
+ children: arr
507
+ } = this.props;
508
+ const children = this.turnChildren(arr); // if (children && children.length > 0) {
509
+
510
+ this.formulaWidth(); // }
511
+ }
512
+
513
+ componentDidUpdate(prevProps) {
514
+ const {
515
+ mode,
516
+ defaultValue,
517
+ value,
518
+ children
519
+ } = this.props;
520
+ let arr = this.turnChildren(children);
521
+
522
+ if (prevProps.children !== children) {
523
+ this.isMultiple = ['tags', 'multiple'].includes(mode);
524
+ this.setState({
525
+ children: arr || [],
526
+ filterChildren: null
527
+ });
528
+
529
+ if (arr && arr.length > 0) {
530
+ this.formulaWidth();
531
+ }
532
+ }
533
+
534
+ if (prevProps.value !== value) {
535
+ // 更新时设置默认 value
536
+ let defaultV = this.isMultiple ? [] : '';
537
+ defaultV = value || defaultValue || defaultV;
538
+ this.setState({
539
+ value: defaultV
540
+ });
506
541
  }
542
+ }
543
+
544
+ componentWillUnmount() {
545
+ this.removeEvent();
546
+ }
547
+
548
+ render() {
549
+ const {
550
+ maxWidth,
551
+ selectWidth
552
+ } = this.state;
553
+
554
+ let _a = this.props,
555
+ {
556
+ dropdownStyle,
557
+ optionLabelProp,
558
+ dropdownClassName
559
+ } = _a,
560
+ props = __rest(_a, ["dropdownStyle", "optionLabelProp", "dropdownClassName"]);
561
+
562
+ this.allList = this.getUseChildrenList();
563
+ this.allHeight = this.allList.length * this.ITEM_HEIGHT || 100;
564
+ const {
565
+ startIndex,
566
+ endIndex
567
+ } = this.getStartAndEndIndex();
568
+ let dynamicWidth = maxWidth;
569
+
570
+ if (this.allList.length === 0 || maxWidth < selectWidth) {
571
+ dynamicWidth = selectWidth;
572
+ }
573
+
574
+ dropdownStyle = Object.assign(Object.assign({
575
+ maxHeight: `${DROPDOWN_HEIGHT}px`
576
+ }, dropdownStyle), {
577
+ overflow: 'auto',
578
+ position: 'relative',
579
+ maxWidth: dynamicWidth
580
+ });
581
+ const {
582
+ value
583
+ } = this.state; // 判断处于 antd Form 中时不自动设置 value
584
+
585
+ const _props = Object.assign({}, props); // 先删除 value,再手动赋值,防止空 value 影响 placeholder
586
+
587
+
588
+ delete _props.value; // value 为空字符会隐藏 placeholder,改为 undefined
589
+
590
+ if (typeof value === 'string' && !value) {
591
+ _props.value = undefined;
592
+ } else {
593
+ _props.value = value;
594
+ }
595
+
596
+ optionLabelProp = optionLabelProp || 'children';
597
+ return React.createElement(Select, Object.assign({}, _props, {
598
+ id: this.id,
599
+ onSearch: this.onSearch,
600
+ onChange: this.onChange,
601
+ dropdownClassName: `${this.dropdownClassName} ${dropdownClassName || ''}`,
602
+ optionLabelProp: optionLabelProp,
603
+ dropdownStyle: dropdownStyle,
604
+ onDropdownVisibleChange: this.onDropdownVisibleChange,
605
+ onDeselect: this.onDeselect,
606
+ ref: ele => this.select = ele,
607
+ dropdownRender: (menu, props) => {
608
+ if (this.allList.length === 0) {
609
+ return React.createElement("div", {
610
+ style: {
611
+ padding: '5px 12px'
612
+ }
613
+ }, React.createElement(Empty, {
614
+ image: Empty.PRESENTED_IMAGE_SIMPLE
615
+ }));
616
+ }
617
+
618
+ return React.createElement(DropDownWrap, Object.assign({}, {
619
+ startIndex,
620
+ endIndex,
621
+ allHeight: this.allHeight,
622
+ menu,
623
+ itemHeight: this.ITEM_HEIGHT
624
+ }, {
625
+ ref: ele => {
626
+ this.wrap = ele;
627
+ }
628
+ }));
629
+ }
630
+ }), this.allList);
631
+ }
632
+
507
633
  }
634
+
508
635
  SuperSelect.Option = Option;
509
- export default SuperSelect;
510
- //# sourceMappingURL=index.js.map
636
+ export default SuperSelect;