tntd 2.1.1 → 2.1.2

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 (804) hide show
  1. package/es/affix/index.js +2 -1
  2. package/es/alert/index.js +2 -1
  3. package/es/anchor/index.js +2 -1
  4. package/es/array-input/icon.js +6 -24
  5. package/es/array-input/index.js +119 -203
  6. package/es/auth-context/index.js +2 -1
  7. package/es/auto-complete/index.js +2 -1
  8. package/es/avatar/index.js +2 -1
  9. package/es/back-top/index.js +2 -1
  10. package/es/badge/index.js +2 -1
  11. package/es/breadcrumb/index.js +2 -1
  12. package/es/button/index.js +2 -1
  13. package/es/calendar/index.js +2 -1
  14. package/es/card/index.js +2 -1
  15. package/es/carousel/index.js +2 -1
  16. package/es/cascader/index.js +2 -1
  17. package/es/checkbox/index.js +2 -1
  18. package/es/col/index.js +2 -1
  19. package/es/collapse/index.js +2 -1
  20. package/es/color-picker/ColorPicker.js +90 -0
  21. package/es/color-picker/ColorPicker.js.map +1 -0
  22. package/es/color-picker/index.js +11 -0
  23. package/es/color-picker/index.js.map +1 -0
  24. package/es/color-picker/index.less +234 -0
  25. package/es/color-picker/tip.svg +23 -0
  26. package/es/columns/index.js +30 -66
  27. package/es/columns/style/index.js +2 -1
  28. package/es/comment/index.js +2 -1
  29. package/es/config-provider/config-provider.js +2 -1
  30. package/es/config-provider/index.js +2 -1
  31. package/es/date-picker/index.js +2 -1
  32. package/es/descriptions/descriptions.js +30 -38
  33. package/es/descriptions/index.js +2 -1
  34. package/es/development-login/LoginModal.js +46 -81
  35. package/es/development-login/index.js +8 -17
  36. package/es/divider/index.js +2 -1
  37. package/es/drawer/drawer.js +20 -27
  38. package/es/drawer/index.js +2 -1
  39. package/es/dropdown/index.js +2 -1
  40. package/es/ellipsis/Svg/CopySVG.js +16 -63
  41. package/es/ellipsis/Svg/CopySVG.js.map +1 -1
  42. package/es/ellipsis/Svg/TickSVG.js +11 -41
  43. package/es/ellipsis/Svg/TickSVG.js.map +1 -1
  44. package/es/ellipsis/index.js +78 -100
  45. package/es/ellipsis/index.js.map +1 -1
  46. package/es/ellipsis/index.less +1 -1
  47. package/es/empty/empty.js +48 -58
  48. package/es/empty/empty.stories.js +6 -5
  49. package/es/empty/index.js +2 -1
  50. package/es/exception/exception.js +19 -32
  51. package/es/exception/index.js +2 -1
  52. package/es/form/index.js +2 -1
  53. package/es/handle/index.js +71 -110
  54. package/es/icon/index.js +2 -1
  55. package/es/icon-list/index.js +120 -1
  56. package/es/img/Contain.js +39 -60
  57. package/es/img/Cover.js +72 -98
  58. package/es/img/index.js +32 -48
  59. package/es/index.js +3 -1
  60. package/es/index.js.map +1 -1
  61. package/es/input/index.js +2 -1
  62. package/es/input-number/index.js +2 -1
  63. package/es/layout/index.js +2 -1
  64. package/es/list/index.js +2 -1
  65. package/es/loading-button/index.js +28 -33
  66. package/es/locale/default.js +4 -3
  67. package/es/locale/en_US.js +31 -29
  68. package/es/locale/en_US.js.map +1 -1
  69. package/es/locale/index.js +2 -1
  70. package/es/locale/zh_CN.js +31 -29
  71. package/es/locale/zh_CN.js.map +1 -1
  72. package/es/locale-provider/index.js +3 -2
  73. package/es/mention/index.js +2 -1
  74. package/es/mentions/index.js +2 -1
  75. package/es/menu/index.js +2 -1
  76. package/es/message/index.js +2 -1
  77. package/es/modal/index.js +2 -1
  78. package/es/modal/modal.js +17 -20
  79. package/es/notification/index.js +2 -1
  80. package/es/page/Box.js +33 -49
  81. package/es/page/index.js +84 -123
  82. package/es/page/index.js.map +1 -1
  83. package/es/page/utils.js +14 -12
  84. package/es/page-header/index.js +2 -1
  85. package/es/pagination/index.js +2 -1
  86. package/es/popconfirm/index.js +2 -1
  87. package/es/popover/index.js +2 -1
  88. package/es/prev-locale.js +47 -49
  89. package/es/progress/index.js +2 -1
  90. package/es/query-form/Field/Checkbox.js +17 -20
  91. package/es/query-form/Field/Select.js +39 -54
  92. package/es/query-form/Field/SelectInput.js +45 -63
  93. package/es/query-form/Field/fieldsMap.js +20 -19
  94. package/es/query-form/Field/index.js +66 -104
  95. package/es/query-form/createActions.js +46 -46
  96. package/es/query-form/index.js +247 -327
  97. package/es/query-form/useForm.js +4 -3
  98. package/es/query-list-scene/List.js +255 -321
  99. package/es/query-list-scene/List.js.map +1 -1
  100. package/es/query-list-scene/QueryForm.js +94 -132
  101. package/es/query-list-scene/QueryListScene.js +21 -29
  102. package/es/query-list-scene/Title.js +4 -6
  103. package/es/query-list-scene/Toolbar.js +15 -21
  104. package/es/query-list-scene/createActions.js +60 -60
  105. package/es/query-list-scene/index.js +2 -1
  106. package/es/query-list-scene/useActions.js +4 -3
  107. package/es/radio/index.js +2 -1
  108. package/es/rate/index.js +2 -1
  109. package/es/render-empty/index.js +2 -1
  110. package/es/render-empty/render-empty.js +16 -19
  111. package/es/result/index.js +2 -1
  112. package/es/row/index.js +2 -1
  113. package/es/select/index.js +2 -1
  114. package/es/skeleton/index.js +2 -1
  115. package/es/slider/index.js +2 -1
  116. package/es/spin/index.js +2 -1
  117. package/es/statistic/index.js +2 -1
  118. package/es/steps/index.js +2 -1
  119. package/es/steps/steps.js +35 -51
  120. package/es/svg-components/illustration-403.js +58 -206
  121. package/es/svg-components/illustration-404.js +75 -290
  122. package/es/svg-components/illustration-500.js +83 -321
  123. package/es/svg-components/illustration-empty.js +15 -54
  124. package/es/svg-components/illustration-failure.js +36 -112
  125. package/es/svg-components/illustration-no-access.js +35 -114
  126. package/es/svg-components/illustration-no-chart.js +37 -134
  127. package/es/svg-components/illustration-no-result.js +32 -92
  128. package/es/svg-components/illustration-offline.js +43 -131
  129. package/es/svg-components/illustration-success.js +43 -137
  130. package/es/svg-components/index.js +2 -1
  131. package/es/switch/index.js +2 -1
  132. package/es/table/assets/image-loading-background.js +17 -45
  133. package/es/table/assets/image-loading.js +5 -26
  134. package/es/table/constants.js +2 -1
  135. package/es/table/context.js +2 -1
  136. package/es/table/hooks/index.js +2 -1
  137. package/es/table/hooks/use-column-setting.js +16 -13
  138. package/es/table/index.js +2 -1
  139. package/es/table/table.js +53 -76
  140. package/es/table/table.stories.js +139 -148
  141. package/es/table/utils.js +18 -17
  142. package/es/tabs/index.js +2 -1
  143. package/es/tag/index.js +123 -2
  144. package/es/tag/index.js.map +1 -1
  145. package/es/tag/tag.less +61 -0
  146. package/es/time-picker/index.js +2 -1
  147. package/es/timeline/index.js +2 -1
  148. package/es/title/index.js +20 -34
  149. package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +5 -9
  150. package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +2 -1
  151. package/es/tntd-cascader/AntdCascader/component/SizeContext.js +2 -1
  152. package/es/tntd-cascader/AntdCascader/component/context.js +7 -5
  153. package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +10 -22
  154. package/es/tntd-cascader/AntdCascader/component/getIcons.js +50 -72
  155. package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +20 -22
  156. package/es/tntd-cascader/AntdCascader/config/utils.js +18 -17
  157. package/es/tntd-cascader/AntdCascader/config/warning.js +10 -9
  158. package/es/tntd-cascader/AntdCascader/index.js +118 -189
  159. package/es/tntd-cascader/AntdCascader/interface.js +2 -1
  160. package/es/tntd-cascader/index.js +2 -1
  161. package/es/tntd-cascader/rc-cascader/Cascader.js +239 -256
  162. package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +11 -21
  163. package/es/tntd-cascader/rc-cascader/OptionList/Column.js +116 -175
  164. package/es/tntd-cascader/rc-cascader/OptionList/index.js +128 -180
  165. package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +19 -22
  166. package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +137 -144
  167. package/es/tntd-cascader/rc-cascader/context.js +2 -1
  168. package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +37 -44
  169. package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +24 -25
  170. package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +17 -15
  171. package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +8 -7
  172. package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +21 -20
  173. package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +41 -51
  174. package/es/tntd-cascader/rc-cascader/index.js +2 -1
  175. package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +27 -33
  176. package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +32 -29
  177. package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +23 -26
  178. package/es/tntd-form/TntdForm/components/Item.js +30 -42
  179. package/es/tntd-form/TntdForm/components/ItemComp.js +158 -167
  180. package/es/tntd-form/TntdForm/components/List.js +78 -89
  181. package/es/tntd-form/TntdForm/index.js +33 -38
  182. package/es/tntd-form/TntdForm/interface.js +2 -1
  183. package/es/tntd-form/TntdForm/store.js +2 -1
  184. package/es/tntd-form/TntdForm/utils.js +168 -158
  185. package/es/tntd-form/index.js +2 -1
  186. package/es/tntd-icon/fonts/iconfont.js +53 -36
  187. package/es/tntd-icon/index.js +17 -23
  188. package/es/tntd-layout/ActionsContext.js +2 -1
  189. package/es/tntd-layout/AppList.js +77 -135
  190. package/es/tntd-layout/Application.js +29 -42
  191. package/es/tntd-layout/Avatar.js +42 -80
  192. package/es/tntd-layout/CompatibleLanguage.js +56 -93
  193. package/es/tntd-layout/EnterpriseLayout/Avatar.js +47 -93
  194. package/es/tntd-layout/EnterpriseLayout/Language.js +34 -56
  195. package/es/tntd-layout/EnterpriseLayout/Theme.js +24 -45
  196. package/es/tntd-layout/EnterpriseLayout/index.js +9 -17
  197. package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +153 -213
  198. package/es/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
  199. package/es/tntd-layout/GlobalNavigation/index.js +50 -84
  200. package/es/tntd-layout/Header.js +26 -59
  201. package/es/tntd-layout/HeaderActions.js +34 -83
  202. package/es/tntd-layout/HeaderNavs.js +35 -46
  203. package/es/tntd-layout/HeaderTabs.js +140 -176
  204. package/es/tntd-layout/Iconfont.js +2 -1
  205. package/es/tntd-layout/Language.js +33 -55
  206. package/es/tntd-layout/Layout.js +78 -176
  207. package/es/tntd-layout/Logo.js +40 -52
  208. package/es/tntd-layout/OrgAppList.js +139 -208
  209. package/es/tntd-layout/SideMenu.js +160 -230
  210. package/es/tntd-layout/Theme.js +29 -47
  211. package/es/tntd-layout/createActions.js +29 -28
  212. package/es/tntd-layout/images/index.js +32 -31
  213. package/es/tntd-layout/index.js +60 -92
  214. package/es/tntd-layout/paaslayout/CompactSideMenu.js +65 -109
  215. package/es/tntd-layout/paaslayout/Header.js +14 -37
  216. package/es/tntd-layout/paaslayout/Logo.js +3 -2
  217. package/es/tntd-layout/paaslayout/SideMenu.js +63 -109
  218. package/es/tntd-layout/paaslayout/index.js +79 -159
  219. package/es/tntd-layout/storage.js +11 -18
  220. package/es/tntd-modal/index.js +32 -73
  221. package/es/tntd-second-page/index.js +24 -47
  222. package/es/tntd-select/DropDownWrap.js +52 -73
  223. package/es/tntd-select/index.js +492 -564
  224. package/es/tntd-select/index.js.map +1 -1
  225. package/es/tooltip/index.js +2 -1
  226. package/es/transfer/index.js +2 -1
  227. package/es/tree/index.js +2 -1
  228. package/es/tree-select/index.js +2 -1
  229. package/es/typography/index.js +2 -1
  230. package/es/upload/index.js +2 -1
  231. package/es/utils/checkAuth.js +21 -24
  232. package/es/utils/findMenuInfoByPath.js +30 -33
  233. package/es/utils/index.js +59 -65
  234. package/es/version/index.js +2 -1
  235. package/lib/affix/index.d.ts +3 -3
  236. package/lib/affix/index.js +22 -23
  237. package/lib/affix/index.js.map +1 -1
  238. package/lib/alert/index.d.ts +3 -3
  239. package/lib/alert/index.js +22 -23
  240. package/lib/alert/index.js.map +1 -1
  241. package/lib/anchor/index.d.ts +3 -3
  242. package/lib/anchor/index.js +22 -23
  243. package/lib/anchor/index.js.map +1 -1
  244. package/lib/array-input/icon.js +12 -33
  245. package/lib/array-input/index.js +150 -254
  246. package/lib/auth-context/index.js +4 -10
  247. package/lib/auto-complete/index.d.ts +3 -3
  248. package/lib/auto-complete/index.js +22 -23
  249. package/lib/auto-complete/index.js.map +1 -1
  250. package/lib/avatar/index.d.ts +3 -3
  251. package/lib/avatar/index.js +22 -23
  252. package/lib/avatar/index.js.map +1 -1
  253. package/lib/back-top/index.d.ts +3 -3
  254. package/lib/back-top/index.js +22 -23
  255. package/lib/back-top/index.js.map +1 -1
  256. package/lib/badge/index.d.ts +3 -3
  257. package/lib/badge/index.js +22 -23
  258. package/lib/badge/index.js.map +1 -1
  259. package/lib/breadcrumb/index.d.ts +3 -3
  260. package/lib/breadcrumb/index.js +22 -23
  261. package/lib/breadcrumb/index.js.map +1 -1
  262. package/lib/button/index.d.ts +3 -3
  263. package/lib/button/index.js +22 -23
  264. package/lib/button/index.js.map +1 -1
  265. package/lib/calendar/index.d.ts +3 -3
  266. package/lib/calendar/index.js +22 -23
  267. package/lib/calendar/index.js.map +1 -1
  268. package/lib/card/index.d.ts +3 -3
  269. package/lib/card/index.js +22 -23
  270. package/lib/card/index.js.map +1 -1
  271. package/lib/carousel/index.d.ts +3 -3
  272. package/lib/carousel/index.js +22 -23
  273. package/lib/carousel/index.js.map +1 -1
  274. package/lib/cascader/index.d.ts +3 -3
  275. package/lib/cascader/index.js +22 -23
  276. package/lib/cascader/index.js.map +1 -1
  277. package/lib/checkbox/index.d.ts +3 -3
  278. package/lib/checkbox/index.js +22 -23
  279. package/lib/checkbox/index.js.map +1 -1
  280. package/lib/col/index.d.ts +3 -3
  281. package/lib/col/index.js +22 -23
  282. package/lib/col/index.js.map +1 -1
  283. package/lib/collapse/index.d.ts +3 -3
  284. package/lib/collapse/index.js +23 -24
  285. package/lib/collapse/index.js.map +1 -1
  286. package/lib/color-picker/ColorPicker.d.ts +16 -0
  287. package/lib/color-picker/ColorPicker.d.ts.map +1 -0
  288. package/lib/color-picker/ColorPicker.js +119 -0
  289. package/lib/color-picker/ColorPicker.js.map +1 -0
  290. package/lib/color-picker/index.d.ts +2 -0
  291. package/lib/color-picker/index.d.ts.map +1 -0
  292. package/lib/color-picker/index.js +17 -0
  293. package/lib/color-picker/index.js.map +1 -0
  294. package/lib/color-picker/index.less +234 -0
  295. package/lib/color-picker/tip.svg +23 -0
  296. package/lib/columns/index.js +41 -81
  297. package/lib/columns/style/index.js +2 -1
  298. package/lib/comment/index.d.ts +3 -3
  299. package/lib/comment/index.js +22 -23
  300. package/lib/comment/index.js.map +1 -1
  301. package/lib/config-provider/config-provider.d.ts +1 -1
  302. package/lib/config-provider/config-provider.js +8 -12
  303. package/lib/config-provider/config-provider.js.map +1 -1
  304. package/lib/config-provider/index.d.ts +3 -3
  305. package/lib/config-provider/index.js +22 -23
  306. package/lib/config-provider/index.js.map +1 -1
  307. package/lib/date-picker/index.d.ts +3 -3
  308. package/lib/date-picker/index.js +22 -23
  309. package/lib/date-picker/index.js.map +1 -1
  310. package/lib/descriptions/descriptions.d.ts +4 -4
  311. package/lib/descriptions/descriptions.d.ts.map +1 -1
  312. package/lib/descriptions/descriptions.js +55 -64
  313. package/lib/descriptions/descriptions.js.map +1 -1
  314. package/lib/descriptions/index.d.ts +1 -1
  315. package/lib/descriptions/index.js +22 -23
  316. package/lib/descriptions/index.js.map +1 -1
  317. package/lib/development-login/LoginModal.js +79 -110
  318. package/lib/development-login/index.js +35 -42
  319. package/lib/divider/index.d.ts +3 -3
  320. package/lib/divider/index.js +22 -23
  321. package/lib/divider/index.js.map +1 -1
  322. package/lib/drawer/drawer.d.ts +1 -1
  323. package/lib/drawer/drawer.js +30 -41
  324. package/lib/drawer/drawer.js.map +1 -1
  325. package/lib/drawer/index.d.ts +2 -2
  326. package/lib/drawer/index.js +20 -22
  327. package/lib/drawer/index.js.map +1 -1
  328. package/lib/dropdown/index.d.ts +3 -3
  329. package/lib/dropdown/index.js +22 -23
  330. package/lib/dropdown/index.js.map +1 -1
  331. package/lib/ellipsis/Svg/CopySVG.d.ts.map +1 -1
  332. package/lib/ellipsis/Svg/CopySVG.js +20 -70
  333. package/lib/ellipsis/Svg/CopySVG.js.map +1 -1
  334. package/lib/ellipsis/Svg/TickSVG.d.ts.map +1 -1
  335. package/lib/ellipsis/Svg/TickSVG.js +15 -48
  336. package/lib/ellipsis/Svg/TickSVG.js.map +1 -1
  337. package/lib/ellipsis/index.d.ts.map +1 -1
  338. package/lib/ellipsis/index.js +115 -128
  339. package/lib/ellipsis/index.js.map +1 -1
  340. package/lib/ellipsis/index.less +1 -1
  341. package/lib/empty/empty.d.ts +2 -2
  342. package/lib/empty/empty.js +75 -90
  343. package/lib/empty/empty.js.map +1 -1
  344. package/lib/empty/empty.stories.js +18 -19
  345. package/lib/empty/index.d.ts +1 -1
  346. package/lib/empty/index.js +19 -20
  347. package/lib/empty/index.js.map +1 -1
  348. package/lib/exception/exception.js +31 -46
  349. package/lib/exception/exception.js.map +1 -1
  350. package/lib/exception/index.js +18 -19
  351. package/lib/form/index.d.ts +3 -3
  352. package/lib/form/index.js +22 -23
  353. package/lib/form/index.js.map +1 -1
  354. package/lib/handle/index.js +104 -140
  355. package/lib/handle/index.js.map +1 -1
  356. package/lib/icon/index.d.ts +3 -3
  357. package/lib/icon/index.js +22 -23
  358. package/lib/icon/index.js.map +1 -1
  359. package/lib/icon-list/index.js +121 -7
  360. package/lib/img/Contain.js +44 -69
  361. package/lib/img/Cover.js +78 -117
  362. package/lib/img/index.js +60 -74
  363. package/lib/index.d.ts +1 -0
  364. package/lib/index.d.ts.map +1 -1
  365. package/lib/index.js +186 -614
  366. package/lib/index.js.map +1 -1
  367. package/lib/input/index.d.ts +3 -3
  368. package/lib/input/index.js +22 -23
  369. package/lib/input/index.js.map +1 -1
  370. package/lib/input-number/index.d.ts +3 -3
  371. package/lib/input-number/index.js +22 -23
  372. package/lib/input-number/index.js.map +1 -1
  373. package/lib/layout/index.d.ts +3 -3
  374. package/lib/layout/index.js +22 -23
  375. package/lib/layout/index.js.map +1 -1
  376. package/lib/list/index.d.ts +3 -3
  377. package/lib/list/index.js +22 -23
  378. package/lib/list/index.js.map +1 -1
  379. package/lib/loading-button/index.js +55 -58
  380. package/lib/locale/default.d.ts +1 -0
  381. package/lib/locale/default.d.ts.map +1 -1
  382. package/lib/locale/default.js +10 -12
  383. package/lib/locale/default.js.map +1 -1
  384. package/lib/locale/en_US.d.ts +1 -0
  385. package/lib/locale/en_US.d.ts.map +1 -1
  386. package/lib/locale/en_US.js +36 -37
  387. package/lib/locale/en_US.js.map +1 -1
  388. package/lib/locale/index.js +18 -36
  389. package/lib/locale/zh_CN.d.ts +1 -0
  390. package/lib/locale/zh_CN.d.ts.map +1 -1
  391. package/lib/locale/zh_CN.js +36 -37
  392. package/lib/locale/zh_CN.js.map +1 -1
  393. package/lib/locale-provider/index.d.ts +3 -3
  394. package/lib/locale-provider/index.js +25 -26
  395. package/lib/locale-provider/index.js.map +1 -1
  396. package/lib/mention/index.d.ts +3 -3
  397. package/lib/mention/index.js +22 -23
  398. package/lib/mention/index.js.map +1 -1
  399. package/lib/mentions/index.d.ts +3 -3
  400. package/lib/mentions/index.js +22 -23
  401. package/lib/mentions/index.js.map +1 -1
  402. package/lib/menu/index.d.ts +3 -3
  403. package/lib/menu/index.js +22 -23
  404. package/lib/menu/index.js.map +1 -1
  405. package/lib/message/index.d.ts +3 -3
  406. package/lib/message/index.js +22 -23
  407. package/lib/message/index.js.map +1 -1
  408. package/lib/modal/index.d.ts +1 -1
  409. package/lib/modal/index.js +21 -22
  410. package/lib/modal/index.js.map +1 -1
  411. package/lib/modal/modal.d.ts +9 -9
  412. package/lib/modal/modal.js +49 -53
  413. package/lib/modal/modal.js.map +1 -1
  414. package/lib/notification/index.d.ts +3 -3
  415. package/lib/notification/index.js +22 -23
  416. package/lib/notification/index.js.map +1 -1
  417. package/lib/page/Box.js +40 -66
  418. package/lib/page/index.d.ts.map +1 -1
  419. package/lib/page/index.js +95 -151
  420. package/lib/page/index.js.map +1 -1
  421. package/lib/page/utils.js +16 -22
  422. package/lib/page-header/index.d.ts +3 -3
  423. package/lib/page-header/index.js +22 -23
  424. package/lib/page-header/index.js.map +1 -1
  425. package/lib/pagination/index.d.ts +3 -3
  426. package/lib/pagination/index.js +22 -23
  427. package/lib/pagination/index.js.map +1 -1
  428. package/lib/popconfirm/index.d.ts +3 -3
  429. package/lib/popconfirm/index.js +22 -23
  430. package/lib/popconfirm/index.js.map +1 -1
  431. package/lib/popover/index.d.ts +3 -3
  432. package/lib/popover/index.js +22 -23
  433. package/lib/popover/index.js.map +1 -1
  434. package/lib/prev-locale.js +53 -67
  435. package/lib/progress/index.d.ts +3 -3
  436. package/lib/progress/index.js +22 -23
  437. package/lib/progress/index.js.map +1 -1
  438. package/lib/query-form/Field/Checkbox.js +22 -28
  439. package/lib/query-form/Field/Select.js +68 -79
  440. package/lib/query-form/Field/SelectInput.js +73 -85
  441. package/lib/query-form/Field/fieldsMap.d.ts +2 -2
  442. package/lib/query-form/Field/fieldsMap.js +32 -34
  443. package/lib/query-form/Field/index.js +95 -139
  444. package/lib/query-form/createActions.js +50 -53
  445. package/lib/query-form/index.js +286 -377
  446. package/lib/query-form/useForm.js +11 -11
  447. package/lib/query-list-scene/List.d.ts.map +1 -1
  448. package/lib/query-list-scene/List.js +289 -360
  449. package/lib/query-list-scene/List.js.map +1 -1
  450. package/lib/query-list-scene/QueryForm.js +103 -161
  451. package/lib/query-list-scene/QueryListScene.js +31 -66
  452. package/lib/query-list-scene/Title.js +9 -15
  453. package/lib/query-list-scene/Toolbar.js +20 -31
  454. package/lib/query-list-scene/createActions.js +64 -79
  455. package/lib/query-list-scene/index.js +24 -28
  456. package/lib/query-list-scene/useActions.js +11 -11
  457. package/lib/radio/index.d.ts +3 -3
  458. package/lib/radio/index.js +22 -23
  459. package/lib/radio/index.js.map +1 -1
  460. package/lib/rate/index.d.ts +3 -3
  461. package/lib/rate/index.js +22 -23
  462. package/lib/rate/index.js.map +1 -1
  463. package/lib/render-empty/index.js +4 -8
  464. package/lib/render-empty/render-empty.js +22 -28
  465. package/lib/render-empty/render-empty.js.map +1 -1
  466. package/lib/result/index.d.ts +3 -3
  467. package/lib/result/index.js +22 -23
  468. package/lib/result/index.js.map +1 -1
  469. package/lib/row/index.d.ts +3 -3
  470. package/lib/row/index.js +22 -23
  471. package/lib/row/index.js.map +1 -1
  472. package/lib/select/index.d.ts +3 -3
  473. package/lib/select/index.js +22 -23
  474. package/lib/select/index.js.map +1 -1
  475. package/lib/skeleton/index.d.ts +3 -3
  476. package/lib/skeleton/index.js +22 -23
  477. package/lib/skeleton/index.js.map +1 -1
  478. package/lib/slider/index.d.ts +3 -3
  479. package/lib/slider/index.js +22 -23
  480. package/lib/slider/index.js.map +1 -1
  481. package/lib/spin/index.d.ts +3 -3
  482. package/lib/spin/index.js +22 -23
  483. package/lib/spin/index.js.map +1 -1
  484. package/lib/statistic/index.d.ts +3 -3
  485. package/lib/statistic/index.js +22 -23
  486. package/lib/statistic/index.js.map +1 -1
  487. package/lib/steps/index.d.ts +1 -1
  488. package/lib/steps/index.js +19 -20
  489. package/lib/steps/index.js.map +1 -1
  490. package/lib/steps/steps.d.ts +3 -3
  491. package/lib/steps/steps.js +59 -72
  492. package/lib/steps/steps.js.map +1 -1
  493. package/lib/svg-components/illustration-403.d.ts +1 -1
  494. package/lib/svg-components/illustration-403.js +84 -217
  495. package/lib/svg-components/illustration-404.d.ts +1 -1
  496. package/lib/svg-components/illustration-404.js +101 -301
  497. package/lib/svg-components/illustration-500.d.ts +1 -1
  498. package/lib/svg-components/illustration-500.js +109 -332
  499. package/lib/svg-components/illustration-empty.d.ts +1 -1
  500. package/lib/svg-components/illustration-empty.js +41 -65
  501. package/lib/svg-components/illustration-failure.d.ts +1 -1
  502. package/lib/svg-components/illustration-failure.js +62 -123
  503. package/lib/svg-components/illustration-no-access.d.ts +1 -1
  504. package/lib/svg-components/illustration-no-access.js +61 -125
  505. package/lib/svg-components/illustration-no-chart.d.ts +1 -1
  506. package/lib/svg-components/illustration-no-chart.js +63 -145
  507. package/lib/svg-components/illustration-no-result.d.ts +1 -1
  508. package/lib/svg-components/illustration-no-result.js +58 -103
  509. package/lib/svg-components/illustration-offline.d.ts +1 -1
  510. package/lib/svg-components/illustration-offline.js +69 -142
  511. package/lib/svg-components/illustration-success.d.ts +1 -1
  512. package/lib/svg-components/illustration-success.js +69 -148
  513. package/lib/svg-components/index.js +26 -75
  514. package/lib/switch/index.d.ts +3 -3
  515. package/lib/switch/index.js +22 -23
  516. package/lib/switch/index.js.map +1 -1
  517. package/lib/table/assets/image-loading-background.d.ts +1 -1
  518. package/lib/table/assets/image-loading-background.js +43 -56
  519. package/lib/table/assets/image-loading.d.ts +1 -1
  520. package/lib/table/assets/image-loading.js +31 -37
  521. package/lib/table/constants.js +3 -6
  522. package/lib/table/context.js +4 -7
  523. package/lib/table/hooks/index.js +16 -14
  524. package/lib/table/hooks/use-column-setting.d.ts +1 -1
  525. package/lib/table/hooks/use-column-setting.js +20 -37
  526. package/lib/table/hooks/use-column-setting.js.map +1 -1
  527. package/lib/table/index.d.ts +1 -1
  528. package/lib/table/index.js +19 -20
  529. package/lib/table/index.js.map +1 -1
  530. package/lib/table/table.d.ts +3 -3
  531. package/lib/table/table.js +92 -110
  532. package/lib/table/table.js.map +1 -1
  533. package/lib/table/table.stories.js +154 -182
  534. package/lib/table/utils.d.ts +1 -1
  535. package/lib/table/utils.js +25 -24
  536. package/lib/table/utils.js.map +1 -1
  537. package/lib/tabs/index.d.ts +3 -3
  538. package/lib/tabs/index.js +22 -23
  539. package/lib/tabs/index.js.map +1 -1
  540. package/lib/tag/index.d.ts +52 -3
  541. package/lib/tag/index.d.ts.map +1 -1
  542. package/lib/tag/index.js +155 -22
  543. package/lib/tag/index.js.map +1 -1
  544. package/lib/tag/tag.less +61 -0
  545. package/lib/time-picker/index.d.ts +3 -3
  546. package/lib/time-picker/index.js +22 -23
  547. package/lib/time-picker/index.js.map +1 -1
  548. package/lib/timeline/index.d.ts +3 -3
  549. package/lib/timeline/index.js +22 -23
  550. package/lib/timeline/index.js.map +1 -1
  551. package/lib/title/index.js +26 -45
  552. package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +31 -18
  553. package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +26 -9
  554. package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +26 -9
  555. package/lib/tntd-cascader/AntdCascader/component/context.js +16 -18
  556. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +39 -36
  557. package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
  558. package/lib/tntd-cascader/AntdCascader/component/getIcons.js +75 -81
  559. package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +50 -31
  560. package/lib/tntd-cascader/AntdCascader/config/utils.js +27 -29
  561. package/lib/tntd-cascader/AntdCascader/config/warning.js +35 -19
  562. package/lib/tntd-cascader/AntdCascader/index.js +162 -216
  563. package/lib/tntd-cascader/AntdCascader/interface.js +6 -13
  564. package/lib/tntd-cascader/img/no-data-s.png +0 -0
  565. package/lib/tntd-cascader/index.js +8 -12
  566. package/lib/tntd-cascader/rc-cascader/Cascader.js +284 -325
  567. package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +41 -30
  568. package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +152 -198
  569. package/lib/tntd-cascader/rc-cascader/OptionList/index.js +163 -223
  570. package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +48 -40
  571. package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +166 -179
  572. package/lib/tntd-cascader/rc-cascader/context.js +27 -11
  573. package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +63 -62
  574. package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +49 -39
  575. package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +41 -26
  576. package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +33 -16
  577. package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +51 -30
  578. package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +65 -75
  579. package/lib/tntd-cascader/rc-cascader/index.js +7 -9
  580. package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +38 -49
  581. package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +39 -42
  582. package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +30 -34
  583. package/lib/tntd-form/TntdForm/components/Item.js +61 -55
  584. package/lib/tntd-form/TntdForm/components/ItemComp.js +190 -203
  585. package/lib/tntd-form/TntdForm/components/List.js +111 -118
  586. package/lib/tntd-form/TntdForm/index.js +67 -61
  587. package/lib/tntd-form/TntdForm/interface.js +2 -4
  588. package/lib/tntd-form/TntdForm/store.js +7 -8
  589. package/lib/tntd-form/TntdForm/utils.js +184 -182
  590. package/lib/tntd-form/index.js +8 -12
  591. package/lib/tntd-icon/fonts/iconfont.js +53 -36
  592. package/lib/tntd-icon/index.js +25 -40
  593. package/lib/tntd-layout/ActionsContext.js +4 -8
  594. package/lib/tntd-layout/AppList.js +224 -173
  595. package/lib/tntd-layout/Application.js +111 -75
  596. package/lib/tntd-layout/Avatar.js +135 -100
  597. package/lib/tntd-layout/CompatibleLanguage.js +180 -128
  598. package/lib/tntd-layout/EnterpriseLayout/Avatar.js +146 -117
  599. package/lib/tntd-layout/EnterpriseLayout/Language.js +90 -73
  600. package/lib/tntd-layout/EnterpriseLayout/Theme.js +102 -69
  601. package/lib/tntd-layout/EnterpriseLayout/index.js +17 -28
  602. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.d.ts.map +1 -1
  603. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +276 -284
  604. package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
  605. package/lib/tntd-layout/GlobalNavigation/index.js +115 -108
  606. package/lib/tntd-layout/Header.js +136 -77
  607. package/lib/tntd-layout/HeaderActions.js +106 -105
  608. package/lib/tntd-layout/HeaderNavs.js +107 -78
  609. package/lib/tntd-layout/HeaderTabs.js +316 -224
  610. package/lib/tntd-layout/Iconfont.js +7 -11
  611. package/lib/tntd-layout/Language.js +76 -69
  612. package/lib/tntd-layout/Layout.js +171 -214
  613. package/lib/tntd-layout/Logo.js +144 -69
  614. package/lib/tntd-layout/OrgAppList.js +388 -238
  615. package/lib/tntd-layout/SideMenu.js +408 -269
  616. package/lib/tntd-layout/Theme.js +93 -75
  617. package/lib/tntd-layout/createActions.js +34 -45
  618. package/lib/tntd-layout/images/avatar/empty.png +0 -0
  619. package/lib/tntd-layout/images/avatar/female1.png +0 -0
  620. package/lib/tntd-layout/images/avatar/female2.png +0 -0
  621. package/lib/tntd-layout/images/avatar/female3.png +0 -0
  622. package/lib/tntd-layout/images/avatar/female4.png +0 -0
  623. package/lib/tntd-layout/images/avatar/female5.png +0 -0
  624. package/lib/tntd-layout/images/avatar/female6.png +0 -0
  625. package/lib/tntd-layout/images/avatar/male1.png +0 -0
  626. package/lib/tntd-layout/images/avatar/male2.png +0 -0
  627. package/lib/tntd-layout/images/avatar/male3.png +0 -0
  628. package/lib/tntd-layout/images/avatar/male4.png +0 -0
  629. package/lib/tntd-layout/images/avatar/male5.png +0 -0
  630. package/lib/tntd-layout/images/avatar/male6.png +0 -0
  631. package/lib/tntd-layout/images/index.js +66 -68
  632. package/lib/tntd-layout/index.js +95 -137
  633. package/lib/tntd-layout/paaslayout/CompactSideMenu.js +182 -131
  634. package/lib/tntd-layout/paaslayout/Header.js +79 -51
  635. package/lib/tntd-layout/paaslayout/Logo.js +30 -15
  636. package/lib/tntd-layout/paaslayout/SideMenu.js +147 -131
  637. package/lib/tntd-layout/paaslayout/index.js +141 -205
  638. package/lib/tntd-layout/storage.js +30 -58
  639. package/lib/tntd-modal/index.js +62 -98
  640. package/lib/tntd-second-page/index.js +33 -60
  641. package/lib/tntd-second-page/index.js.map +1 -1
  642. package/lib/tntd-select/DropDownWrap.js +78 -102
  643. package/lib/tntd-select/index.d.ts +3 -3
  644. package/lib/tntd-select/index.d.ts.map +1 -1
  645. package/lib/tntd-select/index.js +529 -607
  646. package/lib/tntd-select/index.js.map +1 -1
  647. package/lib/tooltip/index.d.ts +3 -3
  648. package/lib/tooltip/index.js +22 -23
  649. package/lib/tooltip/index.js.map +1 -1
  650. package/lib/transfer/index.d.ts +3 -3
  651. package/lib/transfer/index.js +22 -23
  652. package/lib/transfer/index.js.map +1 -1
  653. package/lib/tree/index.d.ts +3 -3
  654. package/lib/tree/index.js +22 -23
  655. package/lib/tree/index.js.map +1 -1
  656. package/lib/tree-select/index.d.ts +3 -3
  657. package/lib/tree-select/index.js +22 -23
  658. package/lib/tree-select/index.js.map +1 -1
  659. package/lib/typography/index.d.ts +3 -3
  660. package/lib/typography/index.js +22 -23
  661. package/lib/typography/index.js.map +1 -1
  662. package/lib/upload/index.d.ts +3 -3
  663. package/lib/upload/index.js +22 -23
  664. package/lib/upload/index.js.map +1 -1
  665. package/lib/utils/checkAuth.js +23 -34
  666. package/lib/utils/findMenuInfoByPath.js +34 -41
  667. package/lib/utils/index.js +80 -117
  668. package/lib/version/index.d.ts +3 -3
  669. package/lib/version/index.js +22 -23
  670. package/lib/version/index.js.map +1 -1
  671. package/package.json +4 -2
  672. package/themes/default/variables.less +6 -7
  673. package/es/array-input/style/index.js +0 -1
  674. package/es/array-input/style/index.js.map +0 -1
  675. package/es/auth-context/style/index.js +0 -1
  676. package/es/auth-context/style/index.js.map +0 -1
  677. package/es/development-login/style/index.js +0 -1
  678. package/es/development-login/style/index.js.map +0 -1
  679. package/es/ellipsis/style/index.js +0 -1
  680. package/es/ellipsis/style/index.js.map +0 -1
  681. package/es/empty/render-empty.js +0 -22
  682. package/es/empty/render-empty.js.map +0 -1
  683. package/es/empty/style/index.js +0 -2
  684. package/es/empty/style/index.js.map +0 -1
  685. package/es/handle/style/index.js +0 -1
  686. package/es/handle/style/index.js.map +0 -1
  687. package/es/icon-list/style/index.js +0 -1
  688. package/es/icon-list/style/index.js.map +0 -1
  689. package/es/img/style/index.js +0 -1
  690. package/es/img/style/index.js.map +0 -1
  691. package/es/loading-button/style/index.js +0 -1
  692. package/es/loading-button/style/index.js.map +0 -1
  693. package/es/page/style/index.js +0 -1
  694. package/es/page/style/index.js.map +0 -1
  695. package/es/query-form/style/index.js +0 -1
  696. package/es/query-form/style/index.js.map +0 -1
  697. package/es/query-list-scene/style/index.js +0 -1
  698. package/es/query-list-scene/style/index.js.map +0 -1
  699. package/es/render-empty/style/index.js +0 -1
  700. package/es/render-empty/style/index.js.map +0 -1
  701. package/es/status/index.js +0 -1
  702. package/es/status/index.js.map +0 -1
  703. package/es/status/status.js +0 -5
  704. package/es/status/status.js.map +0 -1
  705. package/es/table/style/index.js +0 -2
  706. package/es/table/style/index.js.map +0 -1
  707. package/es/title/style/index.js +0 -1
  708. package/es/title/style/index.js.map +0 -1
  709. package/es/tntd-icon/style/index.js +0 -1
  710. package/es/tntd-icon/style/index.js.map +0 -1
  711. package/es/tntd-layout/style/index.js +0 -1
  712. package/es/tntd-layout/style/index.js.map +0 -1
  713. package/es/tntd-modal/style/index.js +0 -1
  714. package/es/tntd-modal/style/index.js.map +0 -1
  715. package/es/tntd-select/style/index.js +0 -1
  716. package/es/tntd-select/style/index.js.map +0 -1
  717. package/lib/array-input/style/index.d.ts +0 -1
  718. package/lib/array-input/style/index.d.ts.map +0 -1
  719. package/lib/array-input/style/index.js +0 -1
  720. package/lib/array-input/style/index.js.map +0 -1
  721. package/lib/auth-context/style/index.d.ts +0 -1
  722. package/lib/auth-context/style/index.d.ts.map +0 -1
  723. package/lib/auth-context/style/index.js +0 -1
  724. package/lib/auth-context/style/index.js.map +0 -1
  725. package/lib/development-login/style/index.d.ts +0 -1
  726. package/lib/development-login/style/index.d.ts.map +0 -1
  727. package/lib/development-login/style/index.js +0 -1
  728. package/lib/development-login/style/index.js.map +0 -1
  729. package/lib/ellipsis/style/index.d.ts +0 -1
  730. package/lib/ellipsis/style/index.d.ts.map +0 -1
  731. package/lib/ellipsis/style/index.js +0 -1
  732. package/lib/ellipsis/style/index.js.map +0 -1
  733. package/lib/empty/render-empty.d.ts +0 -3
  734. package/lib/empty/render-empty.d.ts.map +0 -1
  735. package/lib/empty/render-empty.js +0 -32
  736. package/lib/empty/render-empty.js.map +0 -1
  737. package/lib/empty/style/index.d.ts +0 -3
  738. package/lib/empty/style/index.d.ts.map +0 -1
  739. package/lib/empty/style/index.js +0 -4
  740. package/lib/empty/style/index.js.map +0 -1
  741. package/lib/handle/style/index.d.ts +0 -1
  742. package/lib/handle/style/index.d.ts.map +0 -1
  743. package/lib/handle/style/index.js +0 -1
  744. package/lib/handle/style/index.js.map +0 -1
  745. package/lib/icon-list/style/index.d.ts +0 -3
  746. package/lib/icon-list/style/index.d.ts.map +0 -1
  747. package/lib/icon-list/style/index.js +0 -8
  748. package/lib/icon-list/style/index.js.map +0 -1
  749. package/lib/img/style/index.d.ts +0 -1
  750. package/lib/img/style/index.d.ts.map +0 -1
  751. package/lib/img/style/index.js +0 -1
  752. package/lib/img/style/index.js.map +0 -1
  753. package/lib/loading-button/style/index.d.ts +0 -1
  754. package/lib/loading-button/style/index.d.ts.map +0 -1
  755. package/lib/loading-button/style/index.js +0 -1
  756. package/lib/loading-button/style/index.js.map +0 -1
  757. package/lib/page/style/index.d.ts +0 -1
  758. package/lib/page/style/index.d.ts.map +0 -1
  759. package/lib/page/style/index.js +0 -1
  760. package/lib/page/style/index.js.map +0 -1
  761. package/lib/query-form/style/index.d.ts +0 -1
  762. package/lib/query-form/style/index.d.ts.map +0 -1
  763. package/lib/query-form/style/index.js +0 -1
  764. package/lib/query-form/style/index.js.map +0 -1
  765. package/lib/query-list-scene/style/index.d.ts +0 -1
  766. package/lib/query-list-scene/style/index.d.ts.map +0 -1
  767. package/lib/query-list-scene/style/index.js +0 -1
  768. package/lib/query-list-scene/style/index.js.map +0 -1
  769. package/lib/render-empty/style/index.d.ts +0 -2
  770. package/lib/render-empty/style/index.d.ts.map +0 -1
  771. package/lib/render-empty/style/index.js +0 -3
  772. package/lib/render-empty/style/index.js.map +0 -1
  773. package/lib/status/index.d.ts +0 -2
  774. package/lib/status/index.d.ts.map +0 -1
  775. package/lib/status/index.js +0 -16
  776. package/lib/status/index.js.map +0 -1
  777. package/lib/status/status.d.ts +0 -6
  778. package/lib/status/status.d.ts.map +0 -1
  779. package/lib/status/status.js +0 -13
  780. package/lib/status/status.js.map +0 -1
  781. package/lib/table/style/index.d.ts +0 -3
  782. package/lib/table/style/index.d.ts.map +0 -1
  783. package/lib/table/style/index.js +0 -4
  784. package/lib/table/style/index.js.map +0 -1
  785. package/lib/title/style/index.d.ts +0 -1
  786. package/lib/title/style/index.d.ts.map +0 -1
  787. package/lib/title/style/index.js +0 -1
  788. package/lib/title/style/index.js.map +0 -1
  789. package/lib/tntd-icon/style/index.d.ts +0 -1
  790. package/lib/tntd-icon/style/index.d.ts.map +0 -1
  791. package/lib/tntd-icon/style/index.js +0 -1
  792. package/lib/tntd-icon/style/index.js.map +0 -1
  793. package/lib/tntd-layout/style/index.d.ts +0 -1
  794. package/lib/tntd-layout/style/index.d.ts.map +0 -1
  795. package/lib/tntd-layout/style/index.js +0 -1
  796. package/lib/tntd-layout/style/index.js.map +0 -1
  797. package/lib/tntd-modal/style/index.d.ts +0 -1
  798. package/lib/tntd-modal/style/index.d.ts.map +0 -1
  799. package/lib/tntd-modal/style/index.js +0 -1
  800. package/lib/tntd-modal/style/index.js.map +0 -1
  801. package/lib/tntd-select/style/index.d.ts +0 -1
  802. package/lib/tntd-select/style/index.d.ts.map +0 -1
  803. package/lib/tntd-select/style/index.js +0 -1
  804. package/lib/tntd-select/style/index.js.map +0 -1
@@ -1,19 +1,19 @@
1
- import _debounce from "lodash/debounce";
2
1
  import React, { useState, useEffect } from 'react';
3
2
  import cn from 'classnames';
4
3
  import styled from 'styled-components';
4
+ import { debounce } from 'lodash';
5
5
  import { traverseTree, hasLevel3 } from '../../utils';
6
6
  import Icon from '../Iconfont';
7
7
  import '../../locale';
8
- const SearchArea = styled.div`
8
+ const SearchArea = styled.div `
9
9
  position: relative;
10
10
  font-size: 14px;
11
11
  margin-bottom: 20px;
12
- color: ${props => props.theme.secondaryTextColor};
12
+ color: ${(props) => props.theme.secondaryTextColor};
13
13
  &.active {
14
- color: ${props => props.theme.primaryColor};
14
+ color: ${(props) => props.theme.primaryColor};
15
15
  input {
16
- border-color: ${props => props.theme.primaryColor};
16
+ border-color: ${(props) => props.theme.primaryColor};
17
17
  }
18
18
  }
19
19
  .tnt-icon {
@@ -31,7 +31,7 @@ const SearchArea = styled.div`
31
31
  input {
32
32
  border-width: 0 0 1px;
33
33
  border-style: solid;
34
- border-color: ${props => props.theme.borderColor};
34
+ border-color: ${(props) => props.theme.borderColor};
35
35
  width: 100%;
36
36
  padding: 4px 20px;
37
37
  line-height: 20px;
@@ -39,9 +39,9 @@ const SearchArea = styled.div`
39
39
  outline: none;
40
40
  }
41
41
  `;
42
- const ApplicationTabs = styled.ul`
43
- border: 1px solid ${props => props.theme.borderColor};
44
- color: ${props => props.theme.primaryTextColor};
42
+ const ApplicationTabs = styled.ul `
43
+ border: 1px solid ${(props) => props.theme.borderColor};
44
+ color: ${(props) => props.theme.primaryTextColor};
45
45
  line-height: 32px;
46
46
  margin: 0 0 16px;
47
47
  padding: 0;
@@ -52,16 +52,16 @@ const ApplicationTabs = styled.ul`
52
52
  display: inline-block;
53
53
  cursor: pointer;
54
54
  &:not(:last-child) {
55
- border-right: 1px solid ${props => props.theme.borderColor};
55
+ border-right: 1px solid ${(props) => props.theme.borderColor};
56
56
  }
57
57
  &.active {
58
- background-color: ${props => props.theme.primaryColor};
58
+ background-color: ${(props) => props.theme.primaryColor};
59
59
  color: #fff;
60
60
  }
61
61
  }
62
62
  `;
63
- const GroupMenus = styled.div`
64
- height: ${props => props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)'};
63
+ const GroupMenus = styled.div `
64
+ height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};
65
65
  overflow: auto;
66
66
  & > div {
67
67
  width: 200px;
@@ -70,7 +70,7 @@ const GroupMenus = styled.div`
70
70
  vertical-align: top;
71
71
  }
72
72
  `;
73
- const GroupMenuItem = styled.div`
73
+ const GroupMenuItem = styled.div `
74
74
  margin-bottom: 20px;
75
75
  & > h5 {
76
76
  line-height: 20px;
@@ -78,27 +78,27 @@ const GroupMenuItem = styled.div`
78
78
  margin-bottom: 6px;
79
79
  }
80
80
  `;
81
- const MenuList = styled.ul`
81
+ const MenuList = styled.ul `
82
82
  list-style: none;
83
83
  padding: 0;
84
84
  margin: 0;
85
85
  `;
86
- const MenuItem = styled.li`
86
+ const MenuItem = styled.li `
87
87
  display: block;
88
88
  line-height: 30px;
89
89
  font-size: 12px;
90
90
  cursor: pointer;
91
91
  a {
92
- color: ${props => props.theme.secondaryTextColor};
92
+ color: ${(props) => props.theme.secondaryTextColor};
93
93
  &:hover {
94
- color: ${props => props.theme.secondaryColor} !important;
94
+ color: ${(props) => props.theme.secondaryColor} !important;
95
95
  }
96
96
  }
97
97
  &.active a {
98
- color: ${props => props.theme.primaryColor};
98
+ color: ${(props) => props.theme.primaryColor};
99
99
  }
100
100
  `;
101
- const ListBox = styled.ul`
101
+ const ListBox = styled.ul `
102
102
  background: #fff;
103
103
  max-height: 320px;
104
104
  overflow-y: auto;
@@ -115,205 +115,145 @@ const ListBox = styled.ul`
115
115
  cursor: pointer;
116
116
  line-height: 32px;
117
117
  padding: 0 10px;
118
- color: ${props => props.theme.primaryTextColor};
118
+ color: ${(props) => props.theme.primaryTextColor};
119
119
  &:hover {
120
- color: ${props => props.theme.secondaryColor};
121
- background-color: ${props => props.theme.lightBgColor};
120
+ color: ${(props) => props.theme.secondaryColor};
121
+ background-color: ${(props) => props.theme.lightBgColor};
122
122
  }
123
123
  }
124
124
  `;
125
- const SearchList = ({
126
- items,
127
- onSelectMenu,
128
- theme
129
- }) => React.createElement(ListBox, {
130
- theme: theme
131
- }, items === null || items === void 0 ? void 0 : items.map(item => React.createElement("li", {
132
- onClick: () => onSelectMenu(item)
133
- }, item === null || item === void 0 ? void 0 : item.menuName)));
134
- export default (({
135
- theme,
136
- menus = [],
137
- close,
138
- actions,
139
- popupRef,
140
- containerRef
141
- }) => {
142
- const [active, setActive] = useState(false);
143
- const [searchValue, setSearchValue] = useState();
144
- const language = actions === null || actions === void 0 ? void 0 : actions.getLanguage();
145
- const isLevel3 = hasLevel3(menus);
146
- const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus === null || menus === void 0 ? void 0 : menus[0] : null);
147
- const selectedMenuKey = actions.getSelectedMenuKey();
148
- const calcGroupMenus = menus => {
149
- menus = menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
150
- var _a;
151
- // 分组
152
- if ((_a = cur === null || cur === void 0 ? void 0 : cur.children) === null || _a === void 0 ? void 0 : _a.length) {
153
- acc.push(cur);
154
- } else {
155
- const defaultGroup = acc.find(({
156
- isDefaultGroup
157
- }) => isDefaultGroup);
158
- if (!defaultGroup) {
159
- acc.unshift({
160
- isDefaultGroup: true,
161
- children: [cur]
162
- });
163
- } else {
164
- defaultGroup.children.push(cur);
165
- }
166
- }
167
- return acc;
168
- }, []);
169
- return menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
170
- var _a;
171
- const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210));
172
- if (!acc.length) {
173
- acc.push([cur]);
174
- } else {
175
- const calcGroupHeight = group => {
176
- var _a;
177
- return 46 + (((_a = group === null || group === void 0 ? void 0 : group.children) === null || _a === void 0 ? void 0 : _a.length) || 0) * 30;
178
- };
179
- const calcColumnHeight = columnGroups => columnGroups === null || columnGroups === void 0 ? void 0 : columnGroups.reduce((acc, cur) => {
180
- acc += calcGroupHeight(cur);
181
- return acc;
182
- }, 0);
183
- const currentColumnHeight = calcColumnHeight(acc[acc.length - 1]);
184
- const nextGroupHeight = calcGroupHeight(cur);
185
- const findMinHeightGroup = groups => {
186
- let minHeight = Infinity;
187
- let index = 0;
188
- for (let i = 0; i < groups.length; i++) {
189
- const height = calcColumnHeight(groups[i]);
190
- if (height < minHeight) {
191
- index = i;
192
- minHeight = height;
125
+ const SearchList = ({ items, onSelectMenu, theme }) => (React.createElement(ListBox, { theme: theme }, items === null || items === void 0 ? void 0 : items.map((item) => (React.createElement("li", { onClick: () => onSelectMenu(item) }, item === null || item === void 0 ? void 0 : item.menuName)))));
126
+ export default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {
127
+ const [active, setActive] = useState(false);
128
+ const [searchValue, setSearchValue] = useState();
129
+ const language = actions === null || actions === void 0 ? void 0 : actions.getLanguage();
130
+ const isLevel3 = hasLevel3(menus);
131
+ const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus === null || menus === void 0 ? void 0 : menus[0] : null);
132
+ const selectedMenuKey = actions.getSelectedMenuKey();
133
+ const calcGroupMenus = (menus) => {
134
+ menus = menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
135
+ var _a;
136
+ // 分组
137
+ if ((_a = cur === null || cur === void 0 ? void 0 : cur.children) === null || _a === void 0 ? void 0 : _a.length) {
138
+ acc.push(cur);
193
139
  }
194
- }
195
- return groups[index];
196
- };
197
- if (acc.length >= column) {
198
- const minHeightGroup = findMinHeightGroup(acc);
199
- minHeightGroup === null || minHeightGroup === void 0 ? void 0 : minHeightGroup.push(cur);
200
- } else {
201
- if (currentColumnHeight + nextGroupHeight > 440) {
202
- acc.push([cur]);
203
- } else {
204
- (_a = acc[(acc === null || acc === void 0 ? void 0 : acc.length) - 1]) === null || _a === void 0 ? void 0 : _a.push(cur);
205
- }
206
- }
207
- }
208
- return acc;
209
- }, []);
210
- };
211
- const groupMenus = calcGroupMenus((activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.children) || menus);
212
- const [searchedMenus, setSearchedMenus] = useState([]);
213
- const onMenuClick = menu => {
214
- actions.emit('menuSelect', {
215
- key: menu.code,
216
- data: menu
217
- });
218
- setSearchValue('');
219
- setSearchedMenus([]);
220
- close();
221
- };
222
- const debounceSearch = _debounce(evt => {
223
- var _a;
224
- const value = (_a = evt.target.value) === null || _a === void 0 ? void 0 : _a.trim();
225
- const matchedMenus = [];
226
- if (value) {
227
- traverseTree(menus, node => {
228
- var _a;
229
- if (node.path && ((_a = node === null || node === void 0 ? void 0 : node.menuName) === null || _a === void 0 ? void 0 : _a.includes(value))) {
230
- matchedMenus.push(node);
231
- }
232
- });
233
- }
234
- setSearchedMenus(matchedMenus);
235
- }, 100);
236
- const onSearchChange = evt => {
237
- evt.persist();
238
- setSearchValue(evt.target.value);
239
- debounceSearch(evt);
240
- };
241
- const onSelectAppTab = menu => {
242
- setActiveTopMenu(menu);
243
- };
244
- useEffect(() => {
245
- const clickOutside = evt => {
246
- const {
247
- clientX,
248
- clientY,
249
- pageX,
250
- pageY
251
- } = evt;
252
- const isOutside = (evt, popup) => {
253
- if (popup === null || popup === void 0 ? void 0 : popup.contains) {
254
- return !(popup === null || popup === void 0 ? void 0 : popup.contains(evt.target));
255
- }
256
- let {
257
- x,
258
- y,
259
- height,
260
- width
261
- } = popup.getBoundingClientRect();
262
- console.log('clickOutside...', [x, y], [clientX, clientY], [pageX, pageY]);
263
- x += window.scrollX;
264
- y += window.scrollY;
265
- return pageX < x || pageX > x + width || pageY < y || pageY > y + height;
266
- };
267
- if (isOutside(evt, popupRef.current)) {
140
+ else {
141
+ const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup);
142
+ if (!defaultGroup) {
143
+ acc.unshift({
144
+ isDefaultGroup: true,
145
+ children: [cur],
146
+ });
147
+ }
148
+ else {
149
+ defaultGroup.children.push(cur);
150
+ }
151
+ }
152
+ return acc;
153
+ }, []);
154
+ return menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
155
+ var _a;
156
+ const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210));
157
+ if (!acc.length) {
158
+ acc.push([cur]);
159
+ }
160
+ else {
161
+ const calcGroupHeight = (group) => { var _a; return 46 + (((_a = group === null || group === void 0 ? void 0 : group.children) === null || _a === void 0 ? void 0 : _a.length) || 0) * 30; };
162
+ const calcColumnHeight = (columnGroups) => columnGroups === null || columnGroups === void 0 ? void 0 : columnGroups.reduce((acc, cur) => {
163
+ acc += calcGroupHeight(cur);
164
+ return acc;
165
+ }, 0);
166
+ const currentColumnHeight = calcColumnHeight(acc[acc.length - 1]);
167
+ const nextGroupHeight = calcGroupHeight(cur);
168
+ const findMinHeightGroup = (groups) => {
169
+ let minHeight = Infinity;
170
+ let index = 0;
171
+ for (let i = 0; i < groups.length; i++) {
172
+ const height = calcColumnHeight(groups[i]);
173
+ if (height < minHeight) {
174
+ index = i;
175
+ minHeight = height;
176
+ }
177
+ }
178
+ return groups[index];
179
+ };
180
+ if (acc.length >= column) {
181
+ const minHeightGroup = findMinHeightGroup(acc);
182
+ minHeightGroup === null || minHeightGroup === void 0 ? void 0 : minHeightGroup.push(cur);
183
+ }
184
+ else {
185
+ if (currentColumnHeight + nextGroupHeight > 440) {
186
+ acc.push([cur]);
187
+ }
188
+ else {
189
+ (_a = acc[(acc === null || acc === void 0 ? void 0 : acc.length) - 1]) === null || _a === void 0 ? void 0 : _a.push(cur);
190
+ }
191
+ }
192
+ }
193
+ return acc;
194
+ }, []);
195
+ };
196
+ const groupMenus = calcGroupMenus((activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.children) || menus);
197
+ const [searchedMenus, setSearchedMenus] = useState([]);
198
+ const onMenuClick = (menu) => {
199
+ actions.emit('menuSelect', { key: menu.code, data: menu });
268
200
  setSearchValue('');
269
201
  setSearchedMenus([]);
270
202
  close();
271
- }
272
203
  };
273
- document.addEventListener('click', clickOutside);
274
- return () => document.removeEventListener('click', clickOutside);
275
- }, []);
276
- return React.createElement(React.Fragment, null, React.createElement(SearchArea, {
277
- theme: theme,
278
- className: cn({
279
- active
280
- })
281
- }, React.createElement(Icon, {
282
- type: "search"
283
- }), React.createElement("input", {
284
- placeholder: actions === null || actions === void 0 ? void 0 : actions.getText('menuSearch'),
285
- value: searchValue,
286
- onChange: onSearchChange,
287
- onFocus: () => setActive(true),
288
- onBlur: () => setActive(false)
289
- }), React.createElement(Icon, {
290
- type: "close",
291
- onClick: close
292
- }), (searchedMenus === null || searchedMenus === void 0 ? void 0 : searchedMenus.length) > 0 && React.createElement(SearchList, {
293
- items: searchedMenus,
294
- theme: theme,
295
- onSelectMenu: onMenuClick
296
- })), isLevel3 && React.createElement(ApplicationTabs, {
297
- theme: theme
298
- }, menus === null || menus === void 0 ? void 0 : menus.map(menu => React.createElement("li", {
299
- className: cn({
300
- active: menu.code === (activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.code)
301
- }),
302
- onClick: () => onSelectAppTab(menu)
303
- }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'groupName' : 'enName']))), React.createElement(GroupMenus, {
304
- theme: theme,
305
- isLevel3: isLevel3
306
- }, groupMenus === null || groupMenus === void 0 ? void 0 : groupMenus.map(groups => React.createElement("div", null, groups === null || groups === void 0 ? void 0 : groups.map(group => React.createElement(GroupMenuItem, {
307
- theme: theme
308
- }, React.createElement("h5", null, group === null || group === void 0 ? void 0 : group[language === 'cn' ? 'groupName' : 'enName']), React.createElement(MenuList, null, (group.children || []).map(menu => React.createElement(MenuItem, {
309
- key: menu.code,
310
- className: cn({
311
- active: selectedMenuKey === menu.code
312
- }),
313
- theme: theme,
314
- onClick: () => onMenuClick(menu)
315
- }, React.createElement("a", {
316
- href: menu.path,
317
- onClick: evt => evt.preventDefault()
318
- }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'menuName' : 'enName']))))))))));
319
- });
204
+ const debounceSearch = debounce((evt) => {
205
+ var _a;
206
+ const value = (_a = evt.target.value) === null || _a === void 0 ? void 0 : _a.trim();
207
+ const matchedMenus = [];
208
+ if (value) {
209
+ traverseTree(menus, (node) => {
210
+ var _a;
211
+ if (node.path && ((_a = node === null || node === void 0 ? void 0 : node.menuName) === null || _a === void 0 ? void 0 : _a.includes(value))) {
212
+ matchedMenus.push(node);
213
+ }
214
+ });
215
+ }
216
+ setSearchedMenus(matchedMenus);
217
+ }, 100);
218
+ const onSearchChange = (evt) => {
219
+ evt.persist();
220
+ setSearchValue(evt.target.value);
221
+ debounceSearch(evt);
222
+ };
223
+ const onSelectAppTab = (menu) => {
224
+ setActiveTopMenu(menu);
225
+ };
226
+ useEffect(() => {
227
+ const clickOutside = (evt) => {
228
+ const { clientX, clientY, pageX, pageY } = evt;
229
+ const isOutside = (evt, popup) => {
230
+ if (popup === null || popup === void 0 ? void 0 : popup.contains) {
231
+ return !(popup === null || popup === void 0 ? void 0 : popup.contains(evt.target));
232
+ }
233
+ let { x, y, height, width } = popup.getBoundingClientRect();
234
+ x += window.scrollX;
235
+ y += window.scrollY;
236
+ return pageX < x || pageX > x + width || pageY < y || pageY > y + height;
237
+ };
238
+ if (isOutside(evt, popupRef.current)) {
239
+ setSearchValue('');
240
+ setSearchedMenus([]);
241
+ close();
242
+ }
243
+ };
244
+ document.addEventListener('click', clickOutside);
245
+ return () => document.removeEventListener('click', clickOutside);
246
+ }, []);
247
+ return (React.createElement(React.Fragment, null,
248
+ React.createElement(SearchArea, { theme: theme, className: cn({ active }) },
249
+ React.createElement(Icon, { type: "search" }),
250
+ React.createElement("input", { placeholder: actions === null || actions === void 0 ? void 0 : actions.getText('menuSearch'), value: searchValue, onChange: onSearchChange, onFocus: () => setActive(true), onBlur: () => setActive(false) }),
251
+ React.createElement(Icon, { type: "close", onClick: close }),
252
+ (searchedMenus === null || searchedMenus === void 0 ? void 0 : searchedMenus.length) > 0 && (React.createElement(SearchList, { items: searchedMenus, theme: theme, onSelectMenu: onMenuClick }))),
253
+ isLevel3 && (React.createElement(ApplicationTabs, { theme: theme }, menus === null || menus === void 0 ? void 0 : menus.map((menu) => (React.createElement("li", { className: cn({ active: menu.code === (activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.code) }), onClick: () => onSelectAppTab(menu) }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'groupName' : 'enName']))))),
254
+ React.createElement(GroupMenus, { theme: theme, isLevel3: isLevel3 }, groupMenus === null || groupMenus === void 0 ? void 0 : groupMenus.map((groups) => (React.createElement("div", null, groups === null || groups === void 0 ? void 0 : groups.map((group) => (React.createElement(GroupMenuItem, { theme: theme },
255
+ React.createElement("h5", null, group === null || group === void 0 ? void 0 : group[language === 'cn' ? 'groupName' : 'enName']),
256
+ React.createElement(MenuList, null, (group.children || []).map((menu) => (React.createElement(MenuItem, { key: menu.code, className: cn({ active: selectedMenuKey === menu.code }), theme: theme, onClick: () => onMenuClick(menu) },
257
+ React.createElement("a", { href: menu.path, onClick: (evt) => evt.preventDefault() }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'menuName' : 'enName']))))))))))))));
258
+ };
259
+ //# sourceMappingURL=NavigationPopup.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n console.log('clickOutside...', [x, y], [clientX, clientY], [pageX, pageY])\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}
1
+ {"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}