tntd 2.1.1 → 2.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/affix/index.js +2 -1
- package/es/alert/index.js +2 -1
- package/es/anchor/index.js +2 -1
- package/es/array-input/icon.js +6 -24
- package/es/array-input/index.js +119 -203
- package/es/auth-context/index.js +2 -1
- package/es/auto-complete/index.js +2 -1
- package/es/avatar/index.js +2 -1
- package/es/back-top/index.js +2 -1
- package/es/badge/index.js +2 -1
- package/es/breadcrumb/index.js +2 -1
- package/es/button/index.js +2 -1
- package/es/calendar/index.js +2 -1
- package/es/card/index.js +2 -1
- package/es/carousel/index.js +2 -1
- package/es/cascader/index.js +2 -1
- package/es/checkbox/index.js +2 -1
- package/es/col/index.js +2 -1
- package/es/collapse/index.js +2 -1
- package/es/color-picker/ColorPicker.js +90 -0
- package/es/color-picker/ColorPicker.js.map +1 -0
- package/es/color-picker/index.js +11 -0
- package/es/color-picker/index.js.map +1 -0
- package/es/color-picker/index.less +234 -0
- package/es/color-picker/tip.svg +23 -0
- package/es/columns/index.js +30 -66
- package/es/columns/style/index.js +2 -1
- package/es/comment/index.js +2 -1
- package/es/config-provider/config-provider.js +2 -1
- package/es/config-provider/index.js +2 -1
- package/es/date-picker/index.js +2 -1
- package/es/descriptions/descriptions.js +30 -38
- package/es/descriptions/index.js +2 -1
- package/es/development-login/LoginModal.js +46 -81
- package/es/development-login/index.js +8 -17
- package/es/divider/index.js +2 -1
- package/es/drawer/drawer.js +20 -27
- package/es/drawer/index.js +2 -1
- package/es/dropdown/index.js +2 -1
- package/es/ellipsis/Svg/CopySVG.js +16 -63
- package/es/ellipsis/Svg/CopySVG.js.map +1 -1
- package/es/ellipsis/Svg/TickSVG.js +11 -41
- package/es/ellipsis/Svg/TickSVG.js.map +1 -1
- package/es/ellipsis/index.js +78 -100
- package/es/ellipsis/index.js.map +1 -1
- package/es/ellipsis/index.less +1 -1
- package/es/empty/empty.js +48 -58
- package/es/empty/empty.stories.js +6 -5
- package/es/empty/index.js +2 -1
- package/es/exception/exception.js +19 -32
- package/es/exception/index.js +2 -1
- package/es/form/index.js +2 -1
- package/es/handle/index.js +71 -110
- package/es/icon/index.js +2 -1
- package/es/icon-list/index.js +120 -1
- package/es/img/Contain.js +39 -60
- package/es/img/Cover.js +72 -98
- package/es/img/index.js +32 -48
- package/es/index.js +3 -1
- package/es/index.js.map +1 -1
- package/es/input/index.js +2 -1
- package/es/input-number/index.js +2 -1
- package/es/layout/index.js +2 -1
- package/es/list/index.js +2 -1
- package/es/loading-button/index.js +28 -33
- package/es/locale/default.js +4 -3
- package/es/locale/en_US.js +31 -29
- package/es/locale/en_US.js.map +1 -1
- package/es/locale/index.js +2 -1
- package/es/locale/zh_CN.js +31 -29
- package/es/locale/zh_CN.js.map +1 -1
- package/es/locale-provider/index.js +3 -2
- package/es/mention/index.js +2 -1
- package/es/mentions/index.js +2 -1
- package/es/menu/index.js +2 -1
- package/es/message/index.js +2 -1
- package/es/modal/index.js +2 -1
- package/es/modal/modal.js +17 -20
- package/es/notification/index.js +2 -1
- package/es/page/Box.js +33 -49
- package/es/page/index.js +84 -123
- package/es/page/index.js.map +1 -1
- package/es/page/utils.js +14 -12
- package/es/page-header/index.js +2 -1
- package/es/pagination/index.js +2 -1
- package/es/popconfirm/index.js +2 -1
- package/es/popover/index.js +2 -1
- package/es/prev-locale.js +47 -49
- package/es/progress/index.js +2 -1
- package/es/query-form/Field/Checkbox.js +17 -20
- package/es/query-form/Field/Select.js +39 -54
- package/es/query-form/Field/SelectInput.js +45 -63
- package/es/query-form/Field/fieldsMap.js +20 -19
- package/es/query-form/Field/index.js +66 -104
- package/es/query-form/createActions.js +46 -46
- package/es/query-form/index.js +247 -327
- package/es/query-form/useForm.js +4 -3
- package/es/query-list-scene/List.js +255 -321
- package/es/query-list-scene/List.js.map +1 -1
- package/es/query-list-scene/QueryForm.js +94 -132
- package/es/query-list-scene/QueryListScene.js +21 -29
- package/es/query-list-scene/Title.js +4 -6
- package/es/query-list-scene/Toolbar.js +15 -21
- package/es/query-list-scene/createActions.js +60 -60
- package/es/query-list-scene/index.js +2 -1
- package/es/query-list-scene/useActions.js +4 -3
- package/es/radio/index.js +2 -1
- package/es/rate/index.js +2 -1
- package/es/render-empty/index.js +2 -1
- package/es/render-empty/render-empty.js +16 -19
- package/es/result/index.js +2 -1
- package/es/row/index.js +2 -1
- package/es/select/index.js +2 -1
- package/es/skeleton/index.js +2 -1
- package/es/slider/index.js +2 -1
- package/es/spin/index.js +2 -1
- package/es/statistic/index.js +2 -1
- package/es/steps/index.js +2 -1
- package/es/steps/steps.js +35 -51
- package/es/svg-components/illustration-403.js +58 -206
- package/es/svg-components/illustration-404.js +75 -290
- package/es/svg-components/illustration-500.js +83 -321
- package/es/svg-components/illustration-empty.js +15 -54
- package/es/svg-components/illustration-failure.js +36 -112
- package/es/svg-components/illustration-no-access.js +35 -114
- package/es/svg-components/illustration-no-chart.js +37 -134
- package/es/svg-components/illustration-no-result.js +32 -92
- package/es/svg-components/illustration-offline.js +43 -131
- package/es/svg-components/illustration-success.js +43 -137
- package/es/svg-components/index.js +2 -1
- package/es/switch/index.js +2 -1
- package/es/table/assets/image-loading-background.js +17 -45
- package/es/table/assets/image-loading.js +5 -26
- package/es/table/constants.js +2 -1
- package/es/table/context.js +2 -1
- package/es/table/hooks/index.js +2 -1
- package/es/table/hooks/use-column-setting.js +16 -13
- package/es/table/index.js +2 -1
- package/es/table/table.js +53 -76
- package/es/table/table.stories.js +139 -148
- package/es/table/utils.js +18 -17
- package/es/tabs/index.js +2 -1
- package/es/tag/index.js +123 -2
- package/es/tag/index.js.map +1 -1
- package/es/tag/tag.less +61 -0
- package/es/time-picker/index.js +2 -1
- package/es/timeline/index.js +2 -1
- package/es/title/index.js +20 -34
- package/es/tntd-cascader/AntdCascader/component/DisabledContext.js +5 -9
- package/es/tntd-cascader/AntdCascader/component/FormItemInputContext.js +2 -1
- package/es/tntd-cascader/AntdCascader/component/SizeContext.js +2 -1
- package/es/tntd-cascader/AntdCascader/component/context.js +7 -5
- package/es/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +10 -22
- package/es/tntd-cascader/AntdCascader/component/getIcons.js +50 -72
- package/es/tntd-cascader/AntdCascader/component/useCompactItemContext.js +20 -22
- package/es/tntd-cascader/AntdCascader/config/utils.js +18 -17
- package/es/tntd-cascader/AntdCascader/config/warning.js +10 -9
- package/es/tntd-cascader/AntdCascader/index.js +118 -189
- package/es/tntd-cascader/AntdCascader/interface.js +2 -1
- package/es/tntd-cascader/index.js +2 -1
- package/es/tntd-cascader/rc-cascader/Cascader.js +239 -256
- package/es/tntd-cascader/rc-cascader/OptionList/Checkbox.js +11 -21
- package/es/tntd-cascader/rc-cascader/OptionList/Column.js +116 -175
- package/es/tntd-cascader/rc-cascader/OptionList/index.js +128 -180
- package/es/tntd-cascader/rc-cascader/OptionList/useActive.js +19 -22
- package/es/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +137 -144
- package/es/tntd-cascader/rc-cascader/context.js +2 -1
- package/es/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +37 -44
- package/es/tntd-cascader/rc-cascader/hooks/useEntities.js +24 -25
- package/es/tntd-cascader/rc-cascader/hooks/useMissingValues.js +17 -15
- package/es/tntd-cascader/rc-cascader/hooks/useRefFunc.js +8 -7
- package/es/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +21 -20
- package/es/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +41 -51
- package/es/tntd-cascader/rc-cascader/index.js +2 -1
- package/es/tntd-cascader/rc-cascader/utils/commonUtil.js +27 -33
- package/es/tntd-cascader/rc-cascader/utils/treeUtil.js +32 -29
- package/es/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +23 -26
- package/es/tntd-form/TntdForm/components/Item.js +30 -42
- package/es/tntd-form/TntdForm/components/ItemComp.js +158 -167
- package/es/tntd-form/TntdForm/components/List.js +78 -89
- package/es/tntd-form/TntdForm/index.js +33 -38
- package/es/tntd-form/TntdForm/interface.js +2 -1
- package/es/tntd-form/TntdForm/store.js +2 -1
- package/es/tntd-form/TntdForm/utils.js +168 -158
- package/es/tntd-form/index.js +2 -1
- package/es/tntd-icon/fonts/iconfont.js +53 -36
- package/es/tntd-icon/index.js +17 -23
- package/es/tntd-layout/ActionsContext.js +2 -1
- package/es/tntd-layout/AppList.js +77 -135
- package/es/tntd-layout/Application.js +29 -42
- package/es/tntd-layout/Avatar.js +42 -80
- package/es/tntd-layout/CompatibleLanguage.js +56 -93
- package/es/tntd-layout/EnterpriseLayout/Avatar.js +47 -93
- package/es/tntd-layout/EnterpriseLayout/Language.js +34 -56
- package/es/tntd-layout/EnterpriseLayout/Theme.js +24 -45
- package/es/tntd-layout/EnterpriseLayout/index.js +9 -17
- package/es/tntd-layout/GlobalNavigation/NavigationPopup.js +153 -213
- package/es/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
- package/es/tntd-layout/GlobalNavigation/index.js +50 -84
- package/es/tntd-layout/Header.js +26 -59
- package/es/tntd-layout/HeaderActions.js +34 -83
- package/es/tntd-layout/HeaderNavs.js +35 -46
- package/es/tntd-layout/HeaderTabs.js +140 -176
- package/es/tntd-layout/Iconfont.js +2 -1
- package/es/tntd-layout/Language.js +33 -55
- package/es/tntd-layout/Layout.js +78 -176
- package/es/tntd-layout/Logo.js +40 -52
- package/es/tntd-layout/OrgAppList.js +139 -208
- package/es/tntd-layout/SideMenu.js +160 -230
- package/es/tntd-layout/Theme.js +29 -47
- package/es/tntd-layout/createActions.js +29 -28
- package/es/tntd-layout/images/index.js +32 -31
- package/es/tntd-layout/index.js +60 -92
- package/es/tntd-layout/paaslayout/CompactSideMenu.js +65 -109
- package/es/tntd-layout/paaslayout/Header.js +14 -37
- package/es/tntd-layout/paaslayout/Logo.js +3 -2
- package/es/tntd-layout/paaslayout/SideMenu.js +63 -109
- package/es/tntd-layout/paaslayout/index.js +79 -159
- package/es/tntd-layout/storage.js +11 -18
- package/es/tntd-modal/index.js +32 -73
- package/es/tntd-second-page/index.js +24 -47
- package/es/tntd-select/DropDownWrap.js +52 -73
- package/es/tntd-select/index.js +492 -564
- package/es/tntd-select/index.js.map +1 -1
- package/es/tooltip/index.js +2 -1
- package/es/transfer/index.js +2 -1
- package/es/tree/index.js +2 -1
- package/es/tree-select/index.js +2 -1
- package/es/typography/index.js +2 -1
- package/es/upload/index.js +2 -1
- package/es/utils/checkAuth.js +21 -24
- package/es/utils/findMenuInfoByPath.js +30 -33
- package/es/utils/index.js +59 -65
- package/es/version/index.js +2 -1
- package/lib/affix/index.d.ts +3 -3
- package/lib/affix/index.js +22 -23
- package/lib/affix/index.js.map +1 -1
- package/lib/alert/index.d.ts +3 -3
- package/lib/alert/index.js +22 -23
- package/lib/alert/index.js.map +1 -1
- package/lib/anchor/index.d.ts +3 -3
- package/lib/anchor/index.js +22 -23
- package/lib/anchor/index.js.map +1 -1
- package/lib/array-input/icon.js +12 -33
- package/lib/array-input/index.js +150 -254
- package/lib/auth-context/index.js +4 -10
- package/lib/auto-complete/index.d.ts +3 -3
- package/lib/auto-complete/index.js +22 -23
- package/lib/auto-complete/index.js.map +1 -1
- package/lib/avatar/index.d.ts +3 -3
- package/lib/avatar/index.js +22 -23
- package/lib/avatar/index.js.map +1 -1
- package/lib/back-top/index.d.ts +3 -3
- package/lib/back-top/index.js +22 -23
- package/lib/back-top/index.js.map +1 -1
- package/lib/badge/index.d.ts +3 -3
- package/lib/badge/index.js +22 -23
- package/lib/badge/index.js.map +1 -1
- package/lib/breadcrumb/index.d.ts +3 -3
- package/lib/breadcrumb/index.js +22 -23
- package/lib/breadcrumb/index.js.map +1 -1
- package/lib/button/index.d.ts +3 -3
- package/lib/button/index.js +22 -23
- package/lib/button/index.js.map +1 -1
- package/lib/calendar/index.d.ts +3 -3
- package/lib/calendar/index.js +22 -23
- package/lib/calendar/index.js.map +1 -1
- package/lib/card/index.d.ts +3 -3
- package/lib/card/index.js +22 -23
- package/lib/card/index.js.map +1 -1
- package/lib/carousel/index.d.ts +3 -3
- package/lib/carousel/index.js +22 -23
- package/lib/carousel/index.js.map +1 -1
- package/lib/cascader/index.d.ts +3 -3
- package/lib/cascader/index.js +22 -23
- package/lib/cascader/index.js.map +1 -1
- package/lib/checkbox/index.d.ts +3 -3
- package/lib/checkbox/index.js +22 -23
- package/lib/checkbox/index.js.map +1 -1
- package/lib/col/index.d.ts +3 -3
- package/lib/col/index.js +22 -23
- package/lib/col/index.js.map +1 -1
- package/lib/collapse/index.d.ts +3 -3
- package/lib/collapse/index.js +23 -24
- package/lib/collapse/index.js.map +1 -1
- package/lib/color-picker/ColorPicker.d.ts +16 -0
- package/lib/color-picker/ColorPicker.d.ts.map +1 -0
- package/lib/color-picker/ColorPicker.js +119 -0
- package/lib/color-picker/ColorPicker.js.map +1 -0
- package/lib/color-picker/index.d.ts +2 -0
- package/lib/color-picker/index.d.ts.map +1 -0
- package/lib/color-picker/index.js +17 -0
- package/lib/color-picker/index.js.map +1 -0
- package/lib/color-picker/index.less +234 -0
- package/lib/color-picker/tip.svg +23 -0
- package/lib/columns/index.js +41 -81
- package/lib/columns/style/index.js +2 -1
- package/lib/comment/index.d.ts +3 -3
- package/lib/comment/index.js +22 -23
- 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 +8 -12
- 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 +22 -23
- package/lib/config-provider/index.js.map +1 -1
- package/lib/date-picker/index.d.ts +3 -3
- package/lib/date-picker/index.js +22 -23
- 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 +55 -64
- package/lib/descriptions/descriptions.js.map +1 -1
- package/lib/descriptions/index.d.ts +1 -1
- package/lib/descriptions/index.js +22 -23
- package/lib/descriptions/index.js.map +1 -1
- package/lib/development-login/LoginModal.js +79 -110
- package/lib/development-login/index.js +35 -42
- package/lib/divider/index.d.ts +3 -3
- package/lib/divider/index.js +22 -23
- package/lib/divider/index.js.map +1 -1
- package/lib/drawer/drawer.d.ts +1 -1
- package/lib/drawer/drawer.js +30 -41
- package/lib/drawer/drawer.js.map +1 -1
- package/lib/drawer/index.d.ts +2 -2
- package/lib/drawer/index.js +20 -22
- package/lib/drawer/index.js.map +1 -1
- package/lib/dropdown/index.d.ts +3 -3
- package/lib/dropdown/index.js +22 -23
- package/lib/dropdown/index.js.map +1 -1
- package/lib/ellipsis/Svg/CopySVG.d.ts.map +1 -1
- package/lib/ellipsis/Svg/CopySVG.js +20 -70
- 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 +15 -48
- package/lib/ellipsis/Svg/TickSVG.js.map +1 -1
- package/lib/ellipsis/index.d.ts.map +1 -1
- package/lib/ellipsis/index.js +115 -128
- package/lib/ellipsis/index.js.map +1 -1
- package/lib/ellipsis/index.less +1 -1
- package/lib/empty/empty.d.ts +2 -2
- package/lib/empty/empty.js +75 -90
- package/lib/empty/empty.js.map +1 -1
- package/lib/empty/empty.stories.js +18 -19
- package/lib/empty/index.d.ts +1 -1
- package/lib/empty/index.js +19 -20
- package/lib/empty/index.js.map +1 -1
- package/lib/exception/exception.js +31 -46
- package/lib/exception/exception.js.map +1 -1
- package/lib/exception/index.js +18 -19
- package/lib/form/index.d.ts +3 -3
- package/lib/form/index.js +22 -23
- package/lib/form/index.js.map +1 -1
- package/lib/handle/index.js +104 -140
- package/lib/handle/index.js.map +1 -1
- package/lib/icon/index.d.ts +3 -3
- package/lib/icon/index.js +22 -23
- package/lib/icon/index.js.map +1 -1
- package/lib/icon-list/index.js +121 -7
- package/lib/img/Contain.js +44 -69
- package/lib/img/Cover.js +78 -117
- package/lib/img/index.js +60 -74
- package/lib/index.d.ts +1 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +186 -614
- package/lib/index.js.map +1 -1
- package/lib/input/index.d.ts +3 -3
- package/lib/input/index.js +22 -23
- package/lib/input/index.js.map +1 -1
- package/lib/input-number/index.d.ts +3 -3
- package/lib/input-number/index.js +22 -23
- package/lib/input-number/index.js.map +1 -1
- package/lib/layout/index.d.ts +3 -3
- package/lib/layout/index.js +22 -23
- package/lib/layout/index.js.map +1 -1
- package/lib/list/index.d.ts +3 -3
- package/lib/list/index.js +22 -23
- package/lib/list/index.js.map +1 -1
- package/lib/loading-button/index.js +55 -58
- package/lib/locale/default.d.ts +1 -0
- package/lib/locale/default.d.ts.map +1 -1
- package/lib/locale/default.js +10 -12
- package/lib/locale/default.js.map +1 -1
- package/lib/locale/en_US.d.ts +1 -0
- package/lib/locale/en_US.d.ts.map +1 -1
- package/lib/locale/en_US.js +36 -37
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/index.js +18 -36
- package/lib/locale/zh_CN.d.ts +1 -0
- package/lib/locale/zh_CN.d.ts.map +1 -1
- package/lib/locale/zh_CN.js +36 -37
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/locale-provider/index.d.ts +3 -3
- package/lib/locale-provider/index.js +25 -26
- package/lib/locale-provider/index.js.map +1 -1
- package/lib/mention/index.d.ts +3 -3
- package/lib/mention/index.js +22 -23
- package/lib/mention/index.js.map +1 -1
- package/lib/mentions/index.d.ts +3 -3
- package/lib/mentions/index.js +22 -23
- package/lib/mentions/index.js.map +1 -1
- package/lib/menu/index.d.ts +3 -3
- package/lib/menu/index.js +22 -23
- package/lib/menu/index.js.map +1 -1
- package/lib/message/index.d.ts +3 -3
- package/lib/message/index.js +22 -23
- package/lib/message/index.js.map +1 -1
- package/lib/modal/index.d.ts +1 -1
- package/lib/modal/index.js +21 -22
- package/lib/modal/index.js.map +1 -1
- package/lib/modal/modal.d.ts +9 -9
- package/lib/modal/modal.js +49 -53
- package/lib/modal/modal.js.map +1 -1
- package/lib/notification/index.d.ts +3 -3
- package/lib/notification/index.js +22 -23
- package/lib/notification/index.js.map +1 -1
- package/lib/page/Box.js +40 -66
- package/lib/page/index.d.ts.map +1 -1
- package/lib/page/index.js +95 -151
- package/lib/page/index.js.map +1 -1
- package/lib/page/utils.js +16 -22
- package/lib/page-header/index.d.ts +3 -3
- package/lib/page-header/index.js +22 -23
- package/lib/page-header/index.js.map +1 -1
- package/lib/pagination/index.d.ts +3 -3
- package/lib/pagination/index.js +22 -23
- package/lib/pagination/index.js.map +1 -1
- package/lib/popconfirm/index.d.ts +3 -3
- package/lib/popconfirm/index.js +22 -23
- package/lib/popconfirm/index.js.map +1 -1
- package/lib/popover/index.d.ts +3 -3
- package/lib/popover/index.js +22 -23
- package/lib/popover/index.js.map +1 -1
- package/lib/prev-locale.js +53 -67
- package/lib/progress/index.d.ts +3 -3
- package/lib/progress/index.js +22 -23
- package/lib/progress/index.js.map +1 -1
- package/lib/query-form/Field/Checkbox.js +22 -28
- package/lib/query-form/Field/Select.js +68 -79
- package/lib/query-form/Field/SelectInput.js +73 -85
- package/lib/query-form/Field/fieldsMap.d.ts +2 -2
- package/lib/query-form/Field/fieldsMap.js +32 -34
- package/lib/query-form/Field/index.js +95 -139
- package/lib/query-form/createActions.js +50 -53
- package/lib/query-form/index.js +286 -377
- 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 +289 -360
- package/lib/query-list-scene/List.js.map +1 -1
- package/lib/query-list-scene/QueryForm.js +103 -161
- package/lib/query-list-scene/QueryListScene.js +31 -66
- package/lib/query-list-scene/Title.js +9 -15
- package/lib/query-list-scene/Toolbar.js +20 -31
- package/lib/query-list-scene/createActions.js +64 -79
- package/lib/query-list-scene/index.js +24 -28
- package/lib/query-list-scene/useActions.js +11 -11
- package/lib/radio/index.d.ts +3 -3
- package/lib/radio/index.js +22 -23
- package/lib/radio/index.js.map +1 -1
- package/lib/rate/index.d.ts +3 -3
- package/lib/rate/index.js +22 -23
- package/lib/rate/index.js.map +1 -1
- package/lib/render-empty/index.js +4 -8
- package/lib/render-empty/render-empty.js +22 -28
- package/lib/render-empty/render-empty.js.map +1 -1
- package/lib/result/index.d.ts +3 -3
- package/lib/result/index.js +22 -23
- package/lib/result/index.js.map +1 -1
- package/lib/row/index.d.ts +3 -3
- package/lib/row/index.js +22 -23
- package/lib/row/index.js.map +1 -1
- package/lib/select/index.d.ts +3 -3
- package/lib/select/index.js +22 -23
- package/lib/select/index.js.map +1 -1
- package/lib/skeleton/index.d.ts +3 -3
- package/lib/skeleton/index.js +22 -23
- package/lib/skeleton/index.js.map +1 -1
- package/lib/slider/index.d.ts +3 -3
- package/lib/slider/index.js +22 -23
- package/lib/slider/index.js.map +1 -1
- package/lib/spin/index.d.ts +3 -3
- package/lib/spin/index.js +22 -23
- package/lib/spin/index.js.map +1 -1
- package/lib/statistic/index.d.ts +3 -3
- package/lib/statistic/index.js +22 -23
- package/lib/statistic/index.js.map +1 -1
- package/lib/steps/index.d.ts +1 -1
- package/lib/steps/index.js +19 -20
- package/lib/steps/index.js.map +1 -1
- package/lib/steps/steps.d.ts +3 -3
- package/lib/steps/steps.js +59 -72
- 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 +84 -217
- package/lib/svg-components/illustration-404.d.ts +1 -1
- package/lib/svg-components/illustration-404.js +101 -301
- package/lib/svg-components/illustration-500.d.ts +1 -1
- package/lib/svg-components/illustration-500.js +109 -332
- package/lib/svg-components/illustration-empty.d.ts +1 -1
- package/lib/svg-components/illustration-empty.js +41 -65
- package/lib/svg-components/illustration-failure.d.ts +1 -1
- package/lib/svg-components/illustration-failure.js +62 -123
- package/lib/svg-components/illustration-no-access.d.ts +1 -1
- package/lib/svg-components/illustration-no-access.js +61 -125
- package/lib/svg-components/illustration-no-chart.d.ts +1 -1
- package/lib/svg-components/illustration-no-chart.js +63 -145
- package/lib/svg-components/illustration-no-result.d.ts +1 -1
- package/lib/svg-components/illustration-no-result.js +58 -103
- package/lib/svg-components/illustration-offline.d.ts +1 -1
- package/lib/svg-components/illustration-offline.js +69 -142
- package/lib/svg-components/illustration-success.d.ts +1 -1
- package/lib/svg-components/illustration-success.js +69 -148
- package/lib/svg-components/index.js +26 -75
- package/lib/switch/index.d.ts +3 -3
- package/lib/switch/index.js +22 -23
- 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 +43 -56
- package/lib/table/assets/image-loading.d.ts +1 -1
- package/lib/table/assets/image-loading.js +31 -37
- package/lib/table/constants.js +3 -6
- package/lib/table/context.js +4 -7
- package/lib/table/hooks/index.js +16 -14
- package/lib/table/hooks/use-column-setting.d.ts +1 -1
- package/lib/table/hooks/use-column-setting.js +20 -37
- package/lib/table/hooks/use-column-setting.js.map +1 -1
- package/lib/table/index.d.ts +1 -1
- package/lib/table/index.js +19 -20
- package/lib/table/index.js.map +1 -1
- package/lib/table/table.d.ts +3 -3
- package/lib/table/table.js +92 -110
- package/lib/table/table.js.map +1 -1
- package/lib/table/table.stories.js +154 -182
- package/lib/table/utils.d.ts +1 -1
- package/lib/table/utils.js +25 -24
- package/lib/table/utils.js.map +1 -1
- package/lib/tabs/index.d.ts +3 -3
- package/lib/tabs/index.js +22 -23
- 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 +155 -22
- package/lib/tag/index.js.map +1 -1
- package/lib/tag/tag.less +61 -0
- package/lib/time-picker/index.d.ts +3 -3
- package/lib/time-picker/index.js +22 -23
- package/lib/time-picker/index.js.map +1 -1
- package/lib/timeline/index.d.ts +3 -3
- package/lib/timeline/index.js +22 -23
- package/lib/timeline/index.js.map +1 -1
- package/lib/title/index.js +26 -45
- package/lib/tntd-cascader/AntdCascader/component/DisabledContext.js +31 -18
- package/lib/tntd-cascader/AntdCascader/component/FormItemInputContext.js +26 -9
- package/lib/tntd-cascader/AntdCascader/component/SizeContext.js +26 -9
- package/lib/tntd-cascader/AntdCascader/component/context.js +16 -18
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js +39 -36
- package/lib/tntd-cascader/AntdCascader/component/defaultRenderEmpty.js.map +1 -1
- package/lib/tntd-cascader/AntdCascader/component/getIcons.js +75 -81
- package/lib/tntd-cascader/AntdCascader/component/useCompactItemContext.js +50 -31
- package/lib/tntd-cascader/AntdCascader/config/utils.js +27 -29
- package/lib/tntd-cascader/AntdCascader/config/warning.js +35 -19
- package/lib/tntd-cascader/AntdCascader/index.js +162 -216
- package/lib/tntd-cascader/AntdCascader/interface.js +6 -13
- package/lib/tntd-cascader/img/no-data-s.png +0 -0
- package/lib/tntd-cascader/index.js +8 -12
- package/lib/tntd-cascader/rc-cascader/Cascader.js +284 -325
- package/lib/tntd-cascader/rc-cascader/OptionList/Checkbox.js +41 -30
- package/lib/tntd-cascader/rc-cascader/OptionList/Column.js +152 -198
- package/lib/tntd-cascader/rc-cascader/OptionList/index.js +163 -223
- package/lib/tntd-cascader/rc-cascader/OptionList/useActive.js +48 -40
- package/lib/tntd-cascader/rc-cascader/OptionList/useKeyboard.js +166 -179
- package/lib/tntd-cascader/rc-cascader/context.js +27 -11
- package/lib/tntd-cascader/rc-cascader/hooks/useDisplayValues.js +63 -62
- package/lib/tntd-cascader/rc-cascader/hooks/useEntities.js +49 -39
- package/lib/tntd-cascader/rc-cascader/hooks/useMissingValues.js +41 -26
- package/lib/tntd-cascader/rc-cascader/hooks/useRefFunc.js +33 -16
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchConfig.js +51 -30
- package/lib/tntd-cascader/rc-cascader/hooks/useSearchOptions.js +65 -75
- package/lib/tntd-cascader/rc-cascader/index.js +7 -9
- package/lib/tntd-cascader/rc-cascader/utils/commonUtil.js +38 -49
- package/lib/tntd-cascader/rc-cascader/utils/treeUtil.js +39 -42
- package/lib/tntd-cascader/rc-cascader/utils/warningPropsUtil.js +30 -34
- package/lib/tntd-form/TntdForm/components/Item.js +61 -55
- package/lib/tntd-form/TntdForm/components/ItemComp.js +190 -203
- package/lib/tntd-form/TntdForm/components/List.js +111 -118
- package/lib/tntd-form/TntdForm/index.js +67 -61
- package/lib/tntd-form/TntdForm/interface.js +2 -4
- package/lib/tntd-form/TntdForm/store.js +7 -8
- package/lib/tntd-form/TntdForm/utils.js +184 -182
- package/lib/tntd-form/index.js +8 -12
- package/lib/tntd-icon/fonts/iconfont.js +53 -36
- package/lib/tntd-icon/index.js +25 -40
- package/lib/tntd-layout/ActionsContext.js +4 -8
- package/lib/tntd-layout/AppList.js +224 -173
- package/lib/tntd-layout/Application.js +111 -75
- package/lib/tntd-layout/Avatar.js +135 -100
- package/lib/tntd-layout/CompatibleLanguage.js +180 -128
- package/lib/tntd-layout/EnterpriseLayout/Avatar.js +146 -117
- package/lib/tntd-layout/EnterpriseLayout/Language.js +90 -73
- package/lib/tntd-layout/EnterpriseLayout/Theme.js +102 -69
- package/lib/tntd-layout/EnterpriseLayout/index.js +17 -28
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.d.ts.map +1 -1
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js +276 -284
- package/lib/tntd-layout/GlobalNavigation/NavigationPopup.js.map +1 -1
- package/lib/tntd-layout/GlobalNavigation/index.js +115 -108
- package/lib/tntd-layout/Header.js +136 -77
- package/lib/tntd-layout/HeaderActions.js +106 -105
- package/lib/tntd-layout/HeaderNavs.js +107 -78
- package/lib/tntd-layout/HeaderTabs.js +316 -224
- package/lib/tntd-layout/Iconfont.js +7 -11
- package/lib/tntd-layout/Language.js +76 -69
- package/lib/tntd-layout/Layout.js +171 -214
- package/lib/tntd-layout/Logo.js +144 -69
- package/lib/tntd-layout/OrgAppList.js +388 -238
- package/lib/tntd-layout/SideMenu.js +408 -269
- package/lib/tntd-layout/Theme.js +93 -75
- package/lib/tntd-layout/createActions.js +34 -45
- 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 +66 -68
- package/lib/tntd-layout/index.js +95 -137
- package/lib/tntd-layout/paaslayout/CompactSideMenu.js +182 -131
- package/lib/tntd-layout/paaslayout/Header.js +79 -51
- package/lib/tntd-layout/paaslayout/Logo.js +30 -15
- package/lib/tntd-layout/paaslayout/SideMenu.js +147 -131
- package/lib/tntd-layout/paaslayout/index.js +141 -205
- package/lib/tntd-layout/storage.js +30 -58
- package/lib/tntd-modal/index.js +62 -98
- package/lib/tntd-second-page/index.js +33 -60
- package/lib/tntd-second-page/index.js.map +1 -1
- package/lib/tntd-select/DropDownWrap.js +78 -102
- package/lib/tntd-select/index.d.ts +3 -3
- package/lib/tntd-select/index.d.ts.map +1 -1
- package/lib/tntd-select/index.js +529 -607
- package/lib/tntd-select/index.js.map +1 -1
- package/lib/tooltip/index.d.ts +3 -3
- package/lib/tooltip/index.js +22 -23
- package/lib/tooltip/index.js.map +1 -1
- package/lib/transfer/index.d.ts +3 -3
- package/lib/transfer/index.js +22 -23
- package/lib/transfer/index.js.map +1 -1
- package/lib/tree/index.d.ts +3 -3
- package/lib/tree/index.js +22 -23
- package/lib/tree/index.js.map +1 -1
- package/lib/tree-select/index.d.ts +3 -3
- package/lib/tree-select/index.js +22 -23
- package/lib/tree-select/index.js.map +1 -1
- package/lib/typography/index.d.ts +3 -3
- package/lib/typography/index.js +22 -23
- package/lib/typography/index.js.map +1 -1
- package/lib/upload/index.d.ts +3 -3
- package/lib/upload/index.js +22 -23
- package/lib/upload/index.js.map +1 -1
- package/lib/utils/checkAuth.js +23 -34
- package/lib/utils/findMenuInfoByPath.js +34 -41
- package/lib/utils/index.js +80 -117
- package/lib/version/index.d.ts +3 -3
- package/lib/version/index.js +22 -23
- package/lib/version/index.js.map +1 -1
- package/package.json +4 -2
- package/themes/default/variables.less +6 -7
- package/es/array-input/style/index.js +0 -1
- package/es/array-input/style/index.js.map +0 -1
- package/es/auth-context/style/index.js +0 -1
- package/es/auth-context/style/index.js.map +0 -1
- package/es/development-login/style/index.js +0 -1
- package/es/development-login/style/index.js.map +0 -1
- package/es/ellipsis/style/index.js +0 -1
- package/es/ellipsis/style/index.js.map +0 -1
- package/es/empty/render-empty.js +0 -22
- package/es/empty/render-empty.js.map +0 -1
- package/es/empty/style/index.js +0 -2
- package/es/empty/style/index.js.map +0 -1
- package/es/handle/style/index.js +0 -1
- package/es/handle/style/index.js.map +0 -1
- package/es/icon-list/style/index.js +0 -1
- package/es/icon-list/style/index.js.map +0 -1
- package/es/img/style/index.js +0 -1
- package/es/img/style/index.js.map +0 -1
- package/es/loading-button/style/index.js +0 -1
- package/es/loading-button/style/index.js.map +0 -1
- package/es/page/style/index.js +0 -1
- package/es/page/style/index.js.map +0 -1
- package/es/query-form/style/index.js +0 -1
- package/es/query-form/style/index.js.map +0 -1
- package/es/query-list-scene/style/index.js +0 -1
- package/es/query-list-scene/style/index.js.map +0 -1
- package/es/render-empty/style/index.js +0 -1
- package/es/render-empty/style/index.js.map +0 -1
- package/es/status/index.js +0 -1
- package/es/status/index.js.map +0 -1
- package/es/status/status.js +0 -5
- package/es/status/status.js.map +0 -1
- package/es/table/style/index.js +0 -2
- package/es/table/style/index.js.map +0 -1
- package/es/title/style/index.js +0 -1
- package/es/title/style/index.js.map +0 -1
- package/es/tntd-icon/style/index.js +0 -1
- package/es/tntd-icon/style/index.js.map +0 -1
- package/es/tntd-layout/style/index.js +0 -1
- package/es/tntd-layout/style/index.js.map +0 -1
- package/es/tntd-modal/style/index.js +0 -1
- package/es/tntd-modal/style/index.js.map +0 -1
- package/es/tntd-select/style/index.js +0 -1
- package/es/tntd-select/style/index.js.map +0 -1
- package/lib/array-input/style/index.d.ts +0 -1
- package/lib/array-input/style/index.d.ts.map +0 -1
- package/lib/array-input/style/index.js +0 -1
- package/lib/array-input/style/index.js.map +0 -1
- package/lib/auth-context/style/index.d.ts +0 -1
- package/lib/auth-context/style/index.d.ts.map +0 -1
- package/lib/auth-context/style/index.js +0 -1
- package/lib/auth-context/style/index.js.map +0 -1
- package/lib/development-login/style/index.d.ts +0 -1
- package/lib/development-login/style/index.d.ts.map +0 -1
- package/lib/development-login/style/index.js +0 -1
- package/lib/development-login/style/index.js.map +0 -1
- package/lib/ellipsis/style/index.d.ts +0 -1
- package/lib/ellipsis/style/index.d.ts.map +0 -1
- package/lib/ellipsis/style/index.js +0 -1
- package/lib/ellipsis/style/index.js.map +0 -1
- package/lib/empty/render-empty.d.ts +0 -3
- package/lib/empty/render-empty.d.ts.map +0 -1
- package/lib/empty/render-empty.js +0 -32
- package/lib/empty/render-empty.js.map +0 -1
- package/lib/empty/style/index.d.ts +0 -3
- package/lib/empty/style/index.d.ts.map +0 -1
- package/lib/empty/style/index.js +0 -4
- package/lib/empty/style/index.js.map +0 -1
- package/lib/handle/style/index.d.ts +0 -1
- package/lib/handle/style/index.d.ts.map +0 -1
- package/lib/handle/style/index.js +0 -1
- package/lib/handle/style/index.js.map +0 -1
- package/lib/icon-list/style/index.d.ts +0 -3
- package/lib/icon-list/style/index.d.ts.map +0 -1
- package/lib/icon-list/style/index.js +0 -8
- package/lib/icon-list/style/index.js.map +0 -1
- package/lib/img/style/index.d.ts +0 -1
- package/lib/img/style/index.d.ts.map +0 -1
- package/lib/img/style/index.js +0 -1
- package/lib/img/style/index.js.map +0 -1
- package/lib/loading-button/style/index.d.ts +0 -1
- package/lib/loading-button/style/index.d.ts.map +0 -1
- package/lib/loading-button/style/index.js +0 -1
- package/lib/loading-button/style/index.js.map +0 -1
- package/lib/page/style/index.d.ts +0 -1
- package/lib/page/style/index.d.ts.map +0 -1
- package/lib/page/style/index.js +0 -1
- package/lib/page/style/index.js.map +0 -1
- package/lib/query-form/style/index.d.ts +0 -1
- package/lib/query-form/style/index.d.ts.map +0 -1
- package/lib/query-form/style/index.js +0 -1
- package/lib/query-form/style/index.js.map +0 -1
- package/lib/query-list-scene/style/index.d.ts +0 -1
- package/lib/query-list-scene/style/index.d.ts.map +0 -1
- package/lib/query-list-scene/style/index.js +0 -1
- package/lib/query-list-scene/style/index.js.map +0 -1
- package/lib/render-empty/style/index.d.ts +0 -2
- package/lib/render-empty/style/index.d.ts.map +0 -1
- package/lib/render-empty/style/index.js +0 -3
- package/lib/render-empty/style/index.js.map +0 -1
- package/lib/status/index.d.ts +0 -2
- package/lib/status/index.d.ts.map +0 -1
- package/lib/status/index.js +0 -16
- package/lib/status/index.js.map +0 -1
- package/lib/status/status.d.ts +0 -6
- package/lib/status/status.d.ts.map +0 -1
- package/lib/status/status.js +0 -13
- package/lib/status/status.js.map +0 -1
- package/lib/table/style/index.d.ts +0 -3
- package/lib/table/style/index.d.ts.map +0 -1
- package/lib/table/style/index.js +0 -4
- package/lib/table/style/index.js.map +0 -1
- package/lib/title/style/index.d.ts +0 -1
- package/lib/title/style/index.d.ts.map +0 -1
- package/lib/title/style/index.js +0 -1
- package/lib/title/style/index.js.map +0 -1
- package/lib/tntd-icon/style/index.d.ts +0 -1
- package/lib/tntd-icon/style/index.d.ts.map +0 -1
- package/lib/tntd-icon/style/index.js +0 -1
- package/lib/tntd-icon/style/index.js.map +0 -1
- package/lib/tntd-layout/style/index.d.ts +0 -1
- package/lib/tntd-layout/style/index.d.ts.map +0 -1
- package/lib/tntd-layout/style/index.js +0 -1
- package/lib/tntd-layout/style/index.js.map +0 -1
- package/lib/tntd-modal/style/index.d.ts +0 -1
- package/lib/tntd-modal/style/index.d.ts.map +0 -1
- package/lib/tntd-modal/style/index.js +0 -1
- package/lib/tntd-modal/style/index.js.map +0 -1
- package/lib/tntd-select/style/index.d.ts +0 -1
- package/lib/tntd-select/style/index.d.ts.map +0 -1
- package/lib/tntd-select/style/index.js +0 -1
- package/lib/tntd-select/style/index.js.map +0 -1
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import _debounce from "lodash/debounce";
|
|
2
1
|
import React, { useState, useEffect } from 'react';
|
|
3
2
|
import cn from 'classnames';
|
|
4
3
|
import styled from 'styled-components';
|
|
4
|
+
import { debounce } from 'lodash';
|
|
5
5
|
import { traverseTree, hasLevel3 } from '../../utils';
|
|
6
6
|
import Icon from '../Iconfont';
|
|
7
7
|
import '../../locale';
|
|
8
|
-
const SearchArea = styled.div`
|
|
8
|
+
const SearchArea = styled.div `
|
|
9
9
|
position: relative;
|
|
10
10
|
font-size: 14px;
|
|
11
11
|
margin-bottom: 20px;
|
|
12
|
-
color: ${props => props.theme.secondaryTextColor};
|
|
12
|
+
color: ${(props) => props.theme.secondaryTextColor};
|
|
13
13
|
&.active {
|
|
14
|
-
color: ${props => props.theme.primaryColor};
|
|
14
|
+
color: ${(props) => props.theme.primaryColor};
|
|
15
15
|
input {
|
|
16
|
-
border-color: ${props => props.theme.primaryColor};
|
|
16
|
+
border-color: ${(props) => props.theme.primaryColor};
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
.tnt-icon {
|
|
@@ -31,7 +31,7 @@ const SearchArea = styled.div`
|
|
|
31
31
|
input {
|
|
32
32
|
border-width: 0 0 1px;
|
|
33
33
|
border-style: solid;
|
|
34
|
-
border-color: ${props => props.theme.borderColor};
|
|
34
|
+
border-color: ${(props) => props.theme.borderColor};
|
|
35
35
|
width: 100%;
|
|
36
36
|
padding: 4px 20px;
|
|
37
37
|
line-height: 20px;
|
|
@@ -39,9 +39,9 @@ const SearchArea = styled.div`
|
|
|
39
39
|
outline: none;
|
|
40
40
|
}
|
|
41
41
|
`;
|
|
42
|
-
const ApplicationTabs = styled.ul`
|
|
43
|
-
border: 1px solid ${props => props.theme.borderColor};
|
|
44
|
-
color: ${props => props.theme.primaryTextColor};
|
|
42
|
+
const ApplicationTabs = styled.ul `
|
|
43
|
+
border: 1px solid ${(props) => props.theme.borderColor};
|
|
44
|
+
color: ${(props) => props.theme.primaryTextColor};
|
|
45
45
|
line-height: 32px;
|
|
46
46
|
margin: 0 0 16px;
|
|
47
47
|
padding: 0;
|
|
@@ -52,16 +52,16 @@ const ApplicationTabs = styled.ul`
|
|
|
52
52
|
display: inline-block;
|
|
53
53
|
cursor: pointer;
|
|
54
54
|
&:not(:last-child) {
|
|
55
|
-
border-right: 1px solid ${props => props.theme.borderColor};
|
|
55
|
+
border-right: 1px solid ${(props) => props.theme.borderColor};
|
|
56
56
|
}
|
|
57
57
|
&.active {
|
|
58
|
-
background-color: ${props => props.theme.primaryColor};
|
|
58
|
+
background-color: ${(props) => props.theme.primaryColor};
|
|
59
59
|
color: #fff;
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
62
|
`;
|
|
63
|
-
const GroupMenus = styled.div`
|
|
64
|
-
height: ${props => props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)'};
|
|
63
|
+
const GroupMenus = styled.div `
|
|
64
|
+
height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};
|
|
65
65
|
overflow: auto;
|
|
66
66
|
& > div {
|
|
67
67
|
width: 200px;
|
|
@@ -70,7 +70,7 @@ const GroupMenus = styled.div`
|
|
|
70
70
|
vertical-align: top;
|
|
71
71
|
}
|
|
72
72
|
`;
|
|
73
|
-
const GroupMenuItem = styled.div`
|
|
73
|
+
const GroupMenuItem = styled.div `
|
|
74
74
|
margin-bottom: 20px;
|
|
75
75
|
& > h5 {
|
|
76
76
|
line-height: 20px;
|
|
@@ -78,27 +78,27 @@ const GroupMenuItem = styled.div`
|
|
|
78
78
|
margin-bottom: 6px;
|
|
79
79
|
}
|
|
80
80
|
`;
|
|
81
|
-
const MenuList = styled.ul`
|
|
81
|
+
const MenuList = styled.ul `
|
|
82
82
|
list-style: none;
|
|
83
83
|
padding: 0;
|
|
84
84
|
margin: 0;
|
|
85
85
|
`;
|
|
86
|
-
const MenuItem = styled.li`
|
|
86
|
+
const MenuItem = styled.li `
|
|
87
87
|
display: block;
|
|
88
88
|
line-height: 30px;
|
|
89
89
|
font-size: 12px;
|
|
90
90
|
cursor: pointer;
|
|
91
91
|
a {
|
|
92
|
-
color: ${props => props.theme.secondaryTextColor};
|
|
92
|
+
color: ${(props) => props.theme.secondaryTextColor};
|
|
93
93
|
&:hover {
|
|
94
|
-
color: ${props => props.theme.secondaryColor} !important;
|
|
94
|
+
color: ${(props) => props.theme.secondaryColor} !important;
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
97
|
&.active a {
|
|
98
|
-
color: ${props => props.theme.primaryColor};
|
|
98
|
+
color: ${(props) => props.theme.primaryColor};
|
|
99
99
|
}
|
|
100
100
|
`;
|
|
101
|
-
const ListBox = styled.ul`
|
|
101
|
+
const ListBox = styled.ul `
|
|
102
102
|
background: #fff;
|
|
103
103
|
max-height: 320px;
|
|
104
104
|
overflow-y: auto;
|
|
@@ -115,205 +115,145 @@ const ListBox = styled.ul`
|
|
|
115
115
|
cursor: pointer;
|
|
116
116
|
line-height: 32px;
|
|
117
117
|
padding: 0 10px;
|
|
118
|
-
color: ${props => props.theme.primaryTextColor};
|
|
118
|
+
color: ${(props) => props.theme.primaryTextColor};
|
|
119
119
|
&:hover {
|
|
120
|
-
color: ${props => props.theme.secondaryColor};
|
|
121
|
-
background-color: ${props => props.theme.lightBgColor};
|
|
120
|
+
color: ${(props) => props.theme.secondaryColor};
|
|
121
|
+
background-color: ${(props) => props.theme.lightBgColor};
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
`;
|
|
125
|
-
const SearchList = ({
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
popupRef,
|
|
140
|
-
containerRef
|
|
141
|
-
}) => {
|
|
142
|
-
const [active, setActive] = useState(false);
|
|
143
|
-
const [searchValue, setSearchValue] = useState();
|
|
144
|
-
const language = actions === null || actions === void 0 ? void 0 : actions.getLanguage();
|
|
145
|
-
const isLevel3 = hasLevel3(menus);
|
|
146
|
-
const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus === null || menus === void 0 ? void 0 : menus[0] : null);
|
|
147
|
-
const selectedMenuKey = actions.getSelectedMenuKey();
|
|
148
|
-
const calcGroupMenus = menus => {
|
|
149
|
-
menus = menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
|
|
150
|
-
var _a;
|
|
151
|
-
// 分组
|
|
152
|
-
if ((_a = cur === null || cur === void 0 ? void 0 : cur.children) === null || _a === void 0 ? void 0 : _a.length) {
|
|
153
|
-
acc.push(cur);
|
|
154
|
-
} else {
|
|
155
|
-
const defaultGroup = acc.find(({
|
|
156
|
-
isDefaultGroup
|
|
157
|
-
}) => isDefaultGroup);
|
|
158
|
-
if (!defaultGroup) {
|
|
159
|
-
acc.unshift({
|
|
160
|
-
isDefaultGroup: true,
|
|
161
|
-
children: [cur]
|
|
162
|
-
});
|
|
163
|
-
} else {
|
|
164
|
-
defaultGroup.children.push(cur);
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
return acc;
|
|
168
|
-
}, []);
|
|
169
|
-
return menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
|
|
170
|
-
var _a;
|
|
171
|
-
const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210));
|
|
172
|
-
if (!acc.length) {
|
|
173
|
-
acc.push([cur]);
|
|
174
|
-
} else {
|
|
175
|
-
const calcGroupHeight = group => {
|
|
176
|
-
var _a;
|
|
177
|
-
return 46 + (((_a = group === null || group === void 0 ? void 0 : group.children) === null || _a === void 0 ? void 0 : _a.length) || 0) * 30;
|
|
178
|
-
};
|
|
179
|
-
const calcColumnHeight = columnGroups => columnGroups === null || columnGroups === void 0 ? void 0 : columnGroups.reduce((acc, cur) => {
|
|
180
|
-
acc += calcGroupHeight(cur);
|
|
181
|
-
return acc;
|
|
182
|
-
}, 0);
|
|
183
|
-
const currentColumnHeight = calcColumnHeight(acc[acc.length - 1]);
|
|
184
|
-
const nextGroupHeight = calcGroupHeight(cur);
|
|
185
|
-
const findMinHeightGroup = groups => {
|
|
186
|
-
let minHeight = Infinity;
|
|
187
|
-
let index = 0;
|
|
188
|
-
for (let i = 0; i < groups.length; i++) {
|
|
189
|
-
const height = calcColumnHeight(groups[i]);
|
|
190
|
-
if (height < minHeight) {
|
|
191
|
-
index = i;
|
|
192
|
-
minHeight = height;
|
|
125
|
+
const SearchList = ({ items, onSelectMenu, theme }) => (React.createElement(ListBox, { theme: theme }, items === null || items === void 0 ? void 0 : items.map((item) => (React.createElement("li", { onClick: () => onSelectMenu(item) }, item === null || item === void 0 ? void 0 : item.menuName)))));
|
|
126
|
+
export default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {
|
|
127
|
+
const [active, setActive] = useState(false);
|
|
128
|
+
const [searchValue, setSearchValue] = useState();
|
|
129
|
+
const language = actions === null || actions === void 0 ? void 0 : actions.getLanguage();
|
|
130
|
+
const isLevel3 = hasLevel3(menus);
|
|
131
|
+
const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus === null || menus === void 0 ? void 0 : menus[0] : null);
|
|
132
|
+
const selectedMenuKey = actions.getSelectedMenuKey();
|
|
133
|
+
const calcGroupMenus = (menus) => {
|
|
134
|
+
menus = menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
|
|
135
|
+
var _a;
|
|
136
|
+
// 分组
|
|
137
|
+
if ((_a = cur === null || cur === void 0 ? void 0 : cur.children) === null || _a === void 0 ? void 0 : _a.length) {
|
|
138
|
+
acc.push(cur);
|
|
193
139
|
}
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
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
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
return !(popup === null || popup === void 0 ? void 0 : popup.contains(evt.target));
|
|
255
|
-
}
|
|
256
|
-
let {
|
|
257
|
-
x,
|
|
258
|
-
y,
|
|
259
|
-
height,
|
|
260
|
-
width
|
|
261
|
-
} = popup.getBoundingClientRect();
|
|
262
|
-
console.log('clickOutside...', [x, y], [clientX, clientY], [pageX, pageY]);
|
|
263
|
-
x += window.scrollX;
|
|
264
|
-
y += window.scrollY;
|
|
265
|
-
return pageX < x || pageX > x + width || pageY < y || pageY > y + height;
|
|
266
|
-
};
|
|
267
|
-
if (isOutside(evt, popupRef.current)) {
|
|
140
|
+
else {
|
|
141
|
+
const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup);
|
|
142
|
+
if (!defaultGroup) {
|
|
143
|
+
acc.unshift({
|
|
144
|
+
isDefaultGroup: true,
|
|
145
|
+
children: [cur],
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
defaultGroup.children.push(cur);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return acc;
|
|
153
|
+
}, []);
|
|
154
|
+
return menus === null || menus === void 0 ? void 0 : menus.reduce((acc, cur) => {
|
|
155
|
+
var _a;
|
|
156
|
+
const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210));
|
|
157
|
+
if (!acc.length) {
|
|
158
|
+
acc.push([cur]);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
const calcGroupHeight = (group) => { var _a; return 46 + (((_a = group === null || group === void 0 ? void 0 : group.children) === null || _a === void 0 ? void 0 : _a.length) || 0) * 30; };
|
|
162
|
+
const calcColumnHeight = (columnGroups) => columnGroups === null || columnGroups === void 0 ? void 0 : columnGroups.reduce((acc, cur) => {
|
|
163
|
+
acc += calcGroupHeight(cur);
|
|
164
|
+
return acc;
|
|
165
|
+
}, 0);
|
|
166
|
+
const currentColumnHeight = calcColumnHeight(acc[acc.length - 1]);
|
|
167
|
+
const nextGroupHeight = calcGroupHeight(cur);
|
|
168
|
+
const findMinHeightGroup = (groups) => {
|
|
169
|
+
let minHeight = Infinity;
|
|
170
|
+
let index = 0;
|
|
171
|
+
for (let i = 0; i < groups.length; i++) {
|
|
172
|
+
const height = calcColumnHeight(groups[i]);
|
|
173
|
+
if (height < minHeight) {
|
|
174
|
+
index = i;
|
|
175
|
+
minHeight = height;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return groups[index];
|
|
179
|
+
};
|
|
180
|
+
if (acc.length >= column) {
|
|
181
|
+
const minHeightGroup = findMinHeightGroup(acc);
|
|
182
|
+
minHeightGroup === null || minHeightGroup === void 0 ? void 0 : minHeightGroup.push(cur);
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
if (currentColumnHeight + nextGroupHeight > 440) {
|
|
186
|
+
acc.push([cur]);
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
(_a = acc[(acc === null || acc === void 0 ? void 0 : acc.length) - 1]) === null || _a === void 0 ? void 0 : _a.push(cur);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
return acc;
|
|
194
|
+
}, []);
|
|
195
|
+
};
|
|
196
|
+
const groupMenus = calcGroupMenus((activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.children) || menus);
|
|
197
|
+
const [searchedMenus, setSearchedMenus] = useState([]);
|
|
198
|
+
const onMenuClick = (menu) => {
|
|
199
|
+
actions.emit('menuSelect', { key: menu.code, data: menu });
|
|
268
200
|
setSearchValue('');
|
|
269
201
|
setSearchedMenus([]);
|
|
270
202
|
close();
|
|
271
|
-
}
|
|
272
203
|
};
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
})
|
|
204
|
+
const debounceSearch = debounce((evt) => {
|
|
205
|
+
var _a;
|
|
206
|
+
const value = (_a = evt.target.value) === null || _a === void 0 ? void 0 : _a.trim();
|
|
207
|
+
const matchedMenus = [];
|
|
208
|
+
if (value) {
|
|
209
|
+
traverseTree(menus, (node) => {
|
|
210
|
+
var _a;
|
|
211
|
+
if (node.path && ((_a = node === null || node === void 0 ? void 0 : node.menuName) === null || _a === void 0 ? void 0 : _a.includes(value))) {
|
|
212
|
+
matchedMenus.push(node);
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
setSearchedMenus(matchedMenus);
|
|
217
|
+
}, 100);
|
|
218
|
+
const onSearchChange = (evt) => {
|
|
219
|
+
evt.persist();
|
|
220
|
+
setSearchValue(evt.target.value);
|
|
221
|
+
debounceSearch(evt);
|
|
222
|
+
};
|
|
223
|
+
const onSelectAppTab = (menu) => {
|
|
224
|
+
setActiveTopMenu(menu);
|
|
225
|
+
};
|
|
226
|
+
useEffect(() => {
|
|
227
|
+
const clickOutside = (evt) => {
|
|
228
|
+
const { clientX, clientY, pageX, pageY } = evt;
|
|
229
|
+
const isOutside = (evt, popup) => {
|
|
230
|
+
if (popup === null || popup === void 0 ? void 0 : popup.contains) {
|
|
231
|
+
return !(popup === null || popup === void 0 ? void 0 : popup.contains(evt.target));
|
|
232
|
+
}
|
|
233
|
+
let { x, y, height, width } = popup.getBoundingClientRect();
|
|
234
|
+
x += window.scrollX;
|
|
235
|
+
y += window.scrollY;
|
|
236
|
+
return pageX < x || pageX > x + width || pageY < y || pageY > y + height;
|
|
237
|
+
};
|
|
238
|
+
if (isOutside(evt, popupRef.current)) {
|
|
239
|
+
setSearchValue('');
|
|
240
|
+
setSearchedMenus([]);
|
|
241
|
+
close();
|
|
242
|
+
}
|
|
243
|
+
};
|
|
244
|
+
document.addEventListener('click', clickOutside);
|
|
245
|
+
return () => document.removeEventListener('click', clickOutside);
|
|
246
|
+
}, []);
|
|
247
|
+
return (React.createElement(React.Fragment, null,
|
|
248
|
+
React.createElement(SearchArea, { theme: theme, className: cn({ active }) },
|
|
249
|
+
React.createElement(Icon, { type: "search" }),
|
|
250
|
+
React.createElement("input", { placeholder: actions === null || actions === void 0 ? void 0 : actions.getText('menuSearch'), value: searchValue, onChange: onSearchChange, onFocus: () => setActive(true), onBlur: () => setActive(false) }),
|
|
251
|
+
React.createElement(Icon, { type: "close", onClick: close }),
|
|
252
|
+
(searchedMenus === null || searchedMenus === void 0 ? void 0 : searchedMenus.length) > 0 && (React.createElement(SearchList, { items: searchedMenus, theme: theme, onSelectMenu: onMenuClick }))),
|
|
253
|
+
isLevel3 && (React.createElement(ApplicationTabs, { theme: theme }, menus === null || menus === void 0 ? void 0 : menus.map((menu) => (React.createElement("li", { className: cn({ active: menu.code === (activeTopMenu === null || activeTopMenu === void 0 ? void 0 : activeTopMenu.code) }), onClick: () => onSelectAppTab(menu) }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'groupName' : 'enName']))))),
|
|
254
|
+
React.createElement(GroupMenus, { theme: theme, isLevel3: isLevel3 }, groupMenus === null || groupMenus === void 0 ? void 0 : groupMenus.map((groups) => (React.createElement("div", null, groups === null || groups === void 0 ? void 0 : groups.map((group) => (React.createElement(GroupMenuItem, { theme: theme },
|
|
255
|
+
React.createElement("h5", null, group === null || group === void 0 ? void 0 : group[language === 'cn' ? 'groupName' : 'enName']),
|
|
256
|
+
React.createElement(MenuList, null, (group.children || []).map((menu) => (React.createElement(MenuItem, { key: menu.code, className: cn({ active: selectedMenuKey === menu.code }), theme: theme, onClick: () => onMenuClick(menu) },
|
|
257
|
+
React.createElement("a", { href: menu.path, onClick: (evt) => evt.preventDefault() }, menu === null || menu === void 0 ? void 0 : menu[language === 'cn' ? 'menuName' : 'enName']))))))))))))));
|
|
258
|
+
};
|
|
259
|
+
//# sourceMappingURL=NavigationPopup.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n console.log('clickOutside...', [x, y], [clientX, clientY], [pageX, pageY])\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}
|
|
1
|
+
{"version":3,"file":"NavigationPopup.js","sourceRoot":"","sources":["../../../src/tntd-layout/GlobalNavigation/NavigationPopup.js"],"names":[],"mappings":"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","sourcesContent":["import React, { useState, useEffect } from 'react'\nimport cn from 'classnames'\nimport styled from 'styled-components'\nimport { debounce } from 'lodash'\nimport { traverseTree, hasLevel3 } from '../../utils'\nimport Icon from '../Iconfont'\nimport { getText } from '../../locale'\n\nconst SearchArea = styled.div`\n position: relative;\n font-size: 14px;\n margin-bottom: 20px;\n color: ${(props) => props.theme.secondaryTextColor};\n &.active {\n color: ${(props) => props.theme.primaryColor};\n input {\n border-color: ${(props) => props.theme.primaryColor};\n }\n }\n .tnt-icon {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n line-height: 1em;\n &[type='close'] {\n right: 0;\n top: 0;\n font-size: 18px;\n cursor: pointer;\n }\n }\n input {\n border-width: 0 0 1px;\n border-style: solid;\n border-color: ${(props) => props.theme.borderColor};\n width: 100%;\n padding: 4px 20px;\n line-height: 20px;\n background-color: transparent;\n outline: none;\n }\n`\n\nconst ApplicationTabs = styled.ul`\n border: 1px solid ${(props) => props.theme.borderColor};\n color: ${(props) => props.theme.primaryTextColor};\n line-height: 32px;\n margin: 0 0 16px;\n padding: 0;\n display: inline-block;\n\n & > li {\n padding: 0 20px;\n display: inline-block;\n cursor: pointer;\n &:not(:last-child) {\n border-right: 1px solid ${(props) => props.theme.borderColor};\n }\n &.active {\n background-color: ${(props) => props.theme.primaryColor};\n color: #fff;\n }\n }\n`\n\nconst GroupMenus = styled.div`\n height: ${(props) => (props.isLevel3 ? 'calc(100% - 80px)' : 'calc(100% - 50px)')};\n overflow: auto;\n & > div {\n width: 200px;\n margin-right: 10px;\n display: inline-block;\n vertical-align: top;\n }\n`\n\nconst GroupMenuItem = styled.div`\n margin-bottom: 20px;\n & > h5 {\n line-height: 20px;\n margin: 0;\n margin-bottom: 6px;\n }\n`\n\nconst MenuList = styled.ul`\n list-style: none;\n padding: 0;\n margin: 0;\n`\n\nconst MenuItem = styled.li`\n display: block;\n line-height: 30px;\n font-size: 12px;\n cursor: pointer;\n a {\n color: ${(props) => props.theme.secondaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor} !important;\n }\n }\n &.active a {\n color: ${(props) => props.theme.primaryColor};\n }\n`\n\nconst ListBox = styled.ul`\n background: #fff;\n max-height: 320px;\n overflow-y: auto;\n margin: 0;\n padding: 6px 0;\n list-style: none;\n font-size: 13px;\n position: absolute;\n top: 29px;\n width: 100%;\n box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n li {\n cursor: pointer;\n line-height: 32px;\n padding: 0 10px;\n color: ${(props) => props.theme.primaryTextColor};\n &:hover {\n color: ${(props) => props.theme.secondaryColor};\n background-color: ${(props) => props.theme.lightBgColor};\n }\n }\n`\n\nconst SearchList = ({ items, onSelectMenu, theme }) => (\n <ListBox theme={theme}>\n {items?.map((item) => (\n <li onClick={() => onSelectMenu(item)}>{item?.menuName}</li>\n ))}\n </ListBox>\n)\n\nexport default ({ theme, menus = [], close, actions, popupRef, containerRef }) => {\n const [active, setActive] = useState(false)\n const [searchValue, setSearchValue] = useState()\n const language = actions?.getLanguage()\n const isLevel3 = hasLevel3(menus)\n const [activeTopMenu, setActiveTopMenu] = useState(isLevel3 ? menus?.[0] : null)\n const selectedMenuKey = actions.getSelectedMenuKey()\n const calcGroupMenus = (menus) => {\n menus = menus?.reduce((acc, cur) => {\n // 分组\n if (cur?.children?.length) {\n acc.push(cur)\n } else {\n const defaultGroup = acc.find(({ isDefaultGroup }) => isDefaultGroup)\n if (!defaultGroup) {\n acc.unshift({\n isDefaultGroup: true,\n children: [cur],\n })\n } else {\n defaultGroup.children.push(cur)\n }\n }\n return acc\n }, [])\n\n return menus?.reduce((acc, cur) => {\n const column = Math.max(1, ~~((containerRef.current.clientWidth - 32) / 210))\n\n if (!acc.length) {\n acc.push([cur])\n } else {\n const calcGroupHeight = (group) => 46 + (group?.children?.length || 0) * 30\n const calcColumnHeight = (columnGroups) =>\n columnGroups?.reduce((acc, cur) => {\n acc += calcGroupHeight(cur)\n return acc\n }, 0)\n const currentColumnHeight = calcColumnHeight(acc[acc.length - 1])\n const nextGroupHeight = calcGroupHeight(cur)\n const findMinHeightGroup = (groups) => {\n let minHeight = Infinity\n let index = 0\n\n for (let i = 0; i < groups.length; i++) {\n const height = calcColumnHeight(groups[i])\n if (height < minHeight) {\n index = i\n minHeight = height\n }\n }\n\n return groups[index]\n }\n\n if (acc.length >= column) {\n const minHeightGroup = findMinHeightGroup(acc)\n minHeightGroup?.push(cur)\n } else {\n if (currentColumnHeight + nextGroupHeight > 440) {\n acc.push([cur])\n } else {\n acc[acc?.length - 1]?.push(cur)\n }\n }\n }\n\n return acc\n }, [])\n }\n const groupMenus = calcGroupMenus(activeTopMenu?.children || menus)\n const [searchedMenus, setSearchedMenus] = useState([])\n\n const onMenuClick = (menu) => {\n actions.emit('menuSelect', { key: menu.code, data: menu })\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n const debounceSearch = debounce((evt) => {\n const value = evt.target.value?.trim()\n const matchedMenus = []\n\n if (value) {\n traverseTree(menus, (node) => {\n if (node.path && node?.menuName?.includes(value)) {\n matchedMenus.push(node)\n }\n })\n }\n\n setSearchedMenus(matchedMenus)\n }, 100)\n\n const onSearchChange = (evt) => {\n evt.persist()\n setSearchValue(evt.target.value)\n debounceSearch(evt)\n }\n\n const onSelectAppTab = (menu) => {\n setActiveTopMenu(menu)\n }\n\n useEffect(() => {\n const clickOutside = (evt) => {\n const { clientX, clientY, pageX, pageY } = evt\n const isOutside = (evt, popup) => {\n if (popup?.contains) {\n return !popup?.contains(evt.target)\n }\n\n let { x, y, height, width } = popup.getBoundingClientRect()\n x += window.scrollX\n y += window.scrollY\n\n return pageX < x || pageX > x + width || pageY < y || pageY > y + height\n }\n\n if (isOutside(evt, popupRef.current)) {\n setSearchValue('')\n setSearchedMenus([])\n close()\n }\n }\n\n document.addEventListener('click', clickOutside)\n return () => document.removeEventListener('click', clickOutside)\n }, [])\n\n return (\n <>\n <SearchArea theme={theme} className={cn({ active })}>\n <Icon type=\"search\" />\n <input\n placeholder={actions?.getText('menuSearch')}\n value={searchValue}\n onChange={onSearchChange}\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <Icon type=\"close\" onClick={close} />\n {searchedMenus?.length > 0 && (\n <SearchList items={searchedMenus} theme={theme} onSelectMenu={onMenuClick} />\n )}\n </SearchArea>\n {isLevel3 && (\n <ApplicationTabs theme={theme}>\n {menus?.map((menu) => (\n <li\n className={cn({ active: menu.code === activeTopMenu?.code })}\n onClick={() => onSelectAppTab(menu)}\n >\n {menu?.[language === 'cn' ? 'groupName' : 'enName']}\n </li>\n ))}\n </ApplicationTabs>\n )}\n <GroupMenus theme={theme} isLevel3={isLevel3}>\n {groupMenus?.map((groups) => (\n <div>\n {groups?.map((group) => (\n <GroupMenuItem theme={theme}>\n <h5>{group?.[language === 'cn' ? 'groupName' : 'enName']}</h5>\n <MenuList>\n {(group.children || []).map((menu) => (\n <MenuItem\n key={menu.code}\n className={cn({ active: selectedMenuKey === menu.code })}\n theme={theme}\n onClick={() => onMenuClick(menu)}\n >\n <a href={menu.path} onClick={(evt) => evt.preventDefault()}>\n {menu?.[language === 'cn' ? 'menuName' : 'enName']}\n </a>\n </MenuItem>\n ))}\n </MenuList>\n </GroupMenuItem>\n ))}\n </div>\n ))}\n </GroupMenus>\n </>\n )\n}\n"]}
|