tntd 2.0.25 → 2.1.0

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