@ant-design/pro-components 3.1.0-0 → 3.1.1-1
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/README.es-PR.md +1 -3
- package/README.md +8 -10
- package/README.zh-CN.md +11 -11
- package/dist/pro-components.min.js +1 -1
- package/es/card/ProCard.js +8 -10
- package/es/card/components/Actions/index.js +25 -25
- package/es/card/components/Actions/style.js +79 -71
- package/es/card/components/Card/index.js +157 -142
- package/es/card/components/Card/style.js +249 -192
- package/es/card/components/CheckCard/Group.js +94 -115
- package/es/card/components/CheckCard/index.js +85 -79
- package/es/card/components/CheckCard/style.js +184 -168
- package/es/card/components/Divider/index.js +19 -15
- package/es/card/components/Divider/style.js +32 -29
- package/es/card/components/Loading/index.js +19 -16
- package/es/card/components/Loading/style.js +34 -31
- package/es/card/components/Operation/index.js +16 -13
- package/es/card/components/Operation/style.js +19 -18
- package/es/card/components/Statistic/index.js +46 -41
- package/es/card/components/Statistic/style.js +89 -70
- package/es/card/components/StatisticCard/index.js +46 -41
- package/es/card/components/StatisticCard/style.js +37 -35
- package/es/descriptions/index.js +214 -225
- package/es/descriptions/useFetchData.js +53 -91
- package/es/field/AllProField.js +265 -216
- package/es/field/FieldHOC/index.js +9 -14
- package/es/field/PureProField.js +82 -80
- package/es/field/ValueTypeToComponent.js +517 -618
- package/es/field/components/Cascader/index.d.ts +3 -3
- package/es/field/components/Cascader/index.js +66 -84
- package/es/field/components/Checkbox/index.d.ts +2 -2
- package/es/field/components/Checkbox/index.js +75 -72
- package/es/field/components/Code/index.js +40 -39
- package/es/field/components/ColorPicker/index.d.ts +2 -2
- package/es/field/components/ColorPicker/index.js +38 -32
- package/es/field/components/DatePicker/index.d.ts +2 -2
- package/es/field/components/DatePicker/index.js +49 -53
- package/es/field/components/Digit/index.js +41 -42
- package/es/field/components/DigitRange/index.js +71 -77
- package/es/field/components/FromNow/index.js +27 -25
- package/es/field/components/Image/index.js +28 -24
- package/es/field/components/IndexColumn/index.js +22 -16
- package/es/field/components/Money/index.js +107 -116
- package/es/field/components/Options/index.js +34 -33
- package/es/field/components/Password/index.js +35 -38
- package/es/field/components/Percent/index.js +40 -44
- package/es/field/components/Percent/util.js +3 -5
- package/es/field/components/Progress/index.js +29 -27
- package/es/field/components/Radio/index.d.ts +1 -1
- package/es/field/components/Radio/index.js +61 -62
- package/es/field/components/RangePicker/index.d.ts +2 -2
- package/es/field/components/RangePicker/index.js +52 -63
- package/es/field/components/Rate/index.js +24 -21
- package/es/field/components/Second/index.js +36 -33
- package/es/field/components/Segmented/index.d.ts +1 -1
- package/es/field/components/Segmented/index.js +37 -46
- package/es/field/components/Select/LightSelect/index.d.ts +1 -1
- package/es/field/components/Select/LightSelect/index.js +102 -109
- package/es/field/components/Select/SearchSelect/index.js +129 -155
- package/es/field/components/Select/index.d.ts +2 -2
- package/es/field/components/Select/index.js +193 -219
- package/es/field/components/Slider/index.js +25 -22
- package/es/field/components/Status/index.js +67 -78
- package/es/field/components/Switch/index.d.ts +1 -1
- package/es/field/components/Switch/index.js +32 -30
- package/es/field/components/Text/index.js +34 -37
- package/es/field/components/TextArea/index.js +26 -21
- package/es/field/components/TextArea/readonly.js +24 -21
- package/es/field/components/TimePicker/index.js +96 -105
- package/es/field/components/TreeSelect/index.d.ts +3 -3
- package/es/field/components/TreeSelect/index.js +107 -125
- package/es/form/BaseForm/BaseForm.js +416 -502
- package/es/form/BaseForm/EditOrReadOnlyContext.js +1 -1
- package/es/form/BaseForm/LightWrapper/index.js +56 -65
- package/es/form/BaseForm/LightWrapper/style.js +17 -13
- package/es/form/BaseForm/Submitter/index.js +44 -43
- package/es/form/FieldContext.js +1 -1
- package/es/form/components/Captcha/index.js +74 -134
- package/es/form/components/Cascader/index.d.ts +1 -1
- package/es/form/components/Cascader/index.js +26 -28
- package/es/form/components/Checkbox/index.js +60 -61
- package/es/form/components/ColorPicker/index.d.ts +1 -1
- package/es/form/components/ColorPicker/index.js +24 -26
- package/es/form/components/DatePicker/BaseDatePicker.js +32 -30
- package/es/form/components/DatePicker/DatePicker.js +14 -13
- package/es/form/components/DatePicker/DateTimePicker.js +11 -12
- package/es/form/components/DatePicker/MonthPicker.js +14 -13
- package/es/form/components/DatePicker/QuarterPicker.js +14 -13
- package/es/form/components/DatePicker/TimePicker.js +26 -27
- package/es/form/components/DatePicker/WeekPicker.js +14 -13
- package/es/form/components/DatePicker/YearPicker.js +14 -13
- package/es/form/components/DatePicker/index.js +1 -1
- package/es/form/components/DateRangePicker/BaseDateRanger.js +34 -34
- package/es/form/components/DateRangePicker/DateMonthRangePicker.js +15 -16
- package/es/form/components/DateRangePicker/DateQuarterRangePicker.js +15 -16
- package/es/form/components/DateRangePicker/DateTimeRangePicker.js +15 -16
- package/es/form/components/DateRangePicker/DateWeekRangePicker.js +15 -16
- package/es/form/components/DateRangePicker/DateYearRangePicker.js +15 -16
- package/es/form/components/DateRangePicker/TimeRangePicker.js +26 -29
- package/es/form/components/DateRangePicker/index.js +15 -16
- package/es/form/components/Dependency/index.js +31 -34
- package/es/form/components/Digit/DigitRange.d.ts +2 -2
- package/es/form/components/Digit/DigitRange.js +23 -24
- package/es/form/components/Digit/index.d.ts +1 -1
- package/es/form/components/Digit/index.js +27 -29
- package/es/form/components/Field/index.js +55 -63
- package/es/form/components/FieldSet/index.js +68 -76
- package/es/form/components/FormItem/FormItemRender/index.js +58 -48
- package/es/form/components/FormItem/Group/index.js +95 -95
- package/es/form/components/FormItem/Group/style.js +46 -40
- package/es/form/components/FormItem/index.js +135 -141
- package/es/form/components/FormItem/warpField.js +165 -149
- package/es/form/components/List/ListContainer.js +98 -189
- package/es/form/components/List/ListItem.js +151 -198
- package/es/form/components/List/index.js +97 -107
- package/es/form/components/List/style.js +71 -47
- package/es/form/components/Money/index.d.ts +1 -1
- package/es/form/components/Money/index.js +28 -30
- package/es/form/components/Radio/index.d.ts +2 -2
- package/es/form/components/Radio/index.js +45 -49
- package/es/form/components/Rate/index.d.ts +1 -1
- package/es/form/components/Rate/index.js +17 -20
- package/es/form/components/SchemaForm/index.js +58 -72
- package/es/form/components/SchemaForm/layoutType/Embed.js +5 -6
- package/es/form/components/SchemaForm/layoutType/StepsForm.js +22 -26
- package/es/form/components/SchemaForm/valueType/dependency.js +11 -11
- package/es/form/components/SchemaForm/valueType/divider.js +4 -5
- package/es/form/components/SchemaForm/valueType/field.js +45 -44
- package/es/form/components/SchemaForm/valueType/formList.js +8 -7
- package/es/form/components/SchemaForm/valueType/formSet.js +8 -7
- package/es/form/components/SchemaForm/valueType/group.js +7 -8
- package/es/form/components/SchemaForm/valueType/ignore.js +2 -2
- package/es/form/components/SchemaForm/valueType/index.js +5 -5
- package/es/form/components/Segmented/index.js +20 -23
- package/es/form/components/Select/index.js +69 -73
- package/es/form/components/Slider/index.d.ts +1 -1
- package/es/form/components/Slider/index.js +33 -35
- package/es/form/components/Switch/index.js +24 -26
- package/es/form/components/Text/index.js +75 -86
- package/es/form/components/TextArea/index.d.ts +1 -1
- package/es/form/components/TextArea/index.js +17 -20
- package/es/form/components/TreeSelect/index.js +20 -23
- package/es/form/components/UploadButton/index.js +56 -103
- package/es/form/components/UploadDragger/index.js +37 -44
- package/es/form/helpers/grid.js +65 -67
- package/es/form/layouts/DrawerForm/index.js +150 -241
- package/es/form/layouts/DrawerForm/style.js +26 -25
- package/es/form/layouts/LightFilter/index.d.ts +12 -1
- package/es/form/layouts/LightFilter/index.js +158 -140
- package/es/form/layouts/LightFilter/style.js +52 -48
- package/es/form/layouts/LoginForm/index.js +44 -47
- package/es/form/layouts/LoginForm/style.js +71 -67
- package/es/form/layouts/LoginFormPage/index.js +45 -48
- package/es/form/layouts/LoginFormPage/style.js +136 -126
- package/es/form/layouts/ModalForm/index.js +119 -203
- package/es/form/layouts/ProForm/index.d.ts +2 -2
- package/es/form/layouts/ProForm/index.js +5 -5
- package/es/form/layouts/QueryFilter/Actions.js +23 -22
- package/es/form/layouts/QueryFilter/index.js +178 -203
- package/es/form/layouts/QueryFilter/style.js +45 -37
- package/es/form/layouts/StepsForm/StepForm.d.ts +2 -3
- package/es/form/layouts/StepsForm/StepForm.js +50 -71
- package/es/form/layouts/StepsForm/index.js +175 -217
- package/es/form/layouts/StepsForm/style.js +30 -28
- package/es/form/layouts/index.js +1 -1
- package/es/layout/ProLayout.js +281 -292
- package/es/layout/WrapContent.js +16 -12
- package/es/layout/assert/Logo.js +95 -97
- package/es/layout/components/AppsLogoComponents/AppsLogo.js +10 -12
- package/es/layout/components/AppsLogoComponents/DefaultContent.js +17 -16
- package/es/layout/components/AppsLogoComponents/SimpleContent.js +19 -18
- package/es/layout/components/AppsLogoComponents/index.js +33 -38
- package/es/layout/components/AppsLogoComponents/style/default.js +2 -2
- package/es/layout/components/AppsLogoComponents/style/index.js +52 -50
- package/es/layout/components/AppsLogoComponents/style/simple.js +1 -1
- package/es/layout/components/CollapsedIcon/index.js +18 -15
- package/es/layout/components/CollapsedIcon/style.js +40 -40
- package/es/layout/components/Footer.js +22 -21
- package/es/layout/components/FooterToolbar/index.js +58 -52
- package/es/layout/components/FooterToolbar/style/index.js +38 -37
- package/es/layout/components/FooterToolbar/style/stylish.js +11 -9
- package/es/layout/components/GlobalFooter/index.js +25 -25
- package/es/layout/components/GlobalFooter/style.js +31 -30
- package/es/layout/components/GlobalHeader/ActionsContent.js +62 -78
- package/es/layout/components/GlobalHeader/index.js +59 -47
- package/es/layout/components/GlobalHeader/rightContentStyle.js +49 -49
- package/es/layout/components/GlobalHeader/style.js +58 -54
- package/es/layout/components/GridContent/index.js +24 -19
- package/es/layout/components/GridContent/style.js +14 -13
- package/es/layout/components/Header/index.js +63 -57
- package/es/layout/components/Header/style/header.js +49 -47
- package/es/layout/components/Header/style/stylish.js +15 -11
- package/es/layout/components/Help/AsyncContentPanel.js +13 -18
- package/es/layout/components/Help/HelpProvide.js +1 -1
- package/es/layout/components/Help/ProHelpContentPanel.js +64 -83
- package/es/layout/components/Help/ProHelpDrawer.js +25 -31
- package/es/layout/components/Help/ProHelpModal.d.ts +1 -1
- package/es/layout/components/Help/ProHelpModal.js +24 -27
- package/es/layout/components/Help/ProHelpPanel.js +86 -94
- package/es/layout/components/Help/ProHelpPopover.js +18 -16
- package/es/layout/components/Help/RenderContentPanel.js +34 -24
- package/es/layout/components/Help/Search.js +52 -78
- package/es/layout/components/Help/index.js +9 -11
- package/es/layout/components/Help/style.js +82 -75
- package/es/layout/components/PageContainer/index.js +168 -149
- package/es/layout/components/PageContainer/style/index.js +95 -78
- package/es/layout/components/PageContainer/style/stylish.js +11 -9
- package/es/layout/components/PageHeader/index.js +96 -97
- package/es/layout/components/PageHeader/style/index.js +142 -122
- package/es/layout/components/PageLoading/index.js +17 -20
- package/es/layout/components/SettingDrawer/BlockCheckbox.js +29 -32
- package/es/layout/components/SettingDrawer/LayoutChange.js +22 -22
- package/es/layout/components/SettingDrawer/RegionalChange.js +14 -15
- package/es/layout/components/SettingDrawer/ThemeColor.js +32 -35
- package/es/layout/components/SettingDrawer/index.js +137 -168
- package/es/layout/components/SettingDrawer/style/index.js +141 -137
- package/es/layout/components/SiderMenu/BaseMenu.js +235 -221
- package/es/layout/components/SiderMenu/SiderMenu.js +125 -115
- package/es/layout/components/SiderMenu/index.js +47 -42
- package/es/layout/components/SiderMenu/style/index.js +179 -161
- package/es/layout/components/SiderMenu/style/menu.js +148 -110
- package/es/layout/components/SiderMenu/style/stylish.js +15 -11
- package/es/layout/components/TopNavHeader/index.js +71 -60
- package/es/layout/components/TopNavHeader/style.js +64 -63
- package/es/layout/context/RouteContext.js +1 -1
- package/es/layout/defaultSettings.js +1 -1
- package/es/layout/getPageTitle.js +23 -24
- package/es/layout/locales/en-US.js +3 -2
- package/es/layout/locales/index.js +5 -5
- package/es/layout/locales/it-IT.js +3 -2
- package/es/layout/locales/ko-KR.js +3 -2
- package/es/layout/locales/zh-CN.js +3 -2
- package/es/layout/locales/zh-TW.js +3 -2
- package/es/layout/style/index.js +48 -42
- package/es/layout/utils/getBreadcrumbProps.js +60 -60
- package/es/layout/utils/getMenuData.js +7 -11
- package/es/layout/utils/pathTools.js +2 -6
- package/es/layout/utils/useCurrentMenuLayoutProps.js +4 -9
- package/es/layout/utils/utils.js +15 -17
- package/es/list/Item.js +157 -137
- package/es/list/ListView.js +106 -115
- package/es/list/constants.js +2 -2
- package/es/list/index.js +72 -70
- package/es/list/style/index.js +281 -213
- package/es/provider/index.js +122 -115
- package/es/provider/intl.js +53 -55
- package/es/provider/typing/layoutToken.js +26 -23
- package/es/provider/useStyle/index.js +51 -59
- package/es/provider/utils/merge.js +10 -12
- package/es/skeleton/components/Descriptions/index.js +211 -229
- package/es/skeleton/components/List/index.js +208 -223
- package/es/skeleton/components/Result/index.js +45 -47
- package/es/skeleton/index.js +13 -10
- package/es/table/Store/Provide.d.ts +4 -4
- package/es/table/Store/Provide.js +102 -117
- package/es/table/Table.d.ts +5 -2
- package/es/table/Table.js +526 -691
- package/es/table/TableSearch.d.ts +24 -0
- package/es/table/TableSearch.js +54 -0
- package/es/table/TableToolbar.d.ts +22 -0
- package/es/table/TableToolbar.js +47 -0
- package/es/table/components/Alert/index.js +41 -40
- package/es/table/components/Alert/style.js +28 -27
- package/es/table/components/ColumnSetting/index.js +228 -223
- package/es/table/components/ColumnSetting/style.js +86 -71
- package/es/table/components/DragSortTable/index.js +65 -79
- package/es/table/components/DragSortTable/style.js +20 -19
- package/es/table/components/Dropdown/index.js +42 -47
- package/es/table/components/EditableTable/CellEditorTable.js +24 -32
- package/es/table/components/EditableTable/RowEditorTable.js +23 -28
- package/es/table/components/EditableTable/index.js +295 -329
- package/es/table/components/Form/FormRender.js +99 -103
- package/es/table/components/Form/index.d.ts +4 -19
- package/es/table/components/Form/index.js +112 -159
- package/es/table/components/ListToolBar/HeaderMenu.js +44 -52
- package/es/table/components/ListToolBar/index.js +122 -147
- package/es/table/components/ListToolBar/style.js +127 -117
- package/es/table/components/ToolBar/DensityIcon.js +10 -9
- package/es/table/components/ToolBar/FullscreenIcon.js +5 -9
- package/es/table/components/ToolBar/index.d.ts +2 -8
- package/es/table/components/ToolBar/index.js +155 -195
- package/es/table/style/index.js +144 -112
- package/es/table/typing.d.ts +4 -0
- package/es/table/useFetchData.js +199 -338
- package/es/table/utils/cellRenderToFromItem.js +105 -119
- package/es/table/utils/columnRender.js +63 -54
- package/es/table/utils/columnSort.js +22 -22
- package/es/table/utils/genProColumnToColumn.d.ts +13 -9
- package/es/table/utils/genProColumnToColumn.js +121 -98
- package/es/table/utils/index.d.ts +10 -0
- package/es/table/utils/index.js +112 -178
- package/es/table/utils/useDragSort.d.ts +1 -1
- package/es/table/utils/useDragSort.js +99 -92
- package/es/table/utils/usePageInfo.d.ts +6 -0
- package/es/table/utils/usePageInfo.js +55 -0
- package/es/utils/components/DropdownFooter/index.js +23 -21
- package/es/utils/components/DropdownFooter/style.js +16 -15
- package/es/utils/components/ErrorBoundary/index.js +27 -50
- package/es/utils/components/FieldLabel/index.js +70 -70
- package/es/utils/components/FieldLabel/style.js +104 -81
- package/es/utils/components/FilterDropdown/index.d.ts +11 -0
- package/es/utils/components/FilterDropdown/index.js +43 -32
- package/es/utils/components/FilterDropdown/style.js +19 -16
- package/es/utils/components/InlineErrorFormItem/index.js +78 -78
- package/es/utils/components/InlineErrorFormItem/style.js +56 -49
- package/es/utils/components/LabelIconTip/index.js +30 -31
- package/es/utils/components/LabelIconTip/style.js +36 -35
- package/es/utils/components/ProFormContext/index.js +1 -1
- package/es/utils/conversionMomentValue/index.js +19 -22
- package/es/utils/dateArrayFormatter/index.js +9 -14
- package/es/utils/genCopyable/index.js +74 -32
- package/es/utils/getFieldPropsOrFormItemProps/index.js +1 -1
- package/es/utils/hooks/useDebounceFn/index.js +18 -51
- package/es/utils/hooks/useDebounceValue/index.js +7 -16
- package/es/utils/hooks/useDeepCompareEffect/index.js +6 -18
- package/es/utils/hooks/useDocumentTitle/index.js +2 -2
- package/es/utils/hooks/useFetchData/index.js +36 -65
- package/es/utils/hooks/useForceRender/index.js +2 -9
- package/es/utils/hooks/useLatest/index.js +2 -2
- package/es/utils/hooks/usePrevious/index.js +3 -3
- package/es/utils/hooks/useReactiveRef/index.js +2 -2
- package/es/utils/hooks/useRefCallback/index.js +3 -3
- package/es/utils/hooks/useRefFunction/index.js +4 -9
- package/es/utils/index.d.ts +1 -2
- package/es/utils/index.js +1 -2
- package/es/utils/isBrowser/index.js +2 -2
- package/es/utils/isDeepEqualReact/index.js +9 -44
- package/es/utils/isDropdownValueType/index.js +2 -2
- package/es/utils/isNil/index.js +1 -3
- package/es/utils/isUrl/index.js +2 -2
- package/es/utils/merge/index.js +10 -12
- package/es/utils/nanoid/index.js +5 -6
- package/es/utils/omitBoolean/index.js +1 -1
- package/es/utils/omitUndefined/index.js +3 -3
- package/es/utils/omitUndefinedAndEmptyArr/index.js +4 -5
- package/es/utils/parseValueToMoment/index.js +3 -7
- package/es/utils/pickProFormItemProps/index.js +3 -3
- package/es/utils/pickProProps/index.js +6 -7
- package/es/utils/proFieldParsingText/index.js +85 -98
- package/es/utils/runFunction/index.js +2 -5
- package/es/utils/stringify/index.js +1 -1
- package/es/utils/transformKeySubmitValue/index.js +99 -116
- package/es/utils/useEditableArray/index.d.ts +6 -1
- package/es/utils/useEditableArray/index.js +579 -735
- package/es/utils/useEditableMap/index.d.ts +1 -1
- package/es/utils/useEditableMap/index.js +89 -135
- package/es/utils/useMediaQuery/index.d.ts +2 -2
- package/es/utils/useMediaQuery/index.js +37 -34
- package/es/utils/useMediaQuery/query.js +7 -17
- package/es/version.js +1 -1
- package/guidelines/Guidelines.md +33 -0
- package/guidelines/components/drawer-form.md +90 -0
- package/guidelines/components/editable-pro-table.md +150 -0
- package/guidelines/components/modal-form.md +88 -0
- package/guidelines/components/pro-card.md +90 -0
- package/guidelines/components/pro-form.md +96 -0
- package/guidelines/components/pro-layout.md +84 -0
- package/guidelines/components/pro-table.md +142 -0
- package/guidelines/components/steps-form.md +105 -0
- package/guidelines/design-tokens/colors.md +58 -0
- package/guidelines/design-tokens/layout.md +53 -0
- package/guidelines/design-tokens/typography.md +49 -0
- package/guidelines/overview-components.md +55 -0
- package/guidelines/overview-icons.md +23 -0
- package/lib/card/ProCard.js +8 -10
- package/lib/card/components/Actions/index.js +25 -25
- package/lib/card/components/Actions/style.js +79 -72
- package/lib/card/components/Card/index.js +154 -139
- package/lib/card/components/Card/style.js +249 -193
- package/lib/card/components/CheckCard/Group.js +97 -115
- package/lib/card/components/CheckCard/index.js +85 -78
- package/lib/card/components/CheckCard/style.js +184 -169
- package/lib/card/components/Divider/index.js +20 -16
- package/lib/card/components/Divider/style.js +32 -30
- package/lib/card/components/Loading/index.js +19 -16
- package/lib/card/components/Loading/style.js +34 -32
- package/lib/card/components/Operation/index.js +16 -14
- package/lib/card/components/Operation/style.js +19 -19
- package/lib/card/components/Statistic/index.js +46 -42
- package/lib/card/components/Statistic/style.js +89 -71
- package/lib/card/components/StatisticCard/index.js +46 -41
- package/lib/card/components/StatisticCard/style.js +37 -36
- package/lib/card/index.js +4 -4
- package/lib/descriptions/index.js +219 -225
- package/lib/descriptions/useFetchData.js +51 -90
- package/lib/field/AllProField.js +267 -217
- package/lib/field/FieldHOC/index.js +9 -15
- package/lib/field/PureProField.js +84 -82
- package/lib/field/ValueTypeToComponent.js +517 -618
- package/lib/field/components/Cascader/index.d.ts +2 -2
- package/lib/field/components/Cascader/index.js +66 -85
- package/lib/field/components/Checkbox/index.d.ts +1 -1
- package/lib/field/components/Checkbox/index.js +75 -73
- package/lib/field/components/Code/index.js +40 -39
- package/lib/field/components/ColorPicker/index.js +38 -33
- package/lib/field/components/DatePicker/index.d.ts +1 -1
- package/lib/field/components/DatePicker/index.js +49 -53
- package/lib/field/components/Digit/index.js +41 -43
- package/lib/field/components/DigitRange/index.js +69 -76
- package/lib/field/components/FromNow/index.js +27 -25
- package/lib/field/components/Image/index.js +28 -24
- package/lib/field/components/IndexColumn/index.js +22 -17
- package/lib/field/components/Money/index.js +106 -116
- package/lib/field/components/Options/index.js +34 -34
- package/lib/field/components/Password/index.js +35 -38
- package/lib/field/components/Percent/index.js +40 -45
- package/lib/field/components/Percent/util.js +3 -6
- package/lib/field/components/Progress/index.js +29 -28
- package/lib/field/components/Radio/index.d.ts +1 -1
- package/lib/field/components/Radio/index.js +61 -63
- package/lib/field/components/RangePicker/index.d.ts +1 -1
- package/lib/field/components/RangePicker/index.js +52 -63
- package/lib/field/components/Rate/index.js +24 -21
- package/lib/field/components/Second/index.js +36 -33
- package/lib/field/components/Segmented/index.d.ts +1 -1
- package/lib/field/components/Segmented/index.js +37 -48
- package/lib/field/components/Select/LightSelect/index.d.ts +1 -1
- package/lib/field/components/Select/LightSelect/index.js +103 -110
- package/lib/field/components/Select/SearchSelect/index.js +133 -156
- package/lib/field/components/Select/index.d.ts +1 -1
- package/lib/field/components/Select/index.js +194 -218
- package/lib/field/components/Slider/index.js +25 -22
- package/lib/field/components/Status/index.js +69 -79
- package/lib/field/components/Switch/index.d.ts +1 -1
- package/lib/field/components/Switch/index.js +32 -31
- package/lib/field/components/Text/index.js +34 -38
- package/lib/field/components/TextArea/index.js +26 -21
- package/lib/field/components/TextArea/readonly.js +24 -22
- package/lib/field/components/TimePicker/index.js +96 -105
- package/lib/field/components/TreeSelect/index.d.ts +2 -2
- package/lib/field/components/TreeSelect/index.js +105 -124
- package/lib/field/index.js +34 -34
- package/lib/form/BaseForm/BaseForm.js +413 -499
- package/lib/form/BaseForm/EditOrReadOnlyContext.js +1 -1
- package/lib/form/BaseForm/LightWrapper/index.js +57 -66
- package/lib/form/BaseForm/LightWrapper/style.js +17 -14
- package/lib/form/BaseForm/Submitter/index.js +44 -44
- package/lib/form/BaseForm/index.js +3 -3
- package/lib/form/FieldContext.js +1 -1
- package/lib/form/components/Captcha/index.js +74 -135
- package/lib/form/components/Cascader/index.js +26 -29
- package/lib/form/components/Checkbox/index.js +60 -61
- package/lib/form/components/ColorPicker/index.js +24 -26
- package/lib/form/components/DatePicker/BaseDatePicker.js +32 -30
- package/lib/form/components/DatePicker/DatePicker.js +14 -13
- package/lib/form/components/DatePicker/DateTimePicker.js +11 -12
- package/lib/form/components/DatePicker/MonthPicker.js +14 -13
- package/lib/form/components/DatePicker/QuarterPicker.js +14 -13
- package/lib/form/components/DatePicker/TimePicker.js +26 -27
- package/lib/form/components/DatePicker/WeekPicker.js +14 -13
- package/lib/form/components/DatePicker/YearPicker.js +14 -13
- package/lib/form/components/DatePicker/index.js +1 -1
- package/lib/form/components/DateRangePicker/BaseDateRanger.js +34 -34
- package/lib/form/components/DateRangePicker/DateMonthRangePicker.js +15 -16
- package/lib/form/components/DateRangePicker/DateQuarterRangePicker.js +15 -16
- package/lib/form/components/DateRangePicker/DateTimeRangePicker.js +15 -16
- package/lib/form/components/DateRangePicker/DateWeekRangePicker.js +15 -16
- package/lib/form/components/DateRangePicker/DateYearRangePicker.js +15 -16
- package/lib/form/components/DateRangePicker/TimeRangePicker.js +26 -29
- package/lib/form/components/DateRangePicker/index.js +15 -16
- package/lib/form/components/Dependency/index.js +31 -35
- package/lib/form/components/Digit/DigitRange.js +23 -24
- package/lib/form/components/Digit/index.js +27 -29
- package/lib/form/components/Field/index.js +55 -63
- package/lib/form/components/FieldSet/index.js +68 -76
- package/lib/form/components/FormItem/FormItemRender/index.js +58 -48
- package/lib/form/components/FormItem/Group/index.js +95 -95
- package/lib/form/components/FormItem/Group/style.js +46 -41
- package/lib/form/components/FormItem/index.js +135 -141
- package/lib/form/components/FormItem/warpField.js +165 -149
- package/lib/form/components/List/ListContainer.js +100 -191
- package/lib/form/components/List/ListItem.js +153 -200
- package/lib/form/components/List/index.js +97 -107
- package/lib/form/components/List/style.js +71 -48
- package/lib/form/components/Money/index.js +28 -30
- package/lib/form/components/Radio/index.js +45 -49
- package/lib/form/components/Rate/index.js +17 -21
- package/lib/form/components/SchemaForm/index.js +54 -68
- package/lib/form/components/SchemaForm/layoutType/Embed.js +5 -6
- package/lib/form/components/SchemaForm/layoutType/StepsForm.js +22 -26
- package/lib/form/components/SchemaForm/layoutType/index.js +2 -2
- package/lib/form/components/SchemaForm/valueType/dependency.js +13 -12
- package/lib/form/components/SchemaForm/valueType/divider.js +6 -7
- package/lib/form/components/SchemaForm/valueType/field.js +47 -45
- package/lib/form/components/SchemaForm/valueType/formList.js +10 -9
- package/lib/form/components/SchemaForm/valueType/formSet.js +10 -8
- package/lib/form/components/SchemaForm/valueType/group.js +9 -10
- package/lib/form/components/SchemaForm/valueType/ignore.js +4 -3
- package/lib/form/components/SchemaForm/valueType/index.js +7 -6
- package/lib/form/components/Segmented/index.js +20 -24
- package/lib/form/components/Select/index.js +69 -73
- package/lib/form/components/Slider/index.js +33 -35
- package/lib/form/components/Switch/index.js +24 -26
- package/lib/form/components/Text/index.js +73 -84
- package/lib/form/components/TextArea/index.js +17 -21
- package/lib/form/components/TreeSelect/index.js +20 -23
- package/lib/form/components/UploadButton/index.js +56 -103
- package/lib/form/components/UploadDragger/index.js +37 -44
- package/lib/form/components/index.js +42 -42
- package/lib/form/helpers/grid.js +68 -69
- package/lib/form/helpers/index.js +1 -1
- package/lib/form/index.js +8 -8
- package/lib/form/layouts/DrawerForm/index.js +149 -241
- package/lib/form/layouts/DrawerForm/style.js +26 -26
- package/lib/form/layouts/LightFilter/index.d.ts +12 -1
- package/lib/form/layouts/LightFilter/index.js +158 -141
- package/lib/form/layouts/LightFilter/style.js +52 -49
- package/lib/form/layouts/LoginForm/index.js +44 -48
- package/lib/form/layouts/LoginForm/style.js +71 -68
- package/lib/form/layouts/LoginFormPage/index.js +45 -49
- package/lib/form/layouts/LoginFormPage/style.js +136 -127
- package/lib/form/layouts/ModalForm/index.js +118 -203
- package/lib/form/layouts/ProForm/index.d.ts +1 -1
- package/lib/form/layouts/ProForm/index.js +5 -5
- package/lib/form/layouts/QueryFilter/Actions.js +23 -22
- package/lib/form/layouts/QueryFilter/index.js +177 -202
- package/lib/form/layouts/QueryFilter/style.js +45 -38
- package/lib/form/layouts/StepsForm/StepForm.d.ts +2 -3
- package/lib/form/layouts/StepsForm/StepForm.js +50 -72
- package/lib/form/layouts/StepsForm/index.js +174 -216
- package/lib/form/layouts/StepsForm/style.js +30 -29
- package/lib/form/layouts/index.js +9 -9
- package/lib/index.js +11 -11
- package/lib/layout/ProLayout.js +281 -292
- package/lib/layout/WrapContent.js +18 -14
- package/lib/layout/assert/Logo.js +96 -97
- package/lib/layout/components/AppsLogoComponents/AppsLogo.js +11 -12
- package/lib/layout/components/AppsLogoComponents/DefaultContent.js +19 -17
- package/lib/layout/components/AppsLogoComponents/SimpleContent.js +22 -19
- package/lib/layout/components/AppsLogoComponents/index.js +36 -40
- package/lib/layout/components/AppsLogoComponents/style/default.js +4 -3
- package/lib/layout/components/AppsLogoComponents/style/index.js +52 -51
- package/lib/layout/components/AppsLogoComponents/style/simple.js +3 -2
- package/lib/layout/components/CollapsedIcon/index.js +20 -17
- package/lib/layout/components/CollapsedIcon/style.js +40 -41
- package/lib/layout/components/Footer.js +23 -22
- package/lib/layout/components/FooterToolbar/index.js +59 -53
- package/lib/layout/components/FooterToolbar/style/index.js +38 -38
- package/lib/layout/components/FooterToolbar/style/stylish.js +11 -10
- package/lib/layout/components/GlobalFooter/index.js +27 -27
- package/lib/layout/components/GlobalFooter/style.js +31 -31
- package/lib/layout/components/GlobalHeader/ActionsContent.js +65 -81
- package/lib/layout/components/GlobalHeader/index.js +61 -49
- package/lib/layout/components/GlobalHeader/rightContentStyle.js +49 -50
- package/lib/layout/components/GlobalHeader/style.js +58 -55
- package/lib/layout/components/GridContent/index.js +26 -21
- package/lib/layout/components/GridContent/style.js +14 -14
- package/lib/layout/components/Header/index.js +65 -59
- package/lib/layout/components/Header/style/header.js +49 -48
- package/lib/layout/components/Header/style/stylish.js +15 -12
- package/lib/layout/components/Help/AsyncContentPanel.js +15 -20
- package/lib/layout/components/Help/HelpProvide.js +1 -1
- package/lib/layout/components/Help/ProHelpContentPanel.js +66 -85
- package/lib/layout/components/Help/ProHelpDrawer.js +27 -32
- package/lib/layout/components/Help/ProHelpModal.d.ts +1 -1
- package/lib/layout/components/Help/ProHelpModal.js +26 -28
- package/lib/layout/components/Help/ProHelpPanel.js +86 -94
- package/lib/layout/components/Help/ProHelpPopover.js +20 -18
- package/lib/layout/components/Help/RenderContentPanel.js +36 -26
- package/lib/layout/components/Help/Search.js +55 -80
- package/lib/layout/components/Help/index.js +19 -20
- package/lib/layout/components/Help/style.js +82 -76
- package/lib/layout/components/PageContainer/index.js +172 -151
- package/lib/layout/components/PageContainer/style/index.js +95 -79
- package/lib/layout/components/PageContainer/style/stylish.js +11 -10
- package/lib/layout/components/PageHeader/index.js +99 -99
- package/lib/layout/components/PageHeader/style/index.js +142 -123
- package/lib/layout/components/PageLoading/index.js +18 -20
- package/lib/layout/components/SettingDrawer/BlockCheckbox.js +31 -34
- package/lib/layout/components/SettingDrawer/LayoutChange.js +25 -23
- package/lib/layout/components/SettingDrawer/RegionalChange.js +16 -16
- package/lib/layout/components/SettingDrawer/ThemeColor.js +34 -36
- package/lib/layout/components/SettingDrawer/index.js +138 -168
- package/lib/layout/components/SettingDrawer/style/index.js +141 -138
- package/lib/layout/components/SiderMenu/BaseMenu.js +235 -221
- package/lib/layout/components/SiderMenu/SiderMenu.js +128 -117
- package/lib/layout/components/SiderMenu/index.js +49 -44
- package/lib/layout/components/SiderMenu/style/index.js +179 -162
- package/lib/layout/components/SiderMenu/style/menu.js +148 -111
- package/lib/layout/components/SiderMenu/style/stylish.js +15 -12
- package/lib/layout/components/TopNavHeader/index.js +73 -62
- package/lib/layout/components/TopNavHeader/style.js +64 -64
- package/lib/layout/context/RouteContext.js +1 -1
- package/lib/layout/defaultSettings.js +1 -1
- package/lib/layout/getPageTitle.js +27 -26
- package/lib/layout/index.js +16 -16
- package/lib/layout/locales/en-US.js +3 -2
- package/lib/layout/locales/index.js +8 -6
- package/lib/layout/locales/it-IT.js +3 -2
- package/lib/layout/locales/ko-KR.js +3 -2
- package/lib/layout/locales/zh-CN.js +3 -2
- package/lib/layout/locales/zh-TW.js +3 -2
- package/lib/layout/style/index.js +48 -43
- package/lib/layout/utils/getBreadcrumbProps.js +65 -62
- package/lib/layout/utils/getMenuData.js +9 -13
- package/lib/layout/utils/pathTools.js +2 -6
- package/lib/layout/utils/useCurrentMenuLayoutProps.js +6 -11
- package/lib/layout/utils/utils.js +16 -18
- package/lib/list/Item.js +155 -136
- package/lib/list/ListView.js +110 -119
- package/lib/list/constants.js +2 -2
- package/lib/list/index.js +72 -70
- package/lib/list/style/index.js +281 -214
- package/lib/provider/index.js +128 -118
- package/lib/provider/intl.js +56 -56
- package/lib/provider/typing/layoutToken.js +28 -25
- package/lib/provider/useStyle/index.js +55 -60
- package/lib/provider/utils/merge.js +12 -14
- package/lib/skeleton/components/Descriptions/index.js +213 -229
- package/lib/skeleton/components/List/index.js +211 -221
- package/lib/skeleton/components/Result/index.js +45 -47
- package/lib/skeleton/index.js +23 -19
- package/lib/table/Store/Provide.d.ts +4 -4
- package/lib/table/Store/Provide.js +103 -117
- package/lib/table/Table.d.ts +5 -2
- package/lib/table/Table.js +524 -689
- package/lib/table/TableSearch.d.ts +24 -0
- package/lib/table/TableSearch.js +61 -0
- package/lib/table/TableToolbar.d.ts +22 -0
- package/lib/table/TableToolbar.js +55 -0
- package/lib/table/components/Alert/index.js +41 -40
- package/lib/table/components/Alert/style.js +28 -28
- package/lib/table/components/ColumnSetting/index.js +228 -224
- package/lib/table/components/ColumnSetting/style.js +86 -72
- package/lib/table/components/DragSortTable/index.js +64 -78
- package/lib/table/components/DragSortTable/style.js +20 -20
- package/lib/table/components/Dropdown/index.js +42 -48
- package/lib/table/components/EditableTable/CellEditorTable.js +24 -32
- package/lib/table/components/EditableTable/RowEditorTable.js +23 -28
- package/lib/table/components/EditableTable/index.js +293 -327
- package/lib/table/components/Form/FormRender.js +99 -104
- package/lib/table/components/Form/index.d.ts +4 -19
- package/lib/table/components/Form/index.js +113 -159
- package/lib/table/components/ListToolBar/HeaderMenu.js +42 -51
- package/lib/table/components/ListToolBar/index.js +123 -148
- package/lib/table/components/ListToolBar/style.js +127 -118
- package/lib/table/components/ToolBar/DensityIcon.js +10 -9
- package/lib/table/components/ToolBar/FullscreenIcon.js +5 -10
- package/lib/table/components/ToolBar/index.d.ts +2 -8
- package/lib/table/components/ToolBar/index.js +154 -194
- package/lib/table/index.js +27 -27
- package/lib/table/style/index.js +144 -113
- package/lib/table/typing.d.ts +4 -0
- package/lib/table/useFetchData.js +197 -337
- package/lib/table/utils/cellRenderToFromItem.js +106 -120
- package/lib/table/utils/columnRender.js +65 -54
- package/lib/table/utils/columnSort.js +24 -23
- package/lib/table/utils/genProColumnToColumn.d.ts +13 -9
- package/lib/table/utils/genProColumnToColumn.js +121 -99
- package/lib/table/utils/index.d.ts +10 -0
- package/lib/table/utils/index.js +127 -181
- package/lib/table/utils/useDragSort.d.ts +1 -1
- package/lib/table/utils/useDragSort.js +99 -93
- package/lib/table/utils/usePageInfo.d.ts +6 -0
- package/lib/table/utils/usePageInfo.js +61 -0
- package/lib/utils/components/DropdownFooter/index.js +25 -23
- package/lib/utils/components/DropdownFooter/style.js +16 -16
- package/lib/utils/components/ErrorBoundary/index.js +28 -50
- package/lib/utils/components/FieldLabel/index.js +70 -71
- package/lib/utils/components/FieldLabel/style.js +104 -82
- package/lib/utils/components/FilterDropdown/index.d.ts +11 -0
- package/lib/utils/components/FilterDropdown/index.js +44 -33
- package/lib/utils/components/FilterDropdown/style.js +19 -17
- package/lib/utils/components/InlineErrorFormItem/index.js +80 -80
- package/lib/utils/components/InlineErrorFormItem/style.js +56 -50
- package/lib/utils/components/LabelIconTip/index.js +30 -32
- package/lib/utils/components/LabelIconTip/style.js +36 -36
- package/lib/utils/components/ProFormContext/index.js +1 -1
- package/lib/utils/conversionMomentValue/index.js +22 -23
- package/lib/utils/dateArrayFormatter/index.js +11 -15
- package/lib/utils/genCopyable/index.js +75 -33
- package/lib/utils/getFieldPropsOrFormItemProps/index.js +3 -2
- package/lib/utils/hooks/useDebounceFn/index.js +18 -52
- package/lib/utils/hooks/useDebounceValue/index.js +7 -17
- package/lib/utils/hooks/useDeepCompareEffect/index.js +7 -19
- package/lib/utils/hooks/useDocumentTitle/index.js +2 -2
- package/lib/utils/hooks/useFetchData/index.js +36 -65
- package/lib/utils/hooks/useForceRender/index.js +2 -10
- package/lib/utils/hooks/useLatest/index.js +4 -3
- package/lib/utils/hooks/usePrevious/index.js +5 -4
- package/lib/utils/hooks/useReactiveRef/index.js +2 -2
- package/lib/utils/hooks/useRefCallback/index.js +3 -3
- package/lib/utils/hooks/useRefFunction/index.js +6 -11
- package/lib/utils/index.d.ts +1 -2
- package/lib/utils/index.js +57 -65
- package/lib/utils/isBrowser/index.js +4 -3
- package/lib/utils/isDeepEqualReact/index.js +9 -45
- package/lib/utils/isDropdownValueType/index.js +4 -3
- package/lib/utils/isNil/index.js +2 -3
- package/lib/utils/isUrl/index.js +4 -3
- package/lib/utils/merge/index.js +12 -14
- package/lib/utils/nanoid/index.js +7 -7
- package/lib/utils/omitBoolean/index.js +3 -2
- package/lib/utils/omitUndefined/index.js +5 -4
- package/lib/utils/omitUndefinedAndEmptyArr/index.js +6 -6
- package/lib/utils/parseValueToMoment/index.js +5 -8
- package/lib/utils/pickProFormItemProps/index.js +3 -3
- package/lib/utils/pickProProps/index.js +6 -7
- package/lib/utils/proFieldParsingText/index.js +89 -99
- package/lib/utils/runFunction/index.js +2 -5
- package/lib/utils/stringify/index.js +2 -2
- package/lib/utils/transformKeySubmitValue/index.js +101 -117
- package/lib/utils/useEditableArray/index.d.ts +6 -1
- package/lib/utils/useEditableArray/index.js +582 -735
- package/lib/utils/useEditableMap/index.d.ts +1 -1
- package/lib/utils/useEditableMap/index.js +88 -135
- package/lib/utils/useMediaQuery/index.js +40 -35
- package/lib/utils/useMediaQuery/query.js +7 -18
- package/lib/version.js +1 -1
- package/package.json +20 -31
- package/es/utils/useMountMergeState/index.d.ts +0 -2
- package/es/utils/useMountMergeState/index.js +0 -2
- package/lib/utils/useMountMergeState/index.d.ts +0 -2
- package/lib/utils/useMountMergeState/index.js +0 -12
|
@@ -1,15 +1,10 @@
|
|
|
1
|
-
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
2
|
-
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
3
|
-
import _createClass from "@babel/runtime/helpers/esm/createClass";
|
|
4
|
-
import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
|
|
5
|
-
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
6
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
7
1
|
import { createFromIconfontCN } from '@ant-design/icons';
|
|
2
|
+
import { useControlledState } from '@rc-component/util';
|
|
8
3
|
import { Menu, Skeleton, Tooltip } from 'antd';
|
|
9
|
-
import
|
|
10
|
-
import React, { useContext, useEffect, useMemo, useRef, useState } from 'react';
|
|
4
|
+
import { clsx } from 'clsx';
|
|
5
|
+
import React, { useCallback, useContext, useEffect, useMemo, useRef, useState } from 'react';
|
|
11
6
|
import { ProProvider } from "../../../provider";
|
|
12
|
-
import { isImg, isUrl
|
|
7
|
+
import { isImg, isUrl } from "../../../utils";
|
|
13
8
|
import { defaultSettings } from "../../defaultSettings";
|
|
14
9
|
import { getOpenKeysFromMenuData } from "../../utils/utils";
|
|
15
10
|
import { useStyle } from "./style/menu";
|
|
@@ -18,18 +13,12 @@ import { useStyle } from "./style/menu";
|
|
|
18
13
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
19
14
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
20
15
|
import { createElement as _createElement } from "react";
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
setCollapsed = _useState2[1];
|
|
26
|
-
var _useState3 = useState(false),
|
|
27
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
28
|
-
open = _useState4[0],
|
|
29
|
-
setOpen = _useState4[1];
|
|
30
|
-
useEffect(function () {
|
|
16
|
+
const MenuItemTooltip = props => {
|
|
17
|
+
const [collapsed, setCollapsed] = useState(props.collapsed);
|
|
18
|
+
const [open, setOpen] = useState(false);
|
|
19
|
+
useEffect(() => {
|
|
31
20
|
setOpen(false);
|
|
32
|
-
setTimeout(
|
|
21
|
+
setTimeout(() => {
|
|
33
22
|
setCollapsed(props.collapsed);
|
|
34
23
|
}, 400);
|
|
35
24
|
}, [props.collapsed]);
|
|
@@ -44,7 +33,7 @@ var MenuItemTooltip = function MenuItemTooltip(props) {
|
|
|
44
33
|
children: props.children
|
|
45
34
|
});
|
|
46
35
|
};
|
|
47
|
-
|
|
36
|
+
let IconFont = createFromIconfontCN({
|
|
48
37
|
scriptUrl: defaultSettings.iconfontUrl
|
|
49
38
|
});
|
|
50
39
|
|
|
@@ -54,9 +43,7 @@ var IconFont = createFromIconfontCN({
|
|
|
54
43
|
// icon: 'http://demo.com/icon.png',
|
|
55
44
|
// icon: '/favicon.png',
|
|
56
45
|
// icon: <Icon type="setting" />,
|
|
57
|
-
|
|
58
|
-
var iconPrefixes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'icon-';
|
|
59
|
-
var className = arguments.length > 2 ? arguments[2] : undefined;
|
|
46
|
+
const getIcon = (icon, iconPrefixes = 'icon-', className) => {
|
|
60
47
|
if (typeof icon === 'string' && icon !== '') {
|
|
61
48
|
if (isUrl(icon) || isImg(icon)) {
|
|
62
49
|
return /*#__PURE__*/_jsx("img", {
|
|
@@ -74,157 +61,170 @@ var getIcon = function getIcon(icon) {
|
|
|
74
61
|
}
|
|
75
62
|
return icon;
|
|
76
63
|
};
|
|
77
|
-
|
|
64
|
+
const getMenuTitleSymbol = title => {
|
|
78
65
|
if (title && typeof title === 'string') {
|
|
79
|
-
|
|
66
|
+
const symbol = title.substring(0, 1).toUpperCase();
|
|
80
67
|
return symbol;
|
|
81
68
|
}
|
|
82
69
|
return null;
|
|
83
70
|
};
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
var noGroupLevel = arguments.length > 2 ? arguments[2] : undefined;
|
|
92
|
-
return menusData.map(function (item) {
|
|
93
|
-
return _this.getSubMenuOrItem(item, level, noGroupLevel);
|
|
94
|
-
}).filter(function (item) {
|
|
95
|
-
return item;
|
|
96
|
-
}).flat(1);
|
|
97
|
-
});
|
|
71
|
+
class MenuUtil {
|
|
72
|
+
props;
|
|
73
|
+
constructor(props) {
|
|
74
|
+
this.props = props;
|
|
75
|
+
}
|
|
76
|
+
getNavMenuItems = (menusData = [], level, noGroupLevel) => menusData.map(item => this.getSubMenuOrItem(item, level, noGroupLevel)).filter(item => item).flat(1);
|
|
77
|
+
|
|
98
78
|
/** Get SubMenu or Item */
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
subMenuItemRender
|
|
102
|
-
baseClassName
|
|
103
|
-
prefixCls
|
|
104
|
-
collapsed
|
|
105
|
-
menu
|
|
106
|
-
iconPrefixes
|
|
107
|
-
layout
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
79
|
+
getSubMenuOrItem = (item, level, noGroupLevel) => {
|
|
80
|
+
const {
|
|
81
|
+
subMenuItemRender,
|
|
82
|
+
baseClassName,
|
|
83
|
+
prefixCls,
|
|
84
|
+
collapsed,
|
|
85
|
+
menu,
|
|
86
|
+
iconPrefixes,
|
|
87
|
+
layout
|
|
88
|
+
} = this.props;
|
|
89
|
+
const isGroup = menu?.type === 'group' && layout !== 'top';
|
|
90
|
+
const designToken = this.props.token;
|
|
91
|
+
const name = this.getIntlName(item);
|
|
92
|
+
const children = item?.children;
|
|
93
|
+
const menuType = isGroup && level === 0 ? 'group' : undefined;
|
|
113
94
|
if (Array.isArray(children) && children.length > 0) {
|
|
114
|
-
var _this$props2, _this$props3, _this$props4, _this$props5, _designToken$layout;
|
|
115
95
|
/** Menu 第一级可以有icon,或者 isGroup 时第二级别也要有 */
|
|
116
|
-
|
|
96
|
+
const shouldHasIcon = level === 0 || isGroup && level === 1;
|
|
117
97
|
|
|
118
98
|
// get defaultTitle by menuItemRender
|
|
119
|
-
|
|
99
|
+
const iconDom = getIcon(item.icon, iconPrefixes, `${baseClassName}-icon ${this.props?.hashId}`);
|
|
120
100
|
/**
|
|
121
101
|
* 如果没有icon在收起的时候用首字母代替
|
|
122
102
|
*/
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
className:
|
|
103
|
+
const defaultIcon = collapsed && shouldHasIcon ? getMenuTitleSymbol(name) : null;
|
|
104
|
+
const defaultTitle = /*#__PURE__*/_jsxs("div", {
|
|
105
|
+
className: clsx(`${baseClassName}-item-title`, this.props?.hashId, {
|
|
106
|
+
[`${baseClassName}-item-title-collapsed`]: collapsed,
|
|
107
|
+
[`${baseClassName}-item-title-collapsed-level-${noGroupLevel}`]: collapsed,
|
|
108
|
+
[`${baseClassName}-group-item-title`]: menuType === 'group',
|
|
109
|
+
[`${baseClassName}-item-collapsed-show-title`]: menu?.collapsedShowTitle && collapsed
|
|
110
|
+
}),
|
|
126
111
|
children: [menuType === 'group' && collapsed ? null : shouldHasIcon && iconDom ? /*#__PURE__*/_jsx("span", {
|
|
127
|
-
className:
|
|
112
|
+
className: `${baseClassName}-item-icon ${this.props?.hashId}`.trim(),
|
|
128
113
|
children: iconDom
|
|
129
114
|
}) : defaultIcon, /*#__PURE__*/_jsx("span", {
|
|
130
|
-
className:
|
|
115
|
+
className: clsx(`${baseClassName}-item-text`, this.props?.hashId, {
|
|
116
|
+
[`${baseClassName}-item-text-has-icon`]: menuType !== 'group' && shouldHasIcon && (iconDom || defaultIcon)
|
|
117
|
+
}),
|
|
131
118
|
children: name
|
|
132
119
|
})]
|
|
133
120
|
});
|
|
134
121
|
|
|
135
122
|
// subMenu only title render
|
|
136
|
-
|
|
123
|
+
const title = subMenuItemRender ? subMenuItemRender({
|
|
124
|
+
...item,
|
|
137
125
|
isUrl: false
|
|
138
|
-
}
|
|
126
|
+
}, defaultTitle, this.props) : defaultTitle;
|
|
139
127
|
|
|
140
128
|
// 如果收起来,没有子菜单了,就不需要展示 group,所以 level 不增加
|
|
141
|
-
if (isGroup && level === 0 &&
|
|
142
|
-
return
|
|
129
|
+
if (isGroup && level === 0 && this.props.collapsed && !menu.collapsedShowGroupTitle) {
|
|
130
|
+
return this.getNavMenuItems(children, level + 1, level);
|
|
143
131
|
}
|
|
144
|
-
|
|
132
|
+
const childrenList = this.getNavMenuItems(children, level + 1, isGroup && level === 0 && this.props.collapsed ? level : level + 1);
|
|
145
133
|
return [{
|
|
146
134
|
type: menuType,
|
|
147
135
|
key: item.key || item.path,
|
|
148
136
|
label: title,
|
|
149
137
|
onClick: isGroup ? undefined : item.onTitleClick,
|
|
150
138
|
children: childrenList,
|
|
151
|
-
className:
|
|
139
|
+
className: clsx({
|
|
140
|
+
[`${baseClassName}-group`]: menuType === 'group',
|
|
141
|
+
[`${baseClassName}-submenu`]: menuType !== 'group',
|
|
142
|
+
[`${baseClassName}-submenu-has-icon`]: menuType !== 'group' && shouldHasIcon && iconDom
|
|
143
|
+
})
|
|
152
144
|
}, isGroup && level === 0 ? {
|
|
153
145
|
type: 'divider',
|
|
154
|
-
prefixCls
|
|
155
|
-
className:
|
|
146
|
+
prefixCls,
|
|
147
|
+
className: `${baseClassName}-divider`,
|
|
156
148
|
key: (item.key || item.path) + '-group-divider',
|
|
157
149
|
style: {
|
|
158
150
|
padding: 0,
|
|
159
151
|
borderBlockEnd: 0,
|
|
160
|
-
margin:
|
|
161
|
-
marginBlockStart:
|
|
162
|
-
borderColor: designToken
|
|
152
|
+
margin: this.props.collapsed ? '4px' : '6px 16px',
|
|
153
|
+
marginBlockStart: this.props.collapsed ? 4 : 8,
|
|
154
|
+
borderColor: designToken?.layout?.sider?.colorMenuItemDivider
|
|
163
155
|
}
|
|
164
156
|
} : undefined].filter(Boolean);
|
|
165
157
|
}
|
|
166
158
|
return {
|
|
167
|
-
className:
|
|
159
|
+
className: `${baseClassName}-menu-item`,
|
|
168
160
|
disabled: item.disabled,
|
|
169
161
|
key: item.key || item.path,
|
|
170
162
|
onClick: item.onTitleClick,
|
|
171
163
|
// eslint-disable-next-line react/no-is-mounted
|
|
172
|
-
label:
|
|
164
|
+
label: this.getMenuItemPath(item, level, noGroupLevel)
|
|
173
165
|
};
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
166
|
+
};
|
|
167
|
+
getIntlName = item => {
|
|
168
|
+
const {
|
|
169
|
+
name,
|
|
170
|
+
locale
|
|
171
|
+
} = item;
|
|
172
|
+
const {
|
|
173
|
+
menu,
|
|
174
|
+
formatMessage
|
|
175
|
+
} = this.props;
|
|
176
|
+
let finalName = name;
|
|
177
|
+
if (locale && menu?.locale !== false) {
|
|
178
|
+
finalName = formatMessage?.({
|
|
184
179
|
id: locale,
|
|
185
180
|
defaultMessage: name
|
|
186
181
|
});
|
|
187
182
|
}
|
|
188
|
-
if (
|
|
189
|
-
return
|
|
183
|
+
if (this.props.menuTextRender) {
|
|
184
|
+
return this.props.menuTextRender(item, finalName, this.props);
|
|
190
185
|
}
|
|
191
186
|
return finalName;
|
|
192
|
-
}
|
|
187
|
+
};
|
|
188
|
+
|
|
193
189
|
/**
|
|
194
190
|
* 判断是否是http链接.返回 Link 或 a Judge whether it is http link.return a or Link
|
|
195
191
|
*
|
|
196
192
|
* @memberof SiderMenu
|
|
197
193
|
*/
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
_this$props7$location = _this$props7.location,
|
|
203
|
-
location = _this$props7$location === void 0 ? {
|
|
194
|
+
getMenuItemPath = (item, level, noGroupLevel) => {
|
|
195
|
+
const itemPath = this.conversionPath(item.path || '/');
|
|
196
|
+
const {
|
|
197
|
+
location = {
|
|
204
198
|
pathname: '/'
|
|
205
|
-
}
|
|
206
|
-
isMobile
|
|
207
|
-
onCollapse
|
|
208
|
-
menuItemRender
|
|
209
|
-
iconPrefixes
|
|
199
|
+
},
|
|
200
|
+
isMobile,
|
|
201
|
+
onCollapse,
|
|
202
|
+
menuItemRender,
|
|
203
|
+
iconPrefixes
|
|
204
|
+
} = this.props;
|
|
210
205
|
|
|
211
206
|
// if local is true formatMessage all name。
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
baseClassName
|
|
215
|
-
menu
|
|
216
|
-
collapsed
|
|
217
|
-
|
|
207
|
+
const menuItemTitle = this.getIntlName(item);
|
|
208
|
+
const {
|
|
209
|
+
baseClassName,
|
|
210
|
+
menu,
|
|
211
|
+
collapsed
|
|
212
|
+
} = this.props;
|
|
213
|
+
const isGroup = menu?.type === 'group';
|
|
218
214
|
/** Menu 第一级可以有icon,或者 isGroup 时第二级别也要有 */
|
|
219
|
-
|
|
220
|
-
|
|
215
|
+
const hasIcon = level === 0 || isGroup && level === 1;
|
|
216
|
+
const icon = !hasIcon ? null : getIcon(item.icon, iconPrefixes, `${baseClassName}-icon ${this.props?.hashId}`);
|
|
221
217
|
|
|
222
218
|
// 如果没有 icon 在收起的时候用首字母代替
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
className:
|
|
219
|
+
const defaultIcon = collapsed && hasIcon ? getMenuTitleSymbol(menuItemTitle) : null;
|
|
220
|
+
let defaultItem = /*#__PURE__*/_jsxs("div", {
|
|
221
|
+
className: clsx(`${baseClassName}-item-title`, this.props?.hashId, {
|
|
222
|
+
[`${baseClassName}-item-title-collapsed`]: collapsed,
|
|
223
|
+
[`${baseClassName}-item-title-collapsed-level-${noGroupLevel}`]: collapsed,
|
|
224
|
+
[`${baseClassName}-item-collapsed-show-title`]: menu?.collapsedShowTitle && collapsed
|
|
225
|
+
}),
|
|
226
226
|
children: [/*#__PURE__*/_jsx("span", {
|
|
227
|
-
className:
|
|
227
|
+
className: `${baseClassName}-item-icon ${this.props?.hashId}`.trim(),
|
|
228
228
|
style: {
|
|
229
229
|
display: defaultIcon === null && !icon ? 'none' : ''
|
|
230
230
|
},
|
|
@@ -233,23 +233,28 @@ var MenuUtil = /*#__PURE__*/_createClass(function MenuUtil(props) {
|
|
|
233
233
|
children: defaultIcon
|
|
234
234
|
})
|
|
235
235
|
}), /*#__PURE__*/_jsx("span", {
|
|
236
|
-
className:
|
|
236
|
+
className: clsx(`${baseClassName}-item-text`, this.props?.hashId, {
|
|
237
|
+
[`${baseClassName}-item-text-has-icon`]: hasIcon && (icon || defaultIcon)
|
|
238
|
+
}),
|
|
237
239
|
children: menuItemTitle
|
|
238
240
|
})]
|
|
239
241
|
}, itemPath);
|
|
240
|
-
|
|
242
|
+
const isHttpUrl = isUrl(itemPath);
|
|
241
243
|
|
|
242
244
|
// Is it a http link
|
|
243
245
|
if (isHttpUrl) {
|
|
244
|
-
var _this$props13, _this$props14, _this$props15;
|
|
245
246
|
defaultItem = /*#__PURE__*/_jsxs("span", {
|
|
246
|
-
onClick:
|
|
247
|
-
|
|
248
|
-
(_window = window) === null || _window === void 0 || (_window$open = _window.open) === null || _window$open === void 0 || _window$open.call(_window, itemPath, '_blank');
|
|
247
|
+
onClick: () => {
|
|
248
|
+
window?.open?.(itemPath, '_blank');
|
|
249
249
|
},
|
|
250
|
-
className:
|
|
250
|
+
className: clsx(`${baseClassName}-item-title`, this.props?.hashId, {
|
|
251
|
+
[`${baseClassName}-item-title-collapsed`]: collapsed,
|
|
252
|
+
[`${baseClassName}-item-title-collapsed-level-${noGroupLevel}`]: collapsed,
|
|
253
|
+
[`${baseClassName}-item-link`]: true,
|
|
254
|
+
[`${baseClassName}-item-collapsed-show-title`]: menu?.collapsedShowTitle && collapsed
|
|
255
|
+
}),
|
|
251
256
|
children: [/*#__PURE__*/_jsx("span", {
|
|
252
|
-
className:
|
|
257
|
+
className: `${baseClassName}-item-icon ${this.props?.hashId}`.trim(),
|
|
253
258
|
style: {
|
|
254
259
|
display: defaultIcon === null && !icon ? 'none' : ''
|
|
255
260
|
},
|
|
@@ -258,28 +263,29 @@ var MenuUtil = /*#__PURE__*/_createClass(function MenuUtil(props) {
|
|
|
258
263
|
children: defaultIcon
|
|
259
264
|
})
|
|
260
265
|
}), /*#__PURE__*/_jsx("span", {
|
|
261
|
-
className:
|
|
266
|
+
className: clsx(`${baseClassName}-item-text`, this.props?.hashId, {
|
|
267
|
+
[`${baseClassName}-item-text-has-icon`]: hasIcon && (icon || defaultIcon)
|
|
268
|
+
}),
|
|
262
269
|
children: menuItemTitle
|
|
263
270
|
})]
|
|
264
271
|
}, itemPath);
|
|
265
272
|
}
|
|
266
273
|
if (menuItemRender) {
|
|
267
|
-
|
|
274
|
+
const renderItemProps = {
|
|
275
|
+
...item,
|
|
268
276
|
isUrl: isHttpUrl,
|
|
269
|
-
itemPath
|
|
270
|
-
isMobile
|
|
277
|
+
itemPath,
|
|
278
|
+
isMobile,
|
|
271
279
|
replace: itemPath === location.pathname,
|
|
272
|
-
onClick:
|
|
273
|
-
return onCollapse && onCollapse(true);
|
|
274
|
-
},
|
|
280
|
+
onClick: () => onCollapse && onCollapse(true),
|
|
275
281
|
children: undefined
|
|
276
|
-
}
|
|
282
|
+
};
|
|
277
283
|
return level === 0 ? /*#__PURE__*/_jsx(MenuItemTooltip, {
|
|
278
284
|
collapsed: collapsed,
|
|
279
285
|
title: menuItemTitle,
|
|
280
286
|
disable: item.disabledTooltip,
|
|
281
|
-
children: menuItemRender(renderItemProps, defaultItem,
|
|
282
|
-
}) : menuItemRender(renderItemProps, defaultItem,
|
|
287
|
+
children: menuItemRender(renderItemProps, defaultItem, this.props)
|
|
288
|
+
}) : menuItemRender(renderItemProps, defaultItem, this.props);
|
|
283
289
|
}
|
|
284
290
|
return level === 0 ? /*#__PURE__*/_jsx(MenuItemTooltip, {
|
|
285
291
|
collapsed: collapsed,
|
|
@@ -287,83 +293,85 @@ var MenuUtil = /*#__PURE__*/_createClass(function MenuUtil(props) {
|
|
|
287
293
|
disable: item.disabledTooltip,
|
|
288
294
|
children: defaultItem
|
|
289
295
|
}) : defaultItem;
|
|
290
|
-
}
|
|
291
|
-
|
|
296
|
+
};
|
|
297
|
+
conversionPath = path => {
|
|
292
298
|
if (path && path.indexOf('http') === 0) {
|
|
293
299
|
return path;
|
|
294
300
|
}
|
|
295
|
-
return
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
|
|
301
|
+
return `/${path || ''}`.replace(/\/+/g, '/');
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
|
|
299
305
|
/**
|
|
300
306
|
* 生成openKeys 的对象,因为设置了openKeys 就会变成受控,所以需要一个空对象
|
|
301
307
|
*
|
|
302
308
|
* @param BaseMenuProps
|
|
303
309
|
*/
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
310
|
+
const getOpenKeysProps = (openKeys, {
|
|
311
|
+
layout,
|
|
312
|
+
collapsed
|
|
313
|
+
}) => {
|
|
314
|
+
let openKeysProps = {};
|
|
308
315
|
if (openKeys && !collapsed && ['side', 'mix'].includes(layout || 'mix')) {
|
|
309
316
|
openKeysProps = {
|
|
310
|
-
openKeys
|
|
317
|
+
openKeys
|
|
311
318
|
};
|
|
312
319
|
}
|
|
313
320
|
return openKeysProps;
|
|
314
321
|
};
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
322
|
+
const BaseMenu = props => {
|
|
323
|
+
const {
|
|
324
|
+
mode,
|
|
325
|
+
className,
|
|
326
|
+
onOpenChange,
|
|
327
|
+
style,
|
|
328
|
+
menuData,
|
|
329
|
+
prefixCls,
|
|
330
|
+
menu,
|
|
331
|
+
matchMenuKeys,
|
|
332
|
+
iconfontUrl,
|
|
333
|
+
selectedKeys: propsSelectedKeys,
|
|
334
|
+
onSelect,
|
|
335
|
+
menuRenderType,
|
|
336
|
+
openKeys: propsOpenKeys
|
|
337
|
+
} = props;
|
|
338
|
+
const {
|
|
339
|
+
dark,
|
|
340
|
+
token: designToken
|
|
341
|
+
} = useContext(ProProvider);
|
|
342
|
+
const baseClassName = `${prefixCls}-base-menu-${mode}`;
|
|
333
343
|
// 用于减少 defaultOpenKeys 计算的组件
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
344
|
+
const defaultOpenKeysRef = useRef([]);
|
|
345
|
+
const [defaultOpenAll, setDefaultOpenAll] = useState(menu?.defaultOpenAll);
|
|
346
|
+
const openKeysValue = propsOpenKeys === false ? undefined : propsOpenKeys;
|
|
347
|
+
const [openKeys, setOpenKeysInner] = useControlledState(() => {
|
|
348
|
+
if (menu?.defaultOpenAll) {
|
|
349
|
+
return getOpenKeysFromMenuData(menuData) || [];
|
|
350
|
+
}
|
|
351
|
+
if (propsOpenKeys === false) {
|
|
352
|
+
return false;
|
|
353
|
+
}
|
|
354
|
+
return [];
|
|
355
|
+
}, openKeysValue);
|
|
356
|
+
const setOpenKeys = useCallback(updater => {
|
|
357
|
+
setOpenKeysInner(prev => {
|
|
358
|
+
const next = typeof updater === 'function' ? updater(prev) : updater;
|
|
359
|
+
onOpenChange?.(next);
|
|
360
|
+
return next;
|
|
361
|
+
});
|
|
362
|
+
}, [onOpenChange]);
|
|
363
|
+
const [selectedKeys, setSelectedKeysInner] = useControlledState([], propsSelectedKeys);
|
|
364
|
+
const setSelectedKeys = useCallback(updater => {
|
|
365
|
+
setSelectedKeysInner(prev => {
|
|
366
|
+
const next = typeof updater === 'function' ? updater(prev) : updater;
|
|
367
|
+
if (onSelect && next) {
|
|
368
|
+
onSelect(next);
|
|
345
369
|
}
|
|
346
|
-
return
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
_useMountMergeState4 = _slicedToArray(_useMountMergeState3, 2),
|
|
352
|
-
openKeys = _useMountMergeState4[0],
|
|
353
|
-
setOpenKeys = _useMountMergeState4[1];
|
|
354
|
-
var _useMountMergeState5 = useMountMergeState([], {
|
|
355
|
-
value: propsSelectedKeys,
|
|
356
|
-
onChange: onSelect ? function (keys) {
|
|
357
|
-
if (onSelect && keys) {
|
|
358
|
-
onSelect(keys);
|
|
359
|
-
}
|
|
360
|
-
} : undefined
|
|
361
|
-
}),
|
|
362
|
-
_useMountMergeState6 = _slicedToArray(_useMountMergeState5, 2),
|
|
363
|
-
selectedKeys = _useMountMergeState6[0],
|
|
364
|
-
setSelectedKeys = _useMountMergeState6[1];
|
|
365
|
-
useEffect(function () {
|
|
366
|
-
if (menu !== null && menu !== void 0 && menu.defaultOpenAll || propsOpenKeys === false) {
|
|
370
|
+
return next;
|
|
371
|
+
});
|
|
372
|
+
}, [onSelect]);
|
|
373
|
+
useEffect(() => {
|
|
374
|
+
if (menu?.defaultOpenAll || propsOpenKeys === false) {
|
|
367
375
|
return;
|
|
368
376
|
}
|
|
369
377
|
if (matchMenuKeys) {
|
|
@@ -372,7 +380,7 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
372
380
|
}
|
|
373
381
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
374
382
|
}, [matchMenuKeys.join('-')]);
|
|
375
|
-
useEffect(
|
|
383
|
+
useEffect(() => {
|
|
376
384
|
// reset IconFont
|
|
377
385
|
if (iconfontUrl) {
|
|
378
386
|
IconFont = createFromIconfontCN({
|
|
@@ -380,19 +388,19 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
380
388
|
});
|
|
381
389
|
}
|
|
382
390
|
}, [iconfontUrl]);
|
|
383
|
-
useEffect(
|
|
391
|
+
useEffect(() => {
|
|
384
392
|
// if pathname can't match, use the nearest parent's key
|
|
385
393
|
if (matchMenuKeys.join('-') !== (selectedKeys || []).join('-')) {
|
|
386
394
|
setSelectedKeys(matchMenuKeys);
|
|
387
395
|
}
|
|
388
396
|
if (!defaultOpenAll && propsOpenKeys !== false && matchMenuKeys.join('-') !== (openKeys || []).join('-')) {
|
|
389
|
-
|
|
397
|
+
let newKeys = matchMenuKeys;
|
|
390
398
|
// 如果不自动关闭,我需要把 openKeys 放进去
|
|
391
|
-
if (
|
|
392
|
-
newKeys = Array.from(new Set([
|
|
399
|
+
if (menu?.autoClose === false) {
|
|
400
|
+
newKeys = Array.from(new Set([...matchMenuKeys, ...(openKeys || [])]));
|
|
393
401
|
}
|
|
394
402
|
setOpenKeys(newKeys);
|
|
395
|
-
} else if (menu
|
|
403
|
+
} else if (menu?.ignoreFlatMenu && defaultOpenAll && !props.collapsed) {
|
|
396
404
|
// 忽略用户手动折叠过的菜单状态,折叠按钮切换之后也可实现默认展开所有菜单
|
|
397
405
|
// 但是如果用户手动点击关闭菜单,则应该遵循用户的选择
|
|
398
406
|
setOpenKeys(getOpenKeysFromMenuData(menuData));
|
|
@@ -402,25 +410,25 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
402
410
|
},
|
|
403
411
|
// 依赖项加上 props.collapsed,保证折叠时能正确响应
|
|
404
412
|
[matchMenuKeys.join('-'), props.collapsed]);
|
|
405
|
-
|
|
406
|
-
return getOpenKeysProps(openKeys, props);
|
|
407
|
-
},
|
|
413
|
+
const openKeysProps = useMemo(() => getOpenKeysProps(openKeys, props),
|
|
408
414
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
409
415
|
[openKeys && openKeys.join(','), props.layout, props.collapsed]);
|
|
410
|
-
|
|
411
|
-
wrapSSR
|
|
412
|
-
hashId
|
|
413
|
-
|
|
414
|
-
|
|
416
|
+
const {
|
|
417
|
+
wrapSSR,
|
|
418
|
+
hashId
|
|
419
|
+
} = useStyle(baseClassName, mode);
|
|
420
|
+
const menuUtils = useMemo(() => {
|
|
421
|
+
return new MenuUtil({
|
|
422
|
+
...props,
|
|
415
423
|
token: designToken,
|
|
416
|
-
menuRenderType
|
|
417
|
-
baseClassName
|
|
418
|
-
hashId
|
|
419
|
-
})
|
|
424
|
+
menuRenderType,
|
|
425
|
+
baseClassName,
|
|
426
|
+
hashId
|
|
427
|
+
});
|
|
420
428
|
}, [props, designToken, menuRenderType, baseClassName, hashId]);
|
|
421
|
-
if (menu
|
|
429
|
+
if (menu?.loading) {
|
|
422
430
|
return /*#__PURE__*/_jsx("div", {
|
|
423
|
-
style: mode
|
|
431
|
+
style: mode?.includes('inline') ? {
|
|
424
432
|
padding: 24
|
|
425
433
|
} : {
|
|
426
434
|
marginBlockStart: 16
|
|
@@ -429,7 +437,7 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
429
437
|
active: true,
|
|
430
438
|
title: false,
|
|
431
439
|
paragraph: {
|
|
432
|
-
rows: mode
|
|
440
|
+
rows: mode?.includes('inline') ? 6 : 1
|
|
433
441
|
}
|
|
434
442
|
})
|
|
435
443
|
});
|
|
@@ -441,11 +449,12 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
441
449
|
if (props.openKeys === false && !props.onOpenChange) {
|
|
442
450
|
defaultOpenKeysRef.current = matchMenuKeys;
|
|
443
451
|
}
|
|
444
|
-
|
|
445
|
-
if (finallyData &&
|
|
452
|
+
const finallyData = props.postMenuData ? props.postMenuData(menuData) : menuData;
|
|
453
|
+
if (finallyData && finallyData?.length < 1) {
|
|
446
454
|
return null;
|
|
447
455
|
}
|
|
448
|
-
return wrapSSR( /*#__PURE__*/_createElement(Menu,
|
|
456
|
+
return wrapSSR( /*#__PURE__*/_createElement(Menu, {
|
|
457
|
+
...openKeysProps,
|
|
449
458
|
_internalDisableMenuItemTitleTooltip: true,
|
|
450
459
|
key: "Menu",
|
|
451
460
|
mode: mode,
|
|
@@ -453,13 +462,17 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
453
462
|
defaultOpenKeys: defaultOpenKeysRef.current,
|
|
454
463
|
theme: dark ? 'dark' : 'light',
|
|
455
464
|
selectedKeys: selectedKeys,
|
|
456
|
-
style:
|
|
465
|
+
style: {
|
|
457
466
|
backgroundColor: 'transparent',
|
|
458
|
-
border: 'none'
|
|
459
|
-
|
|
460
|
-
|
|
467
|
+
border: 'none',
|
|
468
|
+
...style
|
|
469
|
+
},
|
|
470
|
+
className: clsx(className, hashId, baseClassName, {
|
|
471
|
+
[`${baseClassName}-horizontal`]: mode === 'horizontal',
|
|
472
|
+
[`${baseClassName}-collapsed`]: props.collapsed
|
|
473
|
+
}),
|
|
461
474
|
items: menuUtils.getNavMenuItems(finallyData, 0, 0),
|
|
462
|
-
onOpenChange:
|
|
475
|
+
onOpenChange: _openKeys => {
|
|
463
476
|
if (!props.collapsed) {
|
|
464
477
|
// 如果用户手动关闭所有菜单,则关闭自动展开
|
|
465
478
|
if (_openKeys.length === 0) {
|
|
@@ -467,7 +480,8 @@ var BaseMenu = function BaseMenu(props) {
|
|
|
467
480
|
}
|
|
468
481
|
setOpenKeys(_openKeys);
|
|
469
482
|
}
|
|
470
|
-
}
|
|
471
|
-
|
|
483
|
+
},
|
|
484
|
+
...props.menuProps
|
|
485
|
+
}));
|
|
472
486
|
};
|
|
473
487
|
export { BaseMenu };
|