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.
- package/es/affix/index.js +1 -2
- package/es/alert/index.js +1 -2
- package/es/anchor/index.js +1 -2
- package/es/array-input/icon.js +24 -6
- package/es/array-input/index.js +203 -119
- package/es/array-input/style/index.js +1 -0
- package/es/array-input/style/index.js.map +1 -0
- package/es/auth-context/index.js +1 -2
- package/es/auth-context/style/index.js +1 -0
- package/es/auth-context/style/index.js.map +1 -0
- package/es/auto-complete/index.js +1 -2
- package/es/avatar/index.js +1 -2
- package/es/back-top/index.js +1 -2
- package/es/badge/index.js +1 -2
- package/es/breadcrumb/index.js +1 -2
- package/es/button/index.js +1 -2
- package/es/calendar/index.js +1 -2
- package/es/card/index.js +1 -2
- package/es/carousel/index.js +1 -2
- package/es/cascader/index.js +1 -2
- package/es/checkbox/index.js +1 -2
- package/es/col/index.js +1 -2
- package/es/collapse/index.js +1 -2
- package/es/columns/index.js +66 -30
- package/es/columns/style/index.js +1 -2
- package/es/comment/index.js +1 -2
- package/es/config-provider/config-provider.js +1 -2
- package/es/config-provider/index.js +1 -2
- package/es/date-picker/index.js +1 -2
- package/es/descriptions/descriptions.js +38 -30
- package/es/descriptions/index.js +1 -2
- package/es/development-login/LoginModal.js +81 -46
- package/es/development-login/index.js +17 -8
- package/es/development-login/style/index.js +1 -0
- package/es/development-login/style/index.js.map +1 -0
- package/es/divider/index.js +1 -2
- package/es/drawer/drawer.js +27 -20
- package/es/drawer/index.js +1 -2
- package/es/dropdown/index.js +1 -2
- package/es/ellipsis/Svg/CopySVG.js +63 -17
- package/es/ellipsis/Svg/CopySVG.js.map +1 -1
- package/es/ellipsis/Svg/TickSVG.js +41 -12
- package/es/ellipsis/Svg/TickSVG.js.map +1 -1
- package/es/ellipsis/index.js +115 -68
- package/es/ellipsis/index.js.map +1 -1
- package/es/ellipsis/index.less +1 -1
- package/es/ellipsis/style/index.js +1 -0
- package/es/ellipsis/style/index.js.map +1 -0
- package/es/empty/empty.js +58 -48
- package/es/empty/empty.stories.js +5 -6
- package/es/empty/index.js +1 -2
- package/es/empty/render-empty.js +22 -0
- package/es/empty/render-empty.js.map +1 -0
- package/es/empty/style/index.js +2 -0
- package/es/empty/style/index.js.map +1 -0
- package/es/exception/exception.js +32 -19
- package/es/exception/index.js +1 -2
- package/es/form/index.js +1 -2
- package/es/handle/index.js +110 -71
- package/es/handle/style/index.js +1 -0
- package/es/handle/style/index.js.map +1 -0
- package/es/icon/index.js +1 -2
- package/es/icon-list/index.js +1 -120
- package/es/icon-list/style/index.js +1 -0
- package/es/icon-list/style/index.js.map +1 -0
- package/es/img/Contain.js +60 -39
- package/es/img/Cover.js +98 -72
- package/es/img/index.js +48 -32
- package/es/img/style/index.js +1 -0
- package/es/img/style/index.js.map +1 -0
- package/es/index.js +1 -2
- package/es/input/index.js +1 -2
- package/es/input-number/index.js +1 -2
- package/es/layout/index.js +1 -2
- package/es/list/index.js +1 -2
- package/es/loading-button/index.js +33 -28
- package/es/loading-button/style/index.js +1 -0
- package/es/loading-button/style/index.js.map +1 -0
- package/es/locale/default.js +3 -4
- package/es/locale/en_US.js +29 -30
- package/es/locale/index.js +1 -2
- package/es/locale/zh_CN.js +29 -30
- package/es/locale-provider/index.js +2 -3
- package/es/mention/index.js +1 -2
- package/es/mentions/index.js +1 -2
- package/es/menu/index.js +1 -2
- package/es/message/index.js +1 -2
- package/es/modal/index.js +1 -2
- package/es/modal/modal.js +20 -17
- package/es/notification/index.js +1 -2
- package/es/page/Box.js +49 -33
- package/es/page/index.js +119 -88
- package/es/page/index.js.map +1 -1
- package/es/page/style/index.js +1 -0
- package/es/page/style/index.js.map +1 -0
- package/es/page/utils.js +12 -14
- package/es/page-header/index.js +1 -2
- package/es/pagination/index.js +1 -2
- package/es/popconfirm/index.js +1 -2
- package/es/popover/index.js +1 -2
- package/es/prev-locale.js +49 -47
- package/es/progress/index.js +1 -2
- package/es/query-form/Field/Checkbox.js +20 -17
- package/es/query-form/Field/Select.js +54 -39
- package/es/query-form/Field/SelectInput.js +63 -45
- package/es/query-form/Field/fieldsMap.js +19 -20
- package/es/query-form/Field/index.js +104 -66
- package/es/query-form/createActions.js +46 -46
- package/es/query-form/index.js +327 -247
- package/es/query-form/index.js.map +1 -1
- package/es/query-form/style/index.js +1 -0
- package/es/query-form/style/index.js.map +1 -0
- package/es/query-form/useForm.js +3 -4
- package/es/query-list-scene/List.js +319 -257
- package/es/query-list-scene/List.js.map +1 -1
- package/es/query-list-scene/QueryForm.js +132 -94
- package/es/query-list-scene/QueryForm.js.map +1 -1
- package/es/query-list-scene/QueryListScene.js +29 -21
- package/es/query-list-scene/Title.js +6 -4
- package/es/query-list-scene/Toolbar.js +21 -15
- package/es/query-list-scene/createActions.js +60 -60
- package/es/query-list-scene/createActions.js.map +1 -1
- package/es/query-list-scene/index.js +1 -2
- package/es/query-list-scene/style/index.js +1 -0
- package/es/query-list-scene/style/index.js.map +1 -0
- package/es/query-list-scene/useActions.js +3 -4
- package/es/radio/index.js +1 -2
- package/es/rate/index.js +1 -2
- package/es/render-empty/index.js +1 -2
- package/es/render-empty/render-empty.js +19 -16
- package/es/render-empty/style/index.js +1 -0
- package/es/render-empty/style/index.js.map +1 -0
- package/es/result/index.js +1 -2
- package/es/row/index.js +1 -2
- package/es/select/index.js +1 -2
- package/es/skeleton/index.js +1 -2
- package/es/slider/index.js +1 -2
- package/es/spin/index.js +1 -2
- package/es/statistic/index.js +1 -2
- package/es/status/index.js +1 -0
- package/es/status/index.js.map +1 -0
- package/es/status/status.js +5 -0
- package/es/status/status.js.map +1 -0
- package/es/steps/index.js +1 -2
- package/es/steps/steps.js +51 -35
- package/es/svg-components/illustration-403.js +206 -58
- package/es/svg-components/illustration-404.js +290 -75
- package/es/svg-components/illustration-500.js +321 -83
- package/es/svg-components/illustration-empty.js +54 -15
- package/es/svg-components/illustration-failure.js +112 -36
- package/es/svg-components/illustration-no-access.js +114 -35
- package/es/svg-components/illustration-no-chart.js +134 -37
- package/es/svg-components/illustration-no-result.js +92 -32
- package/es/svg-components/illustration-offline.js +131 -43
- package/es/svg-components/illustration-success.js +137 -43
- package/es/svg-components/index.js +1 -2
- package/es/switch/index.js +1 -2
- package/es/table/assets/image-loading-background.js +45 -17
- package/es/table/assets/image-loading.js +26 -5
- package/es/table/constants.js +1 -2
- package/es/table/context.js +1 -2
- package/es/table/hooks/index.js +1 -2
- package/es/table/hooks/use-column-setting.js +13 -16
- package/es/table/index.js +1 -2
- package/es/table/style/index.js +2 -0
- package/es/table/style/index.js.map +1 -0
- package/es/table/table.js +76 -53
- package/es/table/table.stories.js +148 -139
- package/es/table/utils.js +17 -18
- package/es/tabs/index.js +1 -2
- package/es/tag/index.js +140 -3
- package/es/tag/index.js.map +1 -1
- package/es/tag/tag.less +46 -0
- package/es/time-picker/index.js +1 -2
- package/es/timeline/index.js +1 -2
- package/es/title/index.js +34 -20
- package/es/title/style/index.js +1 -0
- package/es/title/style/index.js.map +1 -0
- package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +9 -5
- package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +1 -2
- package/es/tntd-cascader/AntdCascader/component/SizeContext.js +1 -2
- package/es/tntd-cascader/AntdCascader/component/context.js +5 -7
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +22 -10
- package/es/tntd-cascader/AntdCascader/component/getIcons.js +72 -50
- package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +22 -20
- package/es/tntd-cascader/AntdCascader/config/utils.js +17 -18
- package/es/tntd-cascader/AntdCascader/config/warning.js +9 -10
- package/es/tntd-cascader/AntdCascader/index.js +189 -118
- package/es/tntd-cascader/AntdCascader/interface.js +1 -2
- package/es/tntd-cascader/index.js +1 -2
- package/es/tntd-cascader/rc-cascader/Cascader.js +256 -239
- package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +21 -11
- package/es/tntd-cascader/rc-cascader/OptionList/Column.js +175 -116
- package/es/tntd-cascader/rc-cascader/OptionList/index.js +180 -128
- package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +22 -19
- package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +144 -137
- package/es/tntd-cascader/rc-cascader/context.js +1 -2
- package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +44 -37
- package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +25 -24
- package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +15 -17
- package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +7 -8
- package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +20 -21
- package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +51 -41
- package/es/tntd-cascader/rc-cascader/index.js +1 -2
- package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +33 -27
- package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +29 -32
- package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +26 -23
- package/es/tntd-form/TntdForm/components/Item.js +42 -30
- package/es/tntd-form/TntdForm/components/ItemComp.js +167 -158
- package/es/tntd-form/TntdForm/components/List.js +89 -78
- package/es/tntd-form/TntdForm/index.js +38 -33
- package/es/tntd-form/TntdForm/interface.js +1 -2
- package/es/tntd-form/TntdForm/store.js +1 -2
- package/es/tntd-form/TntdForm/utils.js +158 -168
- package/es/tntd-form/index.js +1 -2
- package/es/tntd-icon/fonts/iconfont.js +36 -53
- package/es/tntd-icon/index.js +23 -17
- package/es/tntd-icon/style/index.js +1 -0
- package/es/tntd-icon/style/index.js.map +1 -0
- package/es/tntd-layout/ActionsContext.js +1 -2
- package/es/tntd-layout/AppList.js +135 -77
- package/es/tntd-layout/Application.js +42 -29
- package/es/tntd-layout/Avatar.js +80 -42
- package/es/tntd-layout/CompatibleLanguage.js +93 -56
- package/es/tntd-layout/EnterpriseLayout/Avatar.js +93 -47
- package/es/tntd-layout/EnterpriseLayout/Language.js +56 -34
- package/es/tntd-layout/EnterpriseLayout/Theme.js +45 -24
- package/es/tntd-layout/EnterpriseLayout/index.js +17 -9
- package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +212 -154
- package/es/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
- package/es/tntd-layout/GlobalNavigation/index.js +84 -50
- package/es/tntd-layout/Header.js +59 -26
- package/es/tntd-layout/HeaderActions.js +83 -34
- package/es/tntd-layout/HeaderNavs.js +46 -35
- package/es/tntd-layout/HeaderTabs.js +176 -140
- package/es/tntd-layout/Iconfont.js +1 -2
- package/es/tntd-layout/Language.js +55 -33
- package/es/tntd-layout/Layout.js +176 -78
- package/es/tntd-layout/Logo.js +52 -40
- package/es/tntd-layout/OrgAppList.js +208 -139
- package/es/tntd-layout/SideMenu.js +230 -160
- package/es/tntd-layout/Theme.js +47 -29
- package/es/tntd-layout/createActions.js +28 -29
- package/es/tntd-layout/images/index.js +31 -32
- package/es/tntd-layout/index.js +92 -60
- package/es/tntd-layout/paaslayout/CompactSideMenu.js +109 -65
- package/es/tntd-layout/paaslayout/Header.js +37 -14
- package/es/tntd-layout/paaslayout/Logo.js +2 -3
- package/es/tntd-layout/paaslayout/SideMenu.js +109 -63
- package/es/tntd-layout/paaslayout/index.js +159 -79
- package/es/tntd-layout/storage.js +18 -11
- package/es/tntd-layout/style/index.js +1 -0
- package/es/tntd-layout/style/index.js.map +1 -0
- package/es/tntd-modal/index.js +73 -32
- package/es/tntd-modal/style/index.js +1 -0
- package/es/tntd-modal/style/index.js.map +1 -0
- package/es/tntd-second-page/index.js +47 -24
- package/es/tntd-select/DropDownWrap.js +73 -52
- package/es/tntd-select/index.js +564 -482
- package/es/tntd-select/style/index.js +1 -0
- package/es/tntd-select/style/index.js.map +1 -0
- package/es/tooltip/index.js +1 -2
- package/es/transfer/index.js +1 -2
- package/es/tree/index.js +1 -2
- package/es/tree-select/index.js +1 -2
- package/es/typography/index.js +1 -2
- package/es/upload/index.js +1 -2
- package/es/utils/checkAuth.js +24 -21
- package/es/utils/findMenuInfoByPath.js +33 -30
- package/es/utils/index.js +65 -59
- package/es/version/index.js +1 -2
- package/lib/affix/index.d.ts +3 -3
- package/lib/affix/index.js +23 -22
- package/lib/affix/index.js.map +1 -1
- package/lib/alert/index.d.ts +3 -3
- package/lib/alert/index.js +23 -22
- package/lib/alert/index.js.map +1 -1
- package/lib/anchor/index.d.ts +3 -3
- package/lib/anchor/index.js +23 -22
- package/lib/anchor/index.js.map +1 -1
- package/lib/array-input/icon.js +33 -12
- package/lib/array-input/index.js +254 -150
- package/lib/array-input/style/index.d.ts +1 -0
- package/lib/array-input/style/index.d.ts.map +1 -0
- package/lib/array-input/style/index.js +1 -0
- package/lib/array-input/style/index.js.map +1 -0
- package/lib/auth-context/index.js +10 -4
- package/lib/auth-context/style/index.d.ts +1 -0
- package/lib/auth-context/style/index.d.ts.map +1 -0
- package/lib/auth-context/style/index.js +1 -0
- package/lib/auth-context/style/index.js.map +1 -0
- package/lib/auto-complete/index.d.ts +3 -3
- package/lib/auto-complete/index.js +23 -22
- package/lib/auto-complete/index.js.map +1 -1
- package/lib/avatar/index.d.ts +3 -3
- package/lib/avatar/index.js +23 -22
- package/lib/avatar/index.js.map +1 -1
- package/lib/back-top/index.d.ts +3 -3
- package/lib/back-top/index.js +23 -22
- package/lib/back-top/index.js.map +1 -1
- package/lib/badge/index.d.ts +3 -3
- package/lib/badge/index.js +23 -22
- package/lib/badge/index.js.map +1 -1
- package/lib/breadcrumb/index.d.ts +3 -3
- package/lib/breadcrumb/index.js +23 -22
- package/lib/breadcrumb/index.js.map +1 -1
- package/lib/button/index.d.ts +3 -3
- package/lib/button/index.js +23 -22
- package/lib/button/index.js.map +1 -1
- package/lib/calendar/index.d.ts +3 -3
- package/lib/calendar/index.js +23 -22
- package/lib/calendar/index.js.map +1 -1
- package/lib/card/index.d.ts +3 -3
- package/lib/card/index.js +23 -22
- package/lib/card/index.js.map +1 -1
- package/lib/carousel/index.d.ts +3 -3
- package/lib/carousel/index.js +23 -22
- package/lib/carousel/index.js.map +1 -1
- package/lib/cascader/index.d.ts +3 -3
- package/lib/cascader/index.js +23 -22
- package/lib/cascader/index.js.map +1 -1
- package/lib/checkbox/index.d.ts +3 -3
- package/lib/checkbox/index.js +23 -22
- package/lib/checkbox/index.js.map +1 -1
- package/lib/col/index.d.ts +3 -3
- package/lib/col/index.js +23 -22
- package/lib/col/index.js.map +1 -1
- package/lib/collapse/index.d.ts +3 -3
- package/lib/collapse/index.js +24 -23
- package/lib/collapse/index.js.map +1 -1
- package/lib/columns/index.js +81 -41
- package/lib/columns/style/index.js +1 -2
- package/lib/comment/index.d.ts +3 -3
- package/lib/comment/index.js +23 -22
- package/lib/comment/index.js.map +1 -1
- package/lib/config-provider/config-provider.d.ts +1 -1
- package/lib/config-provider/config-provider.js +12 -8
- package/lib/config-provider/config-provider.js.map +1 -1
- package/lib/config-provider/index.d.ts +3 -3
- package/lib/config-provider/index.js +23 -22
- package/lib/config-provider/index.js.map +1 -1
- package/lib/date-picker/index.d.ts +3 -3
- package/lib/date-picker/index.js +23 -22
- package/lib/date-picker/index.js.map +1 -1
- package/lib/descriptions/descriptions.d.ts +4 -4
- package/lib/descriptions/descriptions.d.ts.map +1 -1
- package/lib/descriptions/descriptions.js +64 -55
- package/lib/descriptions/descriptions.js.map +1 -1
- package/lib/descriptions/index.d.ts +1 -1
- package/lib/descriptions/index.js +23 -22
- package/lib/descriptions/index.js.map +1 -1
- package/lib/development-login/LoginModal.js +110 -79
- package/lib/development-login/index.js +42 -35
- package/lib/development-login/style/index.d.ts +1 -0
- package/lib/development-login/style/index.d.ts.map +1 -0
- package/lib/development-login/style/index.js +1 -0
- package/lib/development-login/style/index.js.map +1 -0
- package/lib/divider/index.d.ts +3 -3
- package/lib/divider/index.js +23 -22
- package/lib/divider/index.js.map +1 -1
- package/lib/drawer/drawer.d.ts +1 -1
- package/lib/drawer/drawer.js +41 -30
- package/lib/drawer/drawer.js.map +1 -1
- package/lib/drawer/index.d.ts +2 -2
- package/lib/drawer/index.js +22 -20
- package/lib/drawer/index.js.map +1 -1
- package/lib/dropdown/index.d.ts +3 -3
- package/lib/dropdown/index.js +23 -22
- package/lib/dropdown/index.js.map +1 -1
- package/lib/ellipsis/Svg/CopySVG.d.ts.map +1 -1
- package/lib/ellipsis/Svg/CopySVG.js +70 -21
- package/lib/ellipsis/Svg/CopySVG.js.map +1 -1
- package/lib/ellipsis/Svg/TickSVG.d.ts.map +1 -1
- package/lib/ellipsis/Svg/TickSVG.js +48 -16
- package/lib/ellipsis/Svg/TickSVG.js.map +1 -1
- package/lib/ellipsis/index.d.ts.map +1 -1
- package/lib/ellipsis/index.js +146 -105
- package/lib/ellipsis/index.js.map +1 -1
- package/lib/ellipsis/index.less +1 -1
- package/lib/ellipsis/style/index.d.ts +1 -0
- package/lib/ellipsis/style/index.d.ts.map +1 -0
- package/lib/ellipsis/style/index.js +1 -0
- package/lib/ellipsis/style/index.js.map +1 -0
- package/lib/empty/empty.d.ts +2 -2
- package/lib/empty/empty.js +90 -75
- package/lib/empty/empty.js.map +1 -1
- package/lib/empty/empty.stories.js +19 -18
- package/lib/empty/index.d.ts +1 -1
- package/lib/empty/index.js +20 -19
- package/lib/empty/index.js.map +1 -1
- package/lib/empty/render-empty.d.ts +3 -0
- package/lib/empty/render-empty.d.ts.map +1 -0
- package/lib/empty/render-empty.js +32 -0
- package/lib/empty/render-empty.js.map +1 -0
- package/lib/empty/style/index.d.ts +3 -0
- package/lib/empty/style/index.d.ts.map +1 -0
- package/lib/empty/style/index.js +4 -0
- package/lib/empty/style/index.js.map +1 -0
- package/lib/exception/exception.js +46 -31
- package/lib/exception/exception.js.map +1 -1
- package/lib/exception/index.js +19 -18
- package/lib/form/index.d.ts +3 -3
- package/lib/form/index.js +23 -22
- package/lib/form/index.js.map +1 -1
- package/lib/handle/index.js +140 -104
- package/lib/handle/index.js.map +1 -1
- package/lib/handle/style/index.d.ts +1 -0
- package/lib/handle/style/index.d.ts.map +1 -0
- package/lib/handle/style/index.js +1 -0
- package/lib/handle/style/index.js.map +1 -0
- package/lib/icon/index.d.ts +3 -3
- package/lib/icon/index.js +23 -22
- package/lib/icon/index.js.map +1 -1
- package/lib/icon-list/index.js +7 -121
- package/lib/icon-list/style/index.d.ts +3 -0
- package/lib/icon-list/style/index.d.ts.map +1 -0
- package/lib/icon-list/style/index.js +8 -0
- package/lib/icon-list/style/index.js.map +1 -0
- package/lib/img/Contain.js +69 -44
- package/lib/img/Cover.js +117 -78
- package/lib/img/index.js +74 -60
- package/lib/img/style/index.d.ts +1 -0
- package/lib/img/style/index.d.ts.map +1 -0
- package/lib/img/style/index.js +1 -0
- package/lib/img/style/index.js.map +1 -0
- package/lib/index.js +614 -184
- package/lib/input/index.d.ts +3 -3
- package/lib/input/index.js +23 -22
- package/lib/input/index.js.map +1 -1
- package/lib/input-number/index.d.ts +3 -3
- package/lib/input-number/index.js +23 -22
- package/lib/input-number/index.js.map +1 -1
- package/lib/layout/index.d.ts +3 -3
- package/lib/layout/index.js +23 -22
- package/lib/layout/index.js.map +1 -1
- package/lib/list/index.d.ts +3 -3
- package/lib/list/index.js +23 -22
- package/lib/list/index.js.map +1 -1
- package/lib/loading-button/index.js +58 -55
- package/lib/loading-button/style/index.d.ts +1 -0
- package/lib/loading-button/style/index.d.ts.map +1 -0
- package/lib/loading-button/style/index.js +1 -0
- package/lib/loading-button/style/index.js.map +1 -0
- package/lib/locale/default.js +12 -10
- package/lib/locale/default.js.map +1 -1
- package/lib/locale/en_US.js +37 -35
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/index.js +36 -18
- package/lib/locale/zh_CN.js +37 -35
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/locale-provider/index.d.ts +3 -3
- package/lib/locale-provider/index.js +26 -25
- package/lib/locale-provider/index.js.map +1 -1
- package/lib/mention/index.d.ts +3 -3
- package/lib/mention/index.js +23 -22
- package/lib/mention/index.js.map +1 -1
- package/lib/mentions/index.d.ts +3 -3
- package/lib/mentions/index.js +23 -22
- package/lib/mentions/index.js.map +1 -1
- package/lib/menu/index.d.ts +3 -3
- package/lib/menu/index.js +23 -22
- package/lib/menu/index.js.map +1 -1
- package/lib/message/index.d.ts +3 -3
- package/lib/message/index.js +23 -22
- package/lib/message/index.js.map +1 -1
- package/lib/modal/index.d.ts +1 -1
- package/lib/modal/index.js +22 -21
- package/lib/modal/index.js.map +1 -1
- package/lib/modal/modal.d.ts +9 -9
- package/lib/modal/modal.js +53 -49
- package/lib/modal/modal.js.map +1 -1
- package/lib/notification/index.d.ts +3 -3
- package/lib/notification/index.js +23 -22
- package/lib/notification/index.js.map +1 -1
- package/lib/page/Box.js +66 -40
- package/lib/page/index.d.ts.map +1 -1
- package/lib/page/index.js +147 -99
- package/lib/page/index.js.map +1 -1
- package/lib/page/style/index.d.ts +1 -0
- package/lib/page/style/index.d.ts.map +1 -0
- package/lib/page/style/index.js +1 -0
- package/lib/page/style/index.js.map +1 -0
- package/lib/page/utils.js +22 -16
- package/lib/page-header/index.d.ts +3 -3
- package/lib/page-header/index.js +23 -22
- package/lib/page-header/index.js.map +1 -1
- package/lib/pagination/index.d.ts +3 -3
- package/lib/pagination/index.js +23 -22
- package/lib/pagination/index.js.map +1 -1
- package/lib/popconfirm/index.d.ts +3 -3
- package/lib/popconfirm/index.js +23 -22
- package/lib/popconfirm/index.js.map +1 -1
- package/lib/popover/index.d.ts +3 -3
- package/lib/popover/index.js +23 -22
- package/lib/popover/index.js.map +1 -1
- package/lib/prev-locale.js +67 -53
- package/lib/progress/index.d.ts +3 -3
- package/lib/progress/index.js +23 -22
- package/lib/progress/index.js.map +1 -1
- package/lib/query-form/Field/Checkbox.js +28 -22
- package/lib/query-form/Field/Select.js +79 -68
- package/lib/query-form/Field/SelectInput.js +85 -73
- package/lib/query-form/Field/fieldsMap.d.ts +2 -2
- package/lib/query-form/Field/fieldsMap.js +34 -32
- package/lib/query-form/Field/index.js +139 -95
- package/lib/query-form/createActions.js +53 -50
- package/lib/query-form/index.js +377 -286
- package/lib/query-form/index.js.map +1 -1
- package/lib/query-form/style/index.d.ts +1 -0
- package/lib/query-form/style/index.d.ts.map +1 -0
- package/lib/query-form/style/index.js +1 -0
- package/lib/query-form/style/index.js.map +1 -0
- package/lib/query-form/useForm.js +11 -11
- package/lib/query-list-scene/List.d.ts.map +1 -1
- package/lib/query-list-scene/List.js +358 -291
- package/lib/query-list-scene/List.js.map +1 -1
- package/lib/query-list-scene/QueryForm.js +161 -103
- package/lib/query-list-scene/QueryForm.js.map +1 -1
- package/lib/query-list-scene/QueryListScene.js +66 -31
- package/lib/query-list-scene/Title.js +15 -9
- package/lib/query-list-scene/Toolbar.js +31 -20
- package/lib/query-list-scene/createActions.js +79 -64
- package/lib/query-list-scene/createActions.js.map +1 -1
- package/lib/query-list-scene/index.js +28 -24
- package/lib/query-list-scene/style/index.d.ts +1 -0
- package/lib/query-list-scene/style/index.d.ts.map +1 -0
- package/lib/query-list-scene/style/index.js +1 -0
- package/lib/query-list-scene/style/index.js.map +1 -0
- package/lib/query-list-scene/useActions.js +11 -11
- package/lib/radio/index.d.ts +3 -3
- package/lib/radio/index.js +23 -22
- package/lib/radio/index.js.map +1 -1
- package/lib/rate/index.d.ts +3 -3
- package/lib/rate/index.js +23 -22
- package/lib/rate/index.js.map +1 -1
- package/lib/render-empty/index.js +8 -4
- package/lib/render-empty/render-empty.js +28 -22
- package/lib/render-empty/render-empty.js.map +1 -1
- package/lib/render-empty/style/index.d.ts +2 -0
- package/lib/render-empty/style/index.d.ts.map +1 -0
- package/lib/render-empty/style/index.js +3 -0
- package/lib/render-empty/style/index.js.map +1 -0
- package/lib/result/index.d.ts +3 -3
- package/lib/result/index.js +23 -22
- package/lib/result/index.js.map +1 -1
- package/lib/row/index.d.ts +3 -3
- package/lib/row/index.js +23 -22
- package/lib/row/index.js.map +1 -1
- package/lib/select/index.d.ts +3 -3
- package/lib/select/index.js +23 -22
- package/lib/select/index.js.map +1 -1
- package/lib/skeleton/index.d.ts +3 -3
- package/lib/skeleton/index.js +23 -22
- package/lib/skeleton/index.js.map +1 -1
- package/lib/slider/index.d.ts +3 -3
- package/lib/slider/index.js +23 -22
- package/lib/slider/index.js.map +1 -1
- package/lib/spin/index.d.ts +3 -3
- package/lib/spin/index.js +23 -22
- package/lib/spin/index.js.map +1 -1
- package/lib/statistic/index.d.ts +3 -3
- package/lib/statistic/index.js +23 -22
- package/lib/statistic/index.js.map +1 -1
- package/lib/status/index.d.ts +2 -0
- package/lib/status/index.d.ts.map +1 -0
- package/lib/status/index.js +16 -0
- package/lib/status/index.js.map +1 -0
- package/lib/status/status.d.ts +6 -0
- package/lib/status/status.d.ts.map +1 -0
- package/lib/status/status.js +13 -0
- package/lib/status/status.js.map +1 -0
- package/lib/steps/index.d.ts +1 -1
- package/lib/steps/index.js +20 -19
- package/lib/steps/index.js.map +1 -1
- package/lib/steps/steps.d.ts +3 -3
- package/lib/steps/steps.js +72 -59
- package/lib/steps/steps.js.map +1 -1
- package/lib/svg-components/illustration-403.d.ts +1 -1
- package/lib/svg-components/illustration-403.js +217 -84
- package/lib/svg-components/illustration-404.d.ts +1 -1
- package/lib/svg-components/illustration-404.js +301 -101
- package/lib/svg-components/illustration-500.d.ts +1 -1
- package/lib/svg-components/illustration-500.js +332 -109
- package/lib/svg-components/illustration-empty.d.ts +1 -1
- package/lib/svg-components/illustration-empty.js +65 -41
- package/lib/svg-components/illustration-failure.d.ts +1 -1
- package/lib/svg-components/illustration-failure.js +123 -62
- package/lib/svg-components/illustration-no-access.d.ts +1 -1
- package/lib/svg-components/illustration-no-access.js +125 -61
- package/lib/svg-components/illustration-no-chart.d.ts +1 -1
- package/lib/svg-components/illustration-no-chart.js +145 -63
- package/lib/svg-components/illustration-no-result.d.ts +1 -1
- package/lib/svg-components/illustration-no-result.js +103 -58
- package/lib/svg-components/illustration-offline.d.ts +1 -1
- package/lib/svg-components/illustration-offline.js +142 -69
- package/lib/svg-components/illustration-success.d.ts +1 -1
- package/lib/svg-components/illustration-success.js +148 -69
- package/lib/svg-components/index.js +75 -26
- package/lib/switch/index.d.ts +3 -3
- package/lib/switch/index.js +23 -22
- package/lib/switch/index.js.map +1 -1
- package/lib/table/assets/image-loading-background.d.ts +1 -1
- package/lib/table/assets/image-loading-background.js +56 -43
- package/lib/table/assets/image-loading.d.ts +1 -1
- package/lib/table/assets/image-loading.js +37 -31
- package/lib/table/constants.js +6 -3
- package/lib/table/context.js +7 -4
- package/lib/table/hooks/index.js +14 -16
- package/lib/table/hooks/use-column-setting.d.ts +1 -1
- package/lib/table/hooks/use-column-setting.js +37 -20
- package/lib/table/hooks/use-column-setting.js.map +1 -1
- package/lib/table/index.d.ts +1 -1
- package/lib/table/index.js +20 -19
- package/lib/table/index.js.map +1 -1
- package/lib/table/style/index.d.ts +3 -0
- package/lib/table/style/index.d.ts.map +1 -0
- package/lib/table/style/index.js +4 -0
- package/lib/table/style/index.js.map +1 -0
- package/lib/table/table.d.ts +3 -3
- package/lib/table/table.js +110 -92
- package/lib/table/table.js.map +1 -1
- package/lib/table/table.stories.js +182 -154
- package/lib/table/utils.d.ts +1 -1
- package/lib/table/utils.js +24 -25
- package/lib/table/utils.js.map +1 -1
- package/lib/tabs/index.d.ts +3 -3
- package/lib/tabs/index.js +23 -22
- package/lib/tabs/index.js.map +1 -1
- package/lib/tag/index.d.ts +52 -3
- package/lib/tag/index.d.ts.map +1 -1
- package/lib/tag/index.js +162 -20
- package/lib/tag/index.js.map +1 -1
- package/lib/tag/tag.less +46 -0
- package/lib/time-picker/index.d.ts +3 -3
- package/lib/time-picker/index.js +23 -22
- package/lib/time-picker/index.js.map +1 -1
- package/lib/timeline/index.d.ts +3 -3
- package/lib/timeline/index.js +23 -22
- package/lib/timeline/index.js.map +1 -1
- package/lib/title/index.js +45 -26
- package/lib/title/style/index.d.ts +1 -0
- package/lib/title/style/index.d.ts.map +1 -0
- package/lib/title/style/index.js +1 -0
- package/lib/title/style/index.js.map +1 -0
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +18 -31
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +9 -26
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +9 -26
- package/lib/tntd-cascader/AntdCascader/component/context.js +18 -16
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +36 -39
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
- package/lib/tntd-cascader/AntdCascader/component/getIcons.js +81 -75
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +31 -50
- package/lib/tntd-cascader/AntdCascader/config/utils.js +29 -27
- package/lib/tntd-cascader/AntdCascader/config/warning.js +19 -35
- package/lib/tntd-cascader/AntdCascader/index.js +216 -162
- package/lib/tntd-cascader/AntdCascader/interface.js +13 -6
- package/lib/tntd-cascader/img/no-data-s.png +0 -0
- package/lib/tntd-cascader/index.js +12 -8
- package/lib/tntd-cascader/rc-cascader/Cascader.js +325 -284
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +30 -41
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +198 -152
- package/lib/tntd-cascader/rc-cascader/OptionList/index.js +223 -163
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +40 -48
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +179 -166
- package/lib/tntd-cascader/rc-cascader/context.js +11 -27
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +62 -63
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +39 -49
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +26 -41
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +16 -33
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +30 -51
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +75 -65
- package/lib/tntd-cascader/rc-cascader/index.js +9 -7
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +49 -38
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +42 -39
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +34 -30
- package/lib/tntd-form/TntdForm/components/Item.js +55 -61
- package/lib/tntd-form/TntdForm/components/ItemComp.js +203 -190
- package/lib/tntd-form/TntdForm/components/List.js +118 -111
- package/lib/tntd-form/TntdForm/index.js +61 -67
- package/lib/tntd-form/TntdForm/interface.js +4 -2
- package/lib/tntd-form/TntdForm/store.js +8 -7
- package/lib/tntd-form/TntdForm/utils.js +182 -184
- package/lib/tntd-form/index.js +12 -8
- package/lib/tntd-icon/fonts/iconfont.js +36 -53
- package/lib/tntd-icon/index.js +40 -25
- package/lib/tntd-icon/style/index.d.ts +1 -0
- package/lib/tntd-icon/style/index.d.ts.map +1 -0
- package/lib/tntd-icon/style/index.js +1 -0
- package/lib/tntd-icon/style/index.js.map +1 -0
- package/lib/tntd-layout/ActionsContext.js +8 -4
- package/lib/tntd-layout/AppList.js +173 -224
- package/lib/tntd-layout/Application.js +75 -111
- package/lib/tntd-layout/Avatar.js +100 -135
- package/lib/tntd-layout/CompatibleLanguage.js +128 -180
- package/lib/tntd-layout/EnterpriseLayout/Avatar.js +117 -146
- package/lib/tntd-layout/EnterpriseLayout/Language.js +73 -90
- package/lib/tntd-layout/EnterpriseLayout/Theme.js +69 -102
- package/lib/tntd-layout/EnterpriseLayout/index.js +28 -17
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.d.ts.map +1 -1
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +283 -277
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
- package/lib/tntd-layout/GlobalNavigation/index.js +108 -115
- package/lib/tntd-layout/Header.js +77 -136
- package/lib/tntd-layout/HeaderActions.js +105 -106
- package/lib/tntd-layout/HeaderNavs.js +78 -107
- package/lib/tntd-layout/HeaderTabs.js +224 -316
- package/lib/tntd-layout/Iconfont.js +11 -7
- package/lib/tntd-layout/Language.js +69 -76
- package/lib/tntd-layout/Layout.js +214 -171
- package/lib/tntd-layout/Logo.js +69 -144
- package/lib/tntd-layout/OrgAppList.js +238 -388
- package/lib/tntd-layout/SideMenu.js +269 -408
- package/lib/tntd-layout/Theme.js +75 -93
- package/lib/tntd-layout/createActions.js +45 -34
- package/lib/tntd-layout/images/avatar/empty.png +0 -0
- package/lib/tntd-layout/images/avatar/female1.png +0 -0
- package/lib/tntd-layout/images/avatar/female2.png +0 -0
- package/lib/tntd-layout/images/avatar/female3.png +0 -0
- package/lib/tntd-layout/images/avatar/female4.png +0 -0
- package/lib/tntd-layout/images/avatar/female5.png +0 -0
- package/lib/tntd-layout/images/avatar/female6.png +0 -0
- package/lib/tntd-layout/images/avatar/male1.png +0 -0
- package/lib/tntd-layout/images/avatar/male2.png +0 -0
- package/lib/tntd-layout/images/avatar/male3.png +0 -0
- package/lib/tntd-layout/images/avatar/male4.png +0 -0
- package/lib/tntd-layout/images/avatar/male5.png +0 -0
- package/lib/tntd-layout/images/avatar/male6.png +0 -0
- package/lib/tntd-layout/images/index.js +68 -66
- package/lib/tntd-layout/index.js +137 -95
- package/lib/tntd-layout/paaslayout/CompactSideMenu.js +131 -182
- package/lib/tntd-layout/paaslayout/Header.js +51 -79
- package/lib/tntd-layout/paaslayout/Logo.js +15 -30
- package/lib/tntd-layout/paaslayout/SideMenu.js +131 -147
- package/lib/tntd-layout/paaslayout/index.js +205 -141
- package/lib/tntd-layout/storage.js +58 -30
- package/lib/tntd-layout/style/index.d.ts +1 -0
- package/lib/tntd-layout/style/index.d.ts.map +1 -0
- package/lib/tntd-layout/style/index.js +1 -0
- package/lib/tntd-layout/style/index.js.map +1 -0
- package/lib/tntd-modal/index.js +98 -62
- package/lib/tntd-modal/style/index.d.ts +1 -0
- package/lib/tntd-modal/style/index.d.ts.map +1 -0
- package/lib/tntd-modal/style/index.js +1 -0
- package/lib/tntd-modal/style/index.js.map +1 -0
- package/lib/tntd-second-page/index.js +60 -33
- package/lib/tntd-second-page/index.js.map +1 -1
- package/lib/tntd-select/DropDownWrap.js +102 -78
- package/lib/tntd-select/index.d.ts +3 -2
- package/lib/tntd-select/index.d.ts.map +1 -1
- package/lib/tntd-select/index.js +607 -519
- package/lib/tntd-select/style/index.d.ts +1 -0
- package/lib/tntd-select/style/index.d.ts.map +1 -0
- package/lib/tntd-select/style/index.js +1 -0
- package/lib/tntd-select/style/index.js.map +1 -0
- package/lib/tooltip/index.d.ts +3 -3
- package/lib/tooltip/index.js +23 -22
- package/lib/tooltip/index.js.map +1 -1
- package/lib/transfer/index.d.ts +3 -3
- package/lib/transfer/index.js +23 -22
- package/lib/transfer/index.js.map +1 -1
- package/lib/tree/index.d.ts +3 -3
- package/lib/tree/index.js +23 -22
- package/lib/tree/index.js.map +1 -1
- package/lib/tree-select/index.d.ts +3 -3
- package/lib/tree-select/index.js +23 -22
- package/lib/tree-select/index.js.map +1 -1
- package/lib/typography/index.d.ts +3 -3
- package/lib/typography/index.js +23 -22
- package/lib/typography/index.js.map +1 -1
- package/lib/upload/index.d.ts +3 -3
- package/lib/upload/index.js +23 -22
- package/lib/upload/index.js.map +1 -1
- package/lib/utils/checkAuth.js +34 -23
- package/lib/utils/findMenuInfoByPath.js +41 -34
- package/lib/utils/index.js +117 -80
- package/lib/version/index.d.ts +3 -3
- package/lib/version/index.js +23 -22
- package/lib/version/index.js.map +1 -1
- package/package.json +3 -2
- 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: ${
|
|
12
|
+
color: ${props => props.theme.secondaryTextColor};
|
|
13
13
|
&.active {
|
|
14
|
-
color: ${
|
|
14
|
+
color: ${props => props.theme.primaryColor};
|
|
15
15
|
input {
|
|
16
|
-
border-color: ${
|
|
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: ${
|
|
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 ${
|
|
44
|
-
color: ${
|
|
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 ${
|
|
55
|
+
border-right: 1px solid ${props => props.theme.borderColor};
|
|
56
56
|
}
|
|
57
57
|
&.active {
|
|
58
|
-
background-color: ${
|
|
58
|
+
background-color: ${props => props.theme.primaryColor};
|
|
59
59
|
color: #fff;
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
62
|
`;
|
|
63
|
-
const GroupMenus = styled.div
|
|
64
|
-
height: ${
|
|
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: ${
|
|
92
|
+
color: ${props => props.theme.secondaryTextColor};
|
|
93
93
|
&:hover {
|
|
94
|
-
color: ${
|
|
94
|
+
color: ${props => props.theme.secondaryColor} !important;
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
97
|
&.active a {
|
|
98
|
-
color: ${
|
|
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: ${
|
|
118
|
+
color: ${props => props.theme.primaryTextColor};
|
|
119
119
|
&:hover {
|
|
120
|
-
color: ${
|
|
121
|
-
background-color: ${
|
|
120
|
+
color: ${props => props.theme.secondaryColor};
|
|
121
|
+
background-color: ${props => props.theme.lightBgColor};
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
`;
|
|
125
|
-
const SearchList = ({
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
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
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
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
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
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":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAClD,OAAO,EAAE,MAAM,YAAY,CAAA;AAC3B,OAAO,MAAM,MAAM,mBAAmB,CAAA;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACjC,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACrD,OAAO,IAAI,MAAM,aAAa,CAAA;AAC9B,OAAwB,cAAc,CAAA;AAEtC,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAA;;;;WAIlB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB;;aAEvC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;sBAE1B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;;;;;;;;;;;;;;;oBAkBrC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW;;;;;;;CAOrD,CAAA;AAED,MAAM,eAAe,GAAG,MAAM,CAAC,EAAE,CAAA;sBACX,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW;WAC7C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,gBAAgB;;;;;;;;;;;gCAWlB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW;;;0BAGxC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;;CAI5D,CAAA;AAED,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAA;YACjB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,mBAAmB,CAAC;;;;;;;;CAQlF,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;CAO/B,CAAA;AAED,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAA;;;;CAIzB,CAAA;AAED,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAA;;;;;;aAMb,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB;;eAEvC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,cAAc;;;;aAIvC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;CAE/C,CAAA;AAED,MAAM,OAAO,GAAG,MAAM,CAAC,EAAE,CAAA;;;;;;;;;;;;;;;;;aAiBZ,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,gBAAgB;;eAErC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,cAAc;0BAC1B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY;;;CAG5D,CAAA;AAED,MAAM,UAAU,GAAG,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CACrD,oBAAC,OAAO,IAAC,KAAK,EAAE,KAAK,IAClB,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACpB,4BAAI,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAG,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,QAAQ,CAAM,CAC7D,CAAC,CACM,CACX,CAAA;AAED,eAAe,CAAC,EAAE,KAAK,EAAE,KAAK,GAAG,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE,EAAE;IAC/E,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC3C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,EAAE,CAAA;IAChD,MAAM,QAAQ,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,WAAW,EAAE,CAAA;IACvC,MAAM,QAAQ,GAAG,SAAS,CAAC,KAAK,CAAC,CAAA;IACjC,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IAChF,MAAM,eAAe,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAA;IACpD,MAAM,cAAc,GAAG,CAAC,KAAK,EAAE,EAAE;QAC/B,KAAK,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;;YACjC,KAAK;YACL,IAAI,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,QAAQ,0CAAE,MAAM,EAAE;gBACzB,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;aACd;iBAAM;gBACL,MAAM,YAAY,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,cAAc,CAAC,CAAA;gBACrE,IAAI,CAAC,YAAY,EAAE;oBACjB,GAAG,CAAC,OAAO,CAAC;wBACV,cAAc,EAAE,IAAI;wBACpB,QAAQ,EAAE,CAAC,GAAG,CAAC;qBAChB,CAAC,CAAA;iBACH;qBAAM;oBACL,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;iBAChC;aACF;YACD,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAE,CAAC,CAAA;QAEN,OAAO,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;YAE7E,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE;gBACf,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA;aAChB;iBAAM;gBACL,MAAM,eAAe,GAAG,CAAC,KAAK,EAAE,EAAE,WAAC,OAAA,EAAE,GAAG,CAAC,CAAA,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,0CAAE,MAAM,KAAI,CAAC,CAAC,GAAG,EAAE,CAAA,EAAA,CAAA;gBAC3E,MAAM,gBAAgB,GAAG,CAAC,YAAY,EAAE,EAAE,CACxC,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;oBAChC,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAA;oBAC3B,OAAO,GAAG,CAAA;gBACZ,CAAC,EAAE,CAAC,CAAC,CAAA;gBACP,MAAM,mBAAmB,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAA;gBACjE,MAAM,eAAe,GAAG,eAAe,CAAC,GAAG,CAAC,CAAA;gBAC5C,MAAM,kBAAkB,GAAG,CAAC,MAAM,EAAE,EAAE;oBACpC,IAAI,SAAS,GAAG,QAAQ,CAAA;oBACxB,IAAI,KAAK,GAAG,CAAC,CAAA;oBAEb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,MAAM,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;wBAC1C,IAAI,MAAM,GAAG,SAAS,EAAE;4BACtB,KAAK,GAAG,CAAC,CAAA;4BACT,SAAS,GAAG,MAAM,CAAA;yBACnB;qBACF;oBAED,OAAO,MAAM,CAAC,KAAK,CAAC,CAAA;gBACtB,CAAC,CAAA;gBAED,IAAI,GAAG,CAAC,MAAM,IAAI,MAAM,EAAE;oBACxB,MAAM,cAAc,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;oBAC9C,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,IAAI,CAAC,GAAG,CAAC,CAAA;iBAC1B;qBAAM;oBACL,IAAI,mBAAmB,GAAG,eAAe,GAAG,GAAG,EAAE;wBAC/C,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA;qBAChB;yBAAM;wBACL,MAAA,GAAG,CAAC,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,IAAG,CAAC,CAAC,0CAAE,IAAI,CAAC,GAAG,CAAC,CAAA;qBAChC;iBACF;aACF;YAED,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC,CAAA;IACD,MAAM,UAAU,GAAG,cAAc,CAAC,CAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,QAAQ,KAAI,KAAK,CAAC,CAAA;IACnE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAEtD,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,EAAE;QAC3B,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAA;QAC1D,cAAc,CAAC,EAAE,CAAC,CAAA;QAClB,gBAAgB,CAAC,EAAE,CAAC,CAAA;QACpB,KAAK,EAAE,CAAA;IACT,CAAC,CAAA;IACD,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE;;QACtC,MAAM,KAAK,GAAG,MAAA,GAAG,CAAC,MAAM,CAAC,KAAK,0CAAE,IAAI,EAAE,CAAA;QACtC,MAAM,YAAY,GAAG,EAAE,CAAA;QAEvB,IAAI,KAAK,EAAE;YACT,YAAY,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,EAAE;;gBAC3B,IAAI,IAAI,CAAC,IAAI,KAAI,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,QAAQ,0CAAE,QAAQ,CAAC,KAAK,CAAC,CAAA,EAAE;oBAChD,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;iBACxB;YACH,CAAC,CAAC,CAAA;SACH;QAED,gBAAgB,CAAC,YAAY,CAAC,CAAA;IAChC,CAAC,EAAE,GAAG,CAAC,CAAA;IAEP,MAAM,cAAc,GAAG,CAAC,GAAG,EAAE,EAAE;QAC7B,GAAG,CAAC,OAAO,EAAE,CAAA;QACb,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAChC,cAAc,CAAC,GAAG,CAAC,CAAA;IACrB,CAAC,CAAA;IAED,MAAM,cAAc,GAAG,CAAC,IAAI,EAAE,EAAE;QAC9B,gBAAgB,CAAC,IAAI,CAAC,CAAA;IACxB,CAAC,CAAA;IAED,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,YAAY,GAAG,CAAC,GAAG,EAAE,EAAE;YAC3B,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,GAAG,CAAA;YAC9C,MAAM,SAAS,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;gBAC/B,IAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,EAAE;oBACnB,OAAO,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA,CAAA;iBACpC;gBAED,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,qBAAqB,EAAE,CAAA;gBAC3D,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAA;gBAC1E,CAAC,IAAI,MAAM,CAAC,OAAO,CAAA;gBACnB,CAAC,IAAI,MAAM,CAAC,OAAO,CAAA;gBAEnB,OAAO,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,CAAC,GAAG,KAAK,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,CAAC,GAAG,MAAM,CAAA;YAC1E,CAAC,CAAA;YAED,IAAI,SAAS,CAAC,GAAG,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE;gBACpC,cAAc,CAAC,EAAE,CAAC,CAAA;gBAClB,gBAAgB,CAAC,EAAE,CAAC,CAAA;gBACpB,KAAK,EAAE,CAAA;aACR;QACH,CAAC,CAAA;QAED,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAA;QAChD,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAA;IAClE,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL;QACE,oBAAC,UAAU,IAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC;YACjD,oBAAC,IAAI,IAAC,IAAI,EAAC,QAAQ,GAAG;YACtB,+BACE,WAAW,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,CAAC,YAAY,CAAC,EAC3C,KAAK,EAAE,WAAW,EAClB,QAAQ,EAAE,cAAc,EACxB,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAC9B,MAAM,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,GAC9B;YACF,oBAAC,IAAI,IAAC,IAAI,EAAC,OAAO,EAAC,OAAO,EAAE,KAAK,GAAI;YACpC,CAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,MAAM,IAAG,CAAC,IAAI,CAC5B,oBAAC,UAAU,IAAC,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,WAAW,GAAI,CAC9E,CACU;QACZ,QAAQ,IAAI,CACX,oBAAC,eAAe,IAAC,KAAK,EAAE,KAAK,IAC1B,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACpB,4BACE,SAAS,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,MAAK,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,IAAI,CAAA,EAAE,CAAC,EAC5D,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,IAElC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,CAChD,CACN,CAAC,CACc,CACnB;QACD,oBAAC,UAAU,IAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,IACzC,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAC3B,iCACG,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACtB,oBAAC,aAAa,IAAC,KAAK,EAAE,KAAK;YACzB,gCAAK,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAM;YAC9D,oBAAC,QAAQ,QACN,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACpC,oBAAC,QAAQ,IACP,GAAG,EAAE,IAAI,CAAC,IAAI,EACd,SAAS,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC,EACxD,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC;gBAEhC,2BAAG,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,cAAc,EAAE,IACvD,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAChD,CACK,CACZ,CAAC,CACO,CACG,CACjB,CAAC,CACE,CACP,CAAC,CACS,CACZ,CACJ,CAAA;AACH,CAAC,CAAA","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"]}
|