@unicom-cloud/ui 0.8.44 → 0.8.46
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/Affix.js +54 -51
- package/Alert.js +46 -43
- package/Anchor.js +5 -4
- package/AutoComplete.js +60 -55
- package/Avatar.js +10 -155
- package/BackTop.js +41 -38
- package/Badge.js +63 -93
- package/Breadcrumb.js +63 -118
- package/Button.js +105 -109
- package/Calendar.js +139 -536
- package/Card.js +65 -101
- package/Carousel.js +169 -270
- package/Cascader.js +9 -8
- package/Checkbox.js +4 -3
- package/Collapse.js +4 -3
- package/ColorPicker.js +95 -546
- package/Comment.js +14 -12
- package/ConfigProvider.js +6 -5
- package/Copy.js +33 -31
- package/DatePicker.js +35 -1993
- package/Descriptions.js +30 -28
- package/Divider.js +8 -6
- package/Draggable.js +28 -85
- package/Drawer.js +5 -4
- package/Dropdown.js +107 -167
- package/Empty.js +28 -8
- package/Form.js +30 -1418
- package/Grid.js +13 -250
- package/Icon.js +19 -45
- package/IconHover.js +39 -6
- package/Image.js +3 -3
- package/Input.js +4 -4
- package/InputNumber.js +213 -17
- package/InputTag.js +5 -4
- package/Layout.js +35 -48
- package/Link.js +16 -14
- package/List.js +191 -228
- package/Loading.js +18 -17
- package/Mentions.js +99 -115
- package/Menu.js +8 -7
- package/Message.js +147 -10
- package/Modal.js +5 -4
- package/Notice.js +196 -13
- package/Notification.js +136 -11
- package/NotificationBase.js +5 -4
- package/OverflowEllipsis.js +48 -71
- package/PageHeader.js +52 -52
- package/Pagination.js +12 -11
- package/Picker.js +6 -4
- package/Popconfirm.js +47 -44
- package/Popover.js +25 -23
- package/Portal.js +12 -32
- package/Progress.js +65 -328
- package/Radio.js +6 -5
- package/Rate.js +48 -45
- package/ResizeBox.js +127 -505
- package/Result.js +60 -1417
- package/Select.js +9 -8
- package/SelectView.js +49 -328
- package/Skeleton.js +41 -78
- package/Slider.js +228 -702
- package/Space.js +53 -57
- package/Spin.js +57 -72
- package/Statistic.js +84 -153
- package/Steps.js +64 -123
- package/SuspenseFallbackTest.js +4 -3
- package/Switch.js +41 -38
- package/Table.js +20 -1999
- package/Tabs.js +9 -8
- package/Tag.js +24 -21
- package/TimePicker.js +19 -272
- package/Timeline.js +4 -3
- package/Tooltip.js +79 -72
- package/Transfer.js +138 -402
- package/Tree.js +5 -4
- package/TreeSelect.js +8 -7
- package/Trigger.js +407 -571
- package/Typography.js +11 -722
- package/Upload.js +9 -8
- package/VerificationCode.js +6 -5
- package/Version.js +1 -1
- package/VirtualList.js +4 -3
- package/Watermark.js +3 -2
- package/anchor/Anchor.js +193 -0
- package/anchor/Link.js +54 -0
- package/anchor/context.js +14 -0
- package/anchor/util.js +41 -0
- package/avatar/Avatar.js +85 -0
- package/avatar/Group.js +84 -0
- package/avatar/context.js +5 -0
- package/badge/Count.js +35 -0
- package/breadcrumb/Item.js +67 -0
- package/button/Group.js +15 -0
- package/calendar/Month.js +142 -0
- package/calendar/WeekList.js +24 -0
- package/calendar/Year.js +75 -0
- package/calendar/header/Panel.js +57 -0
- package/calendar/header/index.js +118 -0
- package/calendar/hook/useCellClassName.js +41 -0
- package/card/Grid.js +27 -0
- package/card/Meta.js +32 -0
- package/carousel/Arrow.js +57 -0
- package/carousel/Indicator.js +68 -0
- package/cascader/Cascader.js +300 -0
- package/cascader/base/node.js +142 -0
- package/cascader/base/store.js +93 -0
- package/cascader/hook/useRefCurrent.js +12 -0
- package/cascader/panel/List.js +275 -0
- package/cascader/panel/Option.js +35 -0
- package/cascader/panel/Search.js +171 -0
- package/cascader/util.js +66 -0
- package/checkbox/Checkbox.js +111 -0
- package/checkbox/Group.js +97 -0
- package/checkbox/useCheckbox.js +45 -0
- package/collapse/Collapse.js +90 -0
- package/collapse/Item.js +165 -0
- package/color-picker/ControlBar.js +64 -0
- package/color-picker/InputAlpha.js +24 -0
- package/color-picker/InputHex.js +59 -0
- package/color-picker/InputRgb.js +66 -0
- package/color-picker/Palette.js +36 -0
- package/color-picker/Panel.js +165 -0
- package/color-picker/colors.js +37 -0
- package/color-picker/hooks/useColorPicker.js +63 -0
- package/color-picker/hooks/useControlBlock.js +40 -0
- package/config-provider/ConfigProvider.js +94 -0
- package/config-provider/context.js +24 -0
- package/date-picker/Picker.js +399 -0
- package/date-picker/PickerRange.js +568 -0
- package/date-picker/context.js +5 -0
- package/date-picker/hook/useCellClassName.js +58 -0
- package/date-picker/panel/Body.js +78 -0
- package/date-picker/panel/Footer.js +71 -0
- package/date-picker/panel/Header.js +74 -0
- package/date-picker/panel/Shortcut.js +45 -0
- package/date-picker/panel/WeekList.js +19 -0
- package/date-picker/panel/date/index.js +194 -0
- package/date-picker/panel/month/index.js +113 -0
- package/date-picker/panel/quarter/index.js +93 -0
- package/date-picker/panel/range/index.js +251 -0
- package/date-picker/panel/week/index.js +35 -0
- package/date-picker/panel/year/index.js +74 -0
- package/date-picker/util.js +69 -0
- package/draggable/Item.js +66 -0
- package/drawer/Drawer.js +226 -0
- package/dropdown/Button.js +91 -0
- package/form/Control.js +264 -0
- package/form/Form.js +156 -0
- package/form/FormItem.js +241 -0
- package/form/FormLabel.js +54 -0
- package/form/FormList.js +96 -0
- package/form/FormProvider.js +48 -0
- package/form/IconSymbol.js +20 -0
- package/form/context.js +43 -0
- package/form/hook/useContext.js +32 -0
- package/form/hook/useState.js +31 -0
- package/form/hook/useWatch.js +36 -0
- package/form/interface.js +11 -0
- package/form/promisify.js +23 -0
- package/form/store.js +354 -0
- package/form/useForm.js +53 -0
- package/form/util.js +72 -0
- package/grid/Col.js +87 -0
- package/grid/Row.js +88 -0
- package/grid/context.js +9 -0
- package/grid/grid-item.js +77 -0
- package/grid/grid.js +104 -0
- package/grid/hook/useResponsiveState.js +38 -0
- package/grid/util.js +51 -0
- package/{chunk/I4RV9SKZ.js → hooks/factory/createHTMLMediaHook.js} +35 -43
- package/hooks/index.js +246 -4
- package/{chunk/BdYAMaw9.js → hooks/misc/hookState.js} +1 -1
- package/hooks/misc/parseTimeRanges.js +12 -0
- package/{chunk/TXCrI0jN.js → hooks/misc/util.js} +6 -6
- package/hooks/use-watermark/utils.js +8 -0
- package/hooks/use-watermark.js +71 -76
- package/hooks/useAudio.js +3 -3
- package/hooks/useBeforeUnload.js +2 -2
- package/hooks/useClickAway.js +10 -10
- package/hooks/useCounter.js +1 -1
- package/hooks/useCreation.js +2 -4
- package/hooks/useDrop.js +12 -12
- package/hooks/useDropArea.js +5 -5
- package/hooks/useEvent.js +6 -6
- package/hooks/useEventListener.js +2 -4
- package/hooks/useFavicon.js +1 -2
- package/hooks/useFullscreen.js +11 -13
- package/hooks/useGetSet.js +5 -5
- package/hooks/useHash.js +6 -6
- package/hooks/useHover.js +6 -6
- package/hooks/useHoverDirty.js +7 -7
- package/hooks/useIdle.js +17 -17
- package/hooks/useIsomorphicLayoutEffect2.js +3 -3
- package/hooks/useKey.js +5 -5
- package/hooks/useList.js +1 -1
- package/hooks/useLocalStorage.js +2 -3
- package/hooks/useLocation.js +1 -1
- package/hooks/useLockBodyScroll.js +13 -14
- package/hooks/useLongPress.js +7 -7
- package/hooks/useMeasure.js +3 -3
- package/hooks/useMedia.js +4 -4
- package/hooks/useMediaDevices.js +10 -10
- package/hooks/useMotion.js +11 -11
- package/hooks/useMouse.js +9 -9
- package/hooks/useMouseWheel.js +7 -7
- package/hooks/useNetworkState.js +7 -7
- package/hooks/useOrientation.js +10 -11
- package/hooks/useOverrideRef.js +14 -0
- package/hooks/usePageLeave.js +4 -4
- package/hooks/usePermission.js +9 -9
- package/hooks/usePersistCallback.js +15 -0
- package/hooks/useScroll.js +6 -6
- package/hooks/useScrolling.js +7 -7
- package/hooks/useSearchParam.js +5 -5
- package/hooks/useSessionStorage.js +9 -9
- package/hooks/useSize.js +1 -1
- package/hooks/useSlider.js +6 -6
- package/hooks/useStartTyping.js +4 -4
- package/hooks/useStateList.js +4 -5
- package/hooks/useStateWithHistory.js +1 -1
- package/hooks/useTimeout.js +1 -2
- package/hooks/useVibrate.js +5 -5
- package/hooks/useVideo.js +3 -3
- package/hooks/useWindowScroll.js +13 -13
- package/hooks/useWindowSize.js +6 -6
- package/icon/addFromIconFontCn.js +33 -0
- package/image/Image.js +189 -0
- package/image/ImageFooter.js +45 -0
- package/image/ImagePreview.js +473 -0
- package/image/ImagePreviewArrow.js +40 -0
- package/image/ImagePreviewGroup.js +125 -0
- package/image/ImagePreviewToolbar.js +98 -0
- package/image/TriggerForToolbar.js +10 -0
- package/image/previewGroupContext.js +17 -0
- package/image/util/getFixTranslate.js +7 -0
- package/image/util/getScale.js +72 -0
- package/image/util/hook/useImageStatus.js +16 -0
- package/image/util/hook/useShowFooter.js +7 -0
- package/index.js +440 -398
- package/input/Group.js +20 -0
- package/input/Input.js +185 -0
- package/input/InputElement.js +233 -0
- package/input/Number.js +4 -0
- package/input/Password.js +72 -0
- package/input/Search.js +80 -0
- package/input/Tag.js +7 -0
- package/input/Textarea.js +168 -0
- package/input/autoSizeTextAreaHeight.js +65 -0
- package/input/useComposition.js +39 -0
- package/input-number/decimal.js +154 -0
- package/input-number/useSelectionRange.js +26 -0
- package/input-number/util.js +57 -0
- package/input-tag/InputTag.js +381 -0
- package/layout/Content.js +15 -0
- package/layout/Footer.js +15 -0
- package/layout/Header.js +15 -0
- package/{chunk/B9asjXwm.js → layout/Sider.js} +23 -22
- package/list/Item.js +46 -0
- package/list/Meta.js +21 -0
- package/loading/style/index.module.less.js +4 -0
- package/mentions/util.js +26 -0
- package/menu/Indent.js +17 -0
- package/menu/Item.js +125 -0
- package/menu/ItemGroup.js +39 -0
- package/menu/Menu.js +181 -0
- package/menu/OverflowWrap.js +85 -0
- package/menu/context.js +5 -0
- package/menu/sub-menu/Inline.js +111 -0
- package/menu/sub-menu/Pop.js +126 -0
- package/menu/sub-menu/index.js +17 -0
- package/menu/util.js +80 -0
- package/message/useMessage.js +53 -0
- package/modal/Confirm.js +98 -0
- package/modal/Modal.js +419 -0
- package/modal/config.js +25 -0
- package/modal/use-modal/Hook.js +55 -0
- package/modal/use-modal/index.js +68 -0
- package/notification/useNotification.js +55 -0
- package/overflow-ellipsis/OverflowItem.js +34 -0
- package/package.json +1 -1
- package/pagination/PageItem.js +121 -0
- package/pagination/PageJumper.js +64 -0
- package/pagination/PageOption.js +55 -0
- package/pagination/Pagination.js +245 -0
- package/picker/Input.js +124 -0
- package/picker/InputRange.js +155 -0
- package/portal/Portal.js +25 -0
- package/progress/CircleProgress.js +117 -0
- package/progress/LineProgess.js +103 -0
- package/progress/StepProgress.js +74 -0
- package/radio/Group.js +91 -0
- package/radio/Radio.js +90 -0
- package/resize-box/ResizeTrigger.js +78 -0
- package/resize-box/Split.js +132 -0
- package/resize-box/SplitGroup.js +204 -0
- package/result/403.js +695 -0
- package/result/404.js +513 -0
- package/result/500.js +166 -0
- package/select/OptGroup.js +20 -0
- package/select/Option.js +97 -0
- package/select/Select.js +544 -0
- package/select/util.js +140 -0
- package/select-view/Core.js +309 -0
- package/skeleton/Image.js +24 -0
- package/skeleton/Text.js +27 -0
- package/slider/Button.js +159 -0
- package/slider/Dot.js +43 -0
- package/slider/Input.js +75 -0
- package/slider/Mark.js +28 -0
- package/slider/Tick.js +44 -0
- package/slider/hook/useInterval.js +73 -0
- package/slider/hook/useLegalValue.js +70 -0
- package/slider/util.js +63 -0
- package/space/toArray.js +11 -0
- package/spin/DotLoading.js +26 -0
- package/statistic/Countdown.js +57 -0
- package/statistic/util.js +33 -0
- package/steps/Step.js +68 -0
- package/style.css +1 -1
- package/table/ColGroup.js +59 -0
- package/table/Table.js +634 -0
- package/table/constant.js +5 -0
- package/table/hook/useColumns.js +141 -0
- package/table/hook/useComponent.js +64 -0
- package/table/hook/useExpand.js +36 -0
- package/table/hook/useRowSelection.js +92 -0
- package/table/hook/useSorter.js +54 -0
- package/table/hook/useStickyClassNames.js +30 -0
- package/table/hook/useStickyOffsets.js +30 -0
- package/table/summary/Cell.js +10 -0
- package/table/summary/Row.js +26 -0
- package/table/summary/context.js +5 -0
- package/table/summary/index.js +10 -0
- package/table/tbody/Td.js +168 -0
- package/table/tbody/Tr.js +168 -0
- package/table/tbody/index.js +156 -0
- package/table/tfoot/index.js +16 -0
- package/table/thead/Column.js +250 -0
- package/table/thead/index.js +131 -0
- package/table/util.js +121 -0
- package/tabs/Tab.js +170 -0
- package/tabs/TabContent.js +54 -0
- package/tabs/TabPane.js +26 -0
- package/tabs/hook/useDomSize.js +17 -0
- package/tabs/hook/useHeaderScroll.js +64 -0
- package/tabs/tab-header/DropdownIcon.js +71 -0
- package/tabs/tab-header/TabInk.js +65 -0
- package/tabs/tab-header/TabNavIcon.js +65 -0
- package/tabs/tab-header/TabTitle.js +78 -0
- package/tabs/tab-header/index.js +335 -0
- package/tabs/util.js +22 -0
- package/time-picker/Picker.js +221 -0
- package/time-picker/RangePicker.js +56 -0
- package/time-picker/TimeColumn.js +65 -0
- package/time-picker/TimePicker.js +242 -0
- package/time-picker/context.js +5 -0
- package/time-picker/util.js +43 -0
- package/timeline/Item.js +94 -0
- package/timeline/Timeline.js +80 -0
- package/transfer/Item.js +107 -0
- package/transfer/List.js +192 -0
- package/tree/Animation.js +104 -0
- package/tree/Context.js +5 -0
- package/tree/Node.js +215 -0
- package/tree/NodeList.js +84 -0
- package/tree/Tree.js +549 -0
- package/tree/util.js +76 -0
- package/tree-select/List.js +127 -0
- package/tree-select/Select.js +260 -0
- package/tree-select/hook/useKeyCache.js +56 -0
- package/tree-select/hook/useStateValue.js +98 -0
- package/tree-select/hook/useTreeData.js +13 -0
- package/tree-select/interface.js +13 -0
- package/tree-select/util.js +9 -0
- package/trigger/Portal.js +14 -0
- package/trigger/getPopupStyle.js +190 -0
- package/types/badge/Count.d.ts +2 -1
- package/types/badge/index.d.ts +2 -2
- package/types/button/index.d.ts +2 -2
- package/types/carousel/index.d.ts +1 -1
- package/types/color-picker/colors.d.ts +1 -1
- package/types/color-picker/style/index.d.ts +1 -1
- package/types/drawer/Drawer.d.ts +1 -1
- package/types/dropdown/interface.d.ts +1 -0
- package/types/hooks/index.d.ts +122 -0
- package/types/hooks/use-verification-code/interface.d.ts +1 -1
- package/types/hooks/useAsync.d.ts +1 -1
- package/types/hooks/useDropArea.d.ts +1 -0
- package/types/hooks/useOverrideRef.d.ts +5 -0
- package/types/hooks/usePersistCallback.d.ts +1 -0
- package/types/hooks/useUpsert.d.ts +1 -1
- package/types/icon-hover/index.d.ts +5 -3
- package/types/index.d.ts +2 -120
- package/types/input-tag/InputTag.d.ts +1 -1
- package/types/link/interface.d.ts +1 -1
- package/types/list/index.d.ts +1 -1
- package/types/modal/interface.d.ts +1 -0
- package/types/notice/index.d.ts +3 -0
- package/types/notification/index.d.ts +1 -1
- package/types/page-header/index.d.ts +1 -1
- package/types/select/Select.d.ts +1 -1
- package/types/select-view/Core.d.ts +3 -2
- package/types/select-view/index.d.ts +1 -0
- package/types/statistic/index.d.ts +1 -1
- package/types/switch/index.d.ts +1 -1
- package/types/switch/interface.d.ts +1 -1
- package/types/table/interface.d.ts +2 -1
- package/types/tooltip/index.d.ts +1 -1
- package/types/trigger/index.d.ts +12 -8
- package/types/trigger/interface.d.ts +1 -0
- package/types/typography/Base.d.ts +8 -7
- package/types/typography/EditContent.d.ts +3 -2
- package/types/typography/Paragraph.d.ts +2 -5
- package/types/typography/Text.d.ts +1 -5
- package/types/typography/Title.d.ts +2 -5
- package/types/upload/TriggerNode.d.ts +5 -3
- package/types/upload/list/PictureItem.d.ts +3 -3
- package/types/upload/list/TextItem.d.ts +3 -3
- package/types/utils/CSSTransition.d.ts +2 -0
- package/types/utils/constant.d.ts +1 -1
- package/types/utils/is.d.ts +4 -0
- package/types/utils/reactDOM.d.ts +3 -1
- package/types/utils/warning.d.ts +1 -1
- package/types/version/index.d.ts +1 -1
- package/typography/Base.js +184 -0
- package/typography/EditContent.js +49 -0
- package/typography/Ellipsis.js +293 -0
- package/typography/Operations.js +78 -0
- package/typography/Paragraph.js +26 -0
- package/typography/Text.js +11 -0
- package/typography/Title.js +12 -0
- package/typography/Typography.js +15 -0
- package/typography/useCssEllipsis.js +37 -0
- package/typography/useEllipsis.js +150 -0
- package/upload/TriggerNode.js +118 -0
- package/upload/Upload.js +205 -0
- package/upload/Uploader.js +205 -0
- package/upload/interface.js +9 -0
- package/upload/list/PictureItem.js +91 -0
- package/upload/list/TextItem.js +99 -0
- package/upload/list/UploadProgress.js +97 -0
- package/upload/list/index.js +120 -0
- package/upload/request.js +51 -0
- package/upload/util.js +61 -0
- package/utils/CSSTransition.js +27 -0
- package/utils/contextHolder.js +29 -4
- package/utils/getHighlightText.js +1 -2
- package/utils/is.js +81 -68
- package/utils/reactDOM.js +33 -22
- package/utils/style.js +1 -2
- package/utils/warning.js +7 -3
- package/verification-code/VerificationCode.js +83 -0
- package/virtual-list/Filler.js +31 -0
- package/virtual-list/VirtualList.js +378 -0
- package/virtual-list/util/algorithm.js +32 -0
- package/virtual-list/util/item.js +99 -0
- package/{chunk/BCEX3Acw.js → watermark/Watermark.js} +13 -11
- package/chunk/B1P8u7kB.js +0 -798
- package/chunk/B2ufZjjd.js +0 -1000
- package/chunk/B7QOJqps.js +0 -162
- package/chunk/BBz3S3zo.js +0 -966
- package/chunk/BGzBxiWE.js +0 -517
- package/chunk/BNRfcEHj.js +0 -984
- package/chunk/BSs6uXmc.js +0 -946
- package/chunk/BTjUAV8T.js +0 -277
- package/chunk/BYQeEcKe.js +0 -375
- package/chunk/Ba4UXIST.js +0 -605
- package/chunk/BfaXVcik.js +0 -271
- package/chunk/Bs11tCU6.js +0 -240
- package/chunk/C7FC7dzS.js +0 -516
- package/chunk/CLzbve11.js +0 -694
- package/chunk/CN4zXU4b.js +0 -877
- package/chunk/CYTPZUHD.js +0 -769
- package/chunk/CcCo_dK0.js +0 -335
- package/chunk/CoCXcpQd.js +0 -261
- package/chunk/D4yH4UKK.js +0 -80
- package/chunk/DiSLYN2-.js +0 -167
- package/chunk/Dr0iXIXO.js +0 -736
- package/chunk/G3-2uJao.js +0 -229
- package/chunk/RnTpOC5-.js +0 -1
- package/chunk/Z-mtdHUQ.js +0 -226
- package/chunk/ZISxNnaR.js +0 -165
- package/chunk/aPJXnDSb.js +0 -450
- package/chunk/i605JRmI.js +0 -232
- package/chunk/l0sNRNKZ.js +0 -1
- package/types/form/FormItemTip.d.ts +0 -8
- /package/{chunk/C6Kfwj0f.js → loading/style/index.less.js} +0 -0
- /package/{chunk/DP2rzg_V.js → suspense-fallback-test/style/index.less.js} +0 -0
- /package/{chunk/K6Dvbx-E.js → virtual-list/style/index.less.js} +0 -0
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { jsx as d } from "react/jsx-runtime";
|
|
2
|
+
import ce from "@unicom-cloud/icons/IconUiCheck";
|
|
3
|
+
import de from "@unicom-cloud/icons/IconUiLeft";
|
|
4
|
+
import pe from "@unicom-cloud/icons/IconUiLoading";
|
|
5
|
+
import me from "@unicom-cloud/icons/IconUiRight";
|
|
6
|
+
import { isEmptyValue as fe, isEmptyArray as he } from "@unicom-cloud/utils/is";
|
|
7
|
+
import ge from "lodash/isArray";
|
|
8
|
+
import w from "lodash/isFunction";
|
|
9
|
+
import I from "lodash/isPlainObject";
|
|
10
|
+
import Ce from "lodash/isString";
|
|
11
|
+
import { forwardRef as Ve, useContext as ve, useRef as S, useState as ye, useEffect as W, useImperativeHandle as Se, useCallback as $ } from "react";
|
|
12
|
+
/* empty css */
|
|
13
|
+
import "../config-provider/ConfigProvider.js";
|
|
14
|
+
import be from "../hooks/useForceUpdate.js";
|
|
15
|
+
import ke from "../hooks/useId.js";
|
|
16
|
+
import we from "../hooks/useMergeProps.js";
|
|
17
|
+
import j from "../hooks/useMergeValue.js";
|
|
18
|
+
import Oe from "../hooks/useUpdateEffect.js";
|
|
19
|
+
import Ee from "../SelectView.js";
|
|
20
|
+
import Ne from "../Trigger.js";
|
|
21
|
+
import Pe from "@unicom-cloud/utils/class-name";
|
|
22
|
+
import { Esc as xe, Enter as Ie, Tab as Me } from "../utils/keyCode.js";
|
|
23
|
+
import Le from "./hook/useRefCurrent.js";
|
|
24
|
+
import Te from "./panel/List.js";
|
|
25
|
+
import Re from "./panel/Search.js";
|
|
26
|
+
import { getConfig as De, getStore as Fe, formatValue as b, SHOW_CHILD as Ae, transformValuesToSet as Ue, valueInSet as Be, removeValueFromSet as _e, PANEL_MODE as z } from "./util.js";
|
|
27
|
+
import { ConfigContext as He } from "../config-provider/context.js";
|
|
28
|
+
const We = {
|
|
29
|
+
label: "label",
|
|
30
|
+
value: "value",
|
|
31
|
+
isLeaf: "isLeaf",
|
|
32
|
+
children: "children",
|
|
33
|
+
disabled: "disabled"
|
|
34
|
+
}, $e = {
|
|
35
|
+
options: [],
|
|
36
|
+
bordered: !0,
|
|
37
|
+
fieldNames: We,
|
|
38
|
+
trigger: "click",
|
|
39
|
+
expandTrigger: "click",
|
|
40
|
+
checkedStrategy: Ae,
|
|
41
|
+
defaultActiveFirstOption: !0
|
|
42
|
+
}, je = { bottom: 4 };
|
|
43
|
+
function ze(K, J) {
|
|
44
|
+
const { getPrefixCls: q, renderEmpty: G, componentConfig: O, rtl: v } = ve(He), e = we(
|
|
45
|
+
K,
|
|
46
|
+
$e,
|
|
47
|
+
O == null ? void 0 : O.Cascader
|
|
48
|
+
), {
|
|
49
|
+
disabled: M,
|
|
50
|
+
renderFormat: E,
|
|
51
|
+
getPopupContainer: Q,
|
|
52
|
+
children: L,
|
|
53
|
+
triggerProps: X,
|
|
54
|
+
expandTrigger: Y,
|
|
55
|
+
icons: f
|
|
56
|
+
} = e, T = {
|
|
57
|
+
loading: (f == null ? void 0 : f.loading) || /* @__PURE__ */ d(pe, {}),
|
|
58
|
+
checked: (f == null ? void 0 : f.checked) || /* @__PURE__ */ d(ce, {}),
|
|
59
|
+
next: (f == null ? void 0 : f.next) || (v ? /* @__PURE__ */ d(de, {}) : /* @__PURE__ */ d(me, {}))
|
|
60
|
+
}, g = q("cascader"), a = e.mode === "multiple", y = S(null), Z = be(), l = Le(() => Fe(
|
|
61
|
+
e,
|
|
62
|
+
b(
|
|
63
|
+
"value" in e ? e.value : e.defaultValue,
|
|
64
|
+
a
|
|
65
|
+
)
|
|
66
|
+
), [JSON.stringify(De(e)), e.options]), [R, D] = ye(() => "value" in e ? b(e.value, a, l) : "defaultValue" in e ? b(e.defaultValue, a, l) : []), h = "value" in e ? b(e.value, a, l) : R, [u, ee] = j(!1, {
|
|
67
|
+
value: e.popupVisible,
|
|
68
|
+
defaultValue: e.defaultPopupVisible
|
|
69
|
+
}), [c, te, re] = j("", {
|
|
70
|
+
value: "inputValue" in e ? e.inputValue || "" : void 0
|
|
71
|
+
}), k = S(c), F = S(null), C = S(null), N = S((l == null ? void 0 : l.getCheckedNodes()) || []), A = ke(`${g}-popup-`), P = (t, r) => {
|
|
72
|
+
var n;
|
|
73
|
+
t !== k.current && (te(t), k.current = t, F.current = r, (n = e.onInputValueChange) == null || n.call(e, t, r));
|
|
74
|
+
};
|
|
75
|
+
function ne(t) {
|
|
76
|
+
return fe(t) || he(t);
|
|
77
|
+
}
|
|
78
|
+
W(() => {
|
|
79
|
+
var r;
|
|
80
|
+
const { current: t } = F;
|
|
81
|
+
re === c && (t === "manual" || t === "optionListHide") && ((r = e.onSearch) == null || r.call(e, c, t)), c !== k.current && (k.current = c);
|
|
82
|
+
}, [c]), W(() => {
|
|
83
|
+
const t = () => {
|
|
84
|
+
clearTimeout(y.current), y.current = null;
|
|
85
|
+
};
|
|
86
|
+
return !u && c && (y.current && t(), y.current = setTimeout(() => {
|
|
87
|
+
P("", "optionListHide"), y.current = null;
|
|
88
|
+
}, 200)), () => {
|
|
89
|
+
t();
|
|
90
|
+
};
|
|
91
|
+
}, [u]), Oe(() => {
|
|
92
|
+
if ("value" in e && e.value !== R) {
|
|
93
|
+
const t = b(e.value, a);
|
|
94
|
+
l.setNodeCheckedByValue(t), D(t);
|
|
95
|
+
}
|
|
96
|
+
}, [e.value, a]), Se(J, () => C.current, []);
|
|
97
|
+
const oe = (t) => {
|
|
98
|
+
N.current = Array.from(
|
|
99
|
+
new Set([].concat(t, N.current))
|
|
100
|
+
);
|
|
101
|
+
}, U = (t) => {
|
|
102
|
+
const r = [], n = Ue(t), i = (o) => {
|
|
103
|
+
o.some((s) => {
|
|
104
|
+
if (Be(n, s.pathValue) && (r.push(s.getPathNodes().map((m) => m._data)), _e(n, s.pathValue)), !n.size)
|
|
105
|
+
return !0;
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
return i(l.getCheckedNodes()), n.size && i(N.current), r;
|
|
109
|
+
}, p = $(
|
|
110
|
+
(t) => {
|
|
111
|
+
var r;
|
|
112
|
+
t !== u && ((r = e.onVisibleChange) == null || r.call(e, t), "popupVisible" in e || ee(t));
|
|
113
|
+
},
|
|
114
|
+
[e.onVisibleChange, u]
|
|
115
|
+
), ie = $(
|
|
116
|
+
(t) => {
|
|
117
|
+
var o;
|
|
118
|
+
const r = U([t])[0] || [];
|
|
119
|
+
let n, i = ge(t) ? t.map((s) => String(s)) : [];
|
|
120
|
+
return r.length && (i = r.map((s) => s.label)), w(E) ? n = E(i) : i.every((s) => Ce(s)) ? n = i.join(" / ") : n = i.reduce((s, m, x) => s.concat(x === 0 ? [m] : [" / ", m]), []), {
|
|
121
|
+
text: n || "",
|
|
122
|
+
disabled: (o = r[r.length - 1]) == null ? void 0 : o.disabled
|
|
123
|
+
};
|
|
124
|
+
},
|
|
125
|
+
[l, E]
|
|
126
|
+
), V = (t, r) => {
|
|
127
|
+
var H;
|
|
128
|
+
r === "panel" && I(e.showSearch) && !e.showSearch.retainInputValueWhileSelect && a && P("", "optionChecked");
|
|
129
|
+
const { onChange: n, changeOnSelect: i, expandTrigger: o } = e;
|
|
130
|
+
if (h === t)
|
|
131
|
+
return;
|
|
132
|
+
a || l.setNodeCheckedByValue(t), oe(l.getCheckedNodes());
|
|
133
|
+
const m = U(t), x = a ? t : t[0], ue = a ? m : m[0];
|
|
134
|
+
a || (c || m[0] && ((H = m[0][m[0].length - 1]) != null && H.isLeaf) || i && o === "hover") && p(!1), "value" in e ? (l.setNodeCheckedByValue(h), Z()) : D(t), n == null || n(x, ue, {
|
|
135
|
+
dropdownVisible: u
|
|
136
|
+
});
|
|
137
|
+
}, ae = (t, r, n) => {
|
|
138
|
+
if (n.stopPropagation(), t.disabled)
|
|
139
|
+
return;
|
|
140
|
+
const i = h.filter((o, s) => s !== r);
|
|
141
|
+
l.setNodeCheckedByValue(i), V(i);
|
|
142
|
+
}, B = (t) => {
|
|
143
|
+
const r = t || C.current && C.current.getWidth();
|
|
144
|
+
return /* @__PURE__ */ d(
|
|
145
|
+
"div",
|
|
146
|
+
{
|
|
147
|
+
className: `${g}-list-empty`,
|
|
148
|
+
style: { width: r },
|
|
149
|
+
children: e.notFoundContent || G("Cascader")
|
|
150
|
+
}
|
|
151
|
+
);
|
|
152
|
+
}, le = () => {
|
|
153
|
+
const t = I(e.showSearch) ? e.showSearch.panelMode : void 0, r = t === z.select ? !0 : t === z.cascader ? !1 : !w(e.onSearch) && !!c, n = C.current && C.current.getWidth(), i = w(e.dropdownRender) ? e.dropdownRender : (o) => o;
|
|
154
|
+
return /* @__PURE__ */ d(
|
|
155
|
+
"div",
|
|
156
|
+
{
|
|
157
|
+
id: A,
|
|
158
|
+
className: Pe(`${g}-popup`, e.dropdownMenuClassName, {
|
|
159
|
+
[`${g}-popup-trigger-hover`]: e.expandTrigger === "hover"
|
|
160
|
+
}),
|
|
161
|
+
children: i(
|
|
162
|
+
/* @__PURE__ */ d(
|
|
163
|
+
"div",
|
|
164
|
+
{
|
|
165
|
+
className: `${g}-popup-inner`,
|
|
166
|
+
onMouseDown: (o) => o.preventDefault(),
|
|
167
|
+
children: r ? /* @__PURE__ */ d(
|
|
168
|
+
Re,
|
|
169
|
+
{
|
|
170
|
+
style: { minWidth: n },
|
|
171
|
+
store: l,
|
|
172
|
+
inputValue: c,
|
|
173
|
+
renderEmpty: () => B(n),
|
|
174
|
+
multiple: a,
|
|
175
|
+
onChange: (o) => {
|
|
176
|
+
V(o, "panel");
|
|
177
|
+
},
|
|
178
|
+
prefixCls: g,
|
|
179
|
+
rtl: v,
|
|
180
|
+
onEsc: () => {
|
|
181
|
+
p(!1);
|
|
182
|
+
},
|
|
183
|
+
renderOption: I(e.showSearch) && e.showSearch.renderOption || void 0,
|
|
184
|
+
getTriggerElement: () => {
|
|
185
|
+
var o;
|
|
186
|
+
return (o = C.current) == null ? void 0 : o.dom;
|
|
187
|
+
},
|
|
188
|
+
value: h,
|
|
189
|
+
virtualListProps: e.virtualListProps,
|
|
190
|
+
defaultActiveFirstOption: e.defaultActiveFirstOption,
|
|
191
|
+
icons: T
|
|
192
|
+
}
|
|
193
|
+
) : /* @__PURE__ */ d(
|
|
194
|
+
Te,
|
|
195
|
+
{
|
|
196
|
+
dropdownMenuColumnStyle: e.dropdownMenuColumnStyle,
|
|
197
|
+
virtualListProps: e.virtualListProps,
|
|
198
|
+
expandTrigger: Y,
|
|
199
|
+
store: l,
|
|
200
|
+
dropdownColumnRender: e.dropdownColumnRender,
|
|
201
|
+
renderOption: e.renderOption,
|
|
202
|
+
changeOnSelect: e.changeOnSelect,
|
|
203
|
+
showEmptyChildren: e.showEmptyChildren || !!e.loadMore,
|
|
204
|
+
multiple: a,
|
|
205
|
+
onChange: (o) => {
|
|
206
|
+
V(o, "panel");
|
|
207
|
+
},
|
|
208
|
+
loadMore: e.loadMore,
|
|
209
|
+
prefixCls: g,
|
|
210
|
+
rtl: v,
|
|
211
|
+
getTriggerElement: () => {
|
|
212
|
+
var o;
|
|
213
|
+
return (o = C.current) == null ? void 0 : o.dom;
|
|
214
|
+
},
|
|
215
|
+
renderEmpty: B,
|
|
216
|
+
popupVisible: u,
|
|
217
|
+
value: h,
|
|
218
|
+
renderFooter: e.renderFooter,
|
|
219
|
+
icons: T,
|
|
220
|
+
onEsc: () => {
|
|
221
|
+
p(!1);
|
|
222
|
+
},
|
|
223
|
+
onDoubleClickOption: () => {
|
|
224
|
+
e.changeOnSelect && !a && p(!1);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
)
|
|
228
|
+
}
|
|
229
|
+
)
|
|
230
|
+
)
|
|
231
|
+
}
|
|
232
|
+
);
|
|
233
|
+
}, se = (t) => {
|
|
234
|
+
V(t);
|
|
235
|
+
}, _ = (t) => /* @__PURE__ */ d(
|
|
236
|
+
Ne,
|
|
237
|
+
{
|
|
238
|
+
popup: le,
|
|
239
|
+
trigger: e.trigger,
|
|
240
|
+
disabled: M,
|
|
241
|
+
getPopupContainer: Q,
|
|
242
|
+
position: v ? "br" : "bl",
|
|
243
|
+
classNames: "slideDynamicOrigin",
|
|
244
|
+
popupAlign: je,
|
|
245
|
+
unmountOnExit: "unmountOnExit" in e ? e.unmountOnExit : !w(e.loadMore),
|
|
246
|
+
popupVisible: u,
|
|
247
|
+
...X,
|
|
248
|
+
onVisibleChange: p,
|
|
249
|
+
children: t
|
|
250
|
+
}
|
|
251
|
+
);
|
|
252
|
+
return L ? _(L) : /* @__PURE__ */ d(
|
|
253
|
+
Ee,
|
|
254
|
+
{
|
|
255
|
+
...e,
|
|
256
|
+
ref: C,
|
|
257
|
+
ariaControls: A,
|
|
258
|
+
popupVisible: u,
|
|
259
|
+
value: a ? h : h && h[0],
|
|
260
|
+
inputValue: c,
|
|
261
|
+
rtl: v,
|
|
262
|
+
isEmptyValue: ne(h),
|
|
263
|
+
prefixCls: g,
|
|
264
|
+
isMultiple: a,
|
|
265
|
+
renderText: ie,
|
|
266
|
+
onRemoveCheckedItem: ae,
|
|
267
|
+
onSort: se,
|
|
268
|
+
renderView: _,
|
|
269
|
+
onClear: (t) => {
|
|
270
|
+
var r;
|
|
271
|
+
if (t.stopPropagation(), !a)
|
|
272
|
+
V([]);
|
|
273
|
+
else {
|
|
274
|
+
const i = l.getCheckedNodes().filter((o) => o.disabled).map((o) => o.pathValue);
|
|
275
|
+
l.setNodeCheckedByValue(i), V(i);
|
|
276
|
+
}
|
|
277
|
+
(r = e.onClear) == null || r.call(e, !!u);
|
|
278
|
+
},
|
|
279
|
+
onKeyDown: (t) => {
|
|
280
|
+
var n;
|
|
281
|
+
if (M)
|
|
282
|
+
return;
|
|
283
|
+
t.stopPropagation();
|
|
284
|
+
const r = t.key;
|
|
285
|
+
r === xe.key && u && (p(!1), t.preventDefault()), r === Ie.key && !u && (p(!0), t.preventDefault()), r === Me.key && u && p(!1), (n = e.onKeyDown) == null || n.call(e, t);
|
|
286
|
+
},
|
|
287
|
+
onChangeInputValue: (t) => {
|
|
288
|
+
P(t, "manual"), u || p(!0);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
);
|
|
292
|
+
}
|
|
293
|
+
const Ke = Ve(
|
|
294
|
+
ze
|
|
295
|
+
);
|
|
296
|
+
Ke.displayName = "Cascader";
|
|
297
|
+
export {
|
|
298
|
+
We as DefaultFieldNames,
|
|
299
|
+
Ke as default
|
|
300
|
+
};
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
var b = Object.defineProperty;
|
|
2
|
+
var k = (d, e, t) => e in d ? b(d, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : d[e] = t;
|
|
3
|
+
var a = (d, e, t) => k(d, typeof e != "symbol" ? e + "" : e, t);
|
|
4
|
+
import c from "lodash/get";
|
|
5
|
+
import { DefaultFieldNames as g } from "../Cascader.js";
|
|
6
|
+
class _ {
|
|
7
|
+
constructor(e, t, h) {
|
|
8
|
+
a(this, "value");
|
|
9
|
+
a(this, "label");
|
|
10
|
+
// 是否禁用
|
|
11
|
+
a(this, "disabled");
|
|
12
|
+
a(this, "_level");
|
|
13
|
+
a(this, "_index");
|
|
14
|
+
a(this, "isLeaf");
|
|
15
|
+
a(this, "disableCheckbox");
|
|
16
|
+
// 是否选中
|
|
17
|
+
a(this, "_checked");
|
|
18
|
+
/** 是否半选 */
|
|
19
|
+
a(this, "_halfChecked");
|
|
20
|
+
/** 当前选项节点的父节点 */
|
|
21
|
+
a(this, "parent");
|
|
22
|
+
/** 当前选项节点路径的所有节点的值 */
|
|
23
|
+
a(this, "pathValue", []);
|
|
24
|
+
a(this, "pathLabel", []);
|
|
25
|
+
/** 下一级选项 */
|
|
26
|
+
a(this, "children");
|
|
27
|
+
/** 是否在加载中 */
|
|
28
|
+
a(this, "loading");
|
|
29
|
+
/** 是否加载完成 */
|
|
30
|
+
a(this, "loaded");
|
|
31
|
+
a(this, "config", {});
|
|
32
|
+
// 保存暴露给外部的属性
|
|
33
|
+
a(this, "_data");
|
|
34
|
+
a(this, "_initNode", (e, t = null) => {
|
|
35
|
+
const { showEmptyChildren: h, lazyload: i } = this.config, l = { ...g, ...this.config.fieldNames }, n = c(e, l.children) || e[l.children];
|
|
36
|
+
let f = Array.isArray(n) ? h ? !1 : n.length === 0 : !0;
|
|
37
|
+
i && (l.isLeaf in e ? f = !!c(e, l.isLeaf) || !!e[l.isLeaf] : f = !1);
|
|
38
|
+
const u = c(e, l.value) || e[l.value], o = c(e, l.label) || e[l.label], r = {
|
|
39
|
+
...e,
|
|
40
|
+
value: u,
|
|
41
|
+
label: o,
|
|
42
|
+
isLeaf: f,
|
|
43
|
+
loading: !1,
|
|
44
|
+
loaded: !1,
|
|
45
|
+
disabled: t && t.disabled || c(e, l.disabled) || e[l.disabled],
|
|
46
|
+
parent: t,
|
|
47
|
+
pathValue: t ? [...t.pathValue, u] : [u],
|
|
48
|
+
pathLabel: t ? [...t.pathLabel, o] : [o],
|
|
49
|
+
_level: t ? t._level + 1 : 0,
|
|
50
|
+
_checked: !1,
|
|
51
|
+
_halfChecked: !1
|
|
52
|
+
};
|
|
53
|
+
this._data = {
|
|
54
|
+
...r,
|
|
55
|
+
parent: r.parent && r.parent._data
|
|
56
|
+
}, Object.keys(r).forEach((s) => {
|
|
57
|
+
this[s] = r[s];
|
|
58
|
+
}), n && n.length && (this.children = n.map((s, C) => new _({ ...s, _index: C }, this.config, this)), this._data.children = this.children.map((s) => s._data));
|
|
59
|
+
});
|
|
60
|
+
/**
|
|
61
|
+
* 根据this.children 计算是否当前node半选状态
|
|
62
|
+
* 假设半选是 0.5,全选是1,不选是0。
|
|
63
|
+
* 那么只有当前节点的所有children加起来等于children.length,才是全选,否则和大于0,就是半选。
|
|
64
|
+
*/
|
|
65
|
+
a(this, "_isHalfChecked", () => {
|
|
66
|
+
const e = this.children.reduce((t, h) => {
|
|
67
|
+
const i = h._halfChecked ? 0.5 : h._checked ? 1 : 0;
|
|
68
|
+
return t + i;
|
|
69
|
+
}, 0);
|
|
70
|
+
return e !== this.children.length && e > 0;
|
|
71
|
+
});
|
|
72
|
+
/**
|
|
73
|
+
*
|
|
74
|
+
* @param checked 选中状态
|
|
75
|
+
* @param ignoreDisabled 是否忽略节点禁用设置选中状态,一般在初始化设置选中状态时传参为true
|
|
76
|
+
*/
|
|
77
|
+
a(this, "_setNodeChildrenChecked", (e, t) => {
|
|
78
|
+
!t && this.disabled || this.children && this.children.length && (this.children.forEach((h) => {
|
|
79
|
+
h.disabled ? t && h.setCheckedStateIgnoreDisabled(e) : h.setCheckedState(e);
|
|
80
|
+
}), this.updateHalfState(e));
|
|
81
|
+
});
|
|
82
|
+
a(this, "getSelfChildrenValue", () => {
|
|
83
|
+
const e = [], t = (h, i) => {
|
|
84
|
+
if (!i || !i.length) {
|
|
85
|
+
e.push(h);
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
(i || []).forEach((l) => {
|
|
89
|
+
t(l.pathValue, l.children);
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
return t(this.pathValue, this.children), e;
|
|
93
|
+
});
|
|
94
|
+
a(this, "updateHalfState", (e) => {
|
|
95
|
+
this._halfChecked = this._isHalfChecked(), this._checked = this._halfChecked ? !1 : e;
|
|
96
|
+
});
|
|
97
|
+
// 直接设置选中状态
|
|
98
|
+
a(this, "setCheckedProperty", (e) => {
|
|
99
|
+
this._checked = e, this._halfChecked = !1;
|
|
100
|
+
});
|
|
101
|
+
// 设置当前节点选中状态
|
|
102
|
+
a(this, "setCheckedState", (e) => {
|
|
103
|
+
const t = e ? this._checked : !this._checked && !this._halfChecked;
|
|
104
|
+
if (!(this.disabled || t) && (this.setCheckedProperty(e), !this.config.changeOnSelect)) {
|
|
105
|
+
this._setNodeChildrenChecked(e);
|
|
106
|
+
let h = this.parent;
|
|
107
|
+
for (; h && !h.disabled; )
|
|
108
|
+
h.updateHalfState(e), h = h.parent;
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
// 忽略禁用设置选中状态
|
|
112
|
+
a(this, "setCheckedStateIgnoreDisabled", (e) => {
|
|
113
|
+
if (e !== !!this._checked && (this.setCheckedProperty(e), !this.config.changeOnSelect)) {
|
|
114
|
+
this._setNodeChildrenChecked(e, !0);
|
|
115
|
+
let t = this.parent;
|
|
116
|
+
for (; t; )
|
|
117
|
+
t.updateHalfState(e), t = t.parent;
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
/**
|
|
121
|
+
* 遍历节点的parent,获取当前节点的路径节点。
|
|
122
|
+
* node: { label: '1-1-1', parent: { label: '1-1', parent: { label: '1' }, ... }, ...}
|
|
123
|
+
* @return [node.parent.parent, node.parent, node]
|
|
124
|
+
* @memberof Store
|
|
125
|
+
*/
|
|
126
|
+
a(this, "getPathNodes", () => {
|
|
127
|
+
const e = [this];
|
|
128
|
+
let t = this.parent;
|
|
129
|
+
for (; t; )
|
|
130
|
+
e.unshift(t), t = t.parent;
|
|
131
|
+
return e;
|
|
132
|
+
});
|
|
133
|
+
a(this, "getChildren", () => this.children);
|
|
134
|
+
a(this, "setLoading", (e) => {
|
|
135
|
+
this.loading = e, (e || e === void 0) && (this.loaded = !1), e === !1 && (this.loaded = !0);
|
|
136
|
+
});
|
|
137
|
+
this.config = t || {}, this._initNode(e, h || null);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
export {
|
|
141
|
+
_ as default
|
|
142
|
+
};
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
var l = Object.defineProperty;
|
|
2
|
+
var c = (i, e, t) => e in i ? l(i, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : i[e] = t;
|
|
3
|
+
var a = (i, e, t) => c(i, typeof e != "symbol" ? e + "" : e, t);
|
|
4
|
+
import d from "lodash/isArray";
|
|
5
|
+
import u from "lodash/isEqualWith";
|
|
6
|
+
import N from "lodash/isFunction";
|
|
7
|
+
import g from "lodash/isString";
|
|
8
|
+
import { transformValuesToSet as m, valueInSet as n } from "../util.js";
|
|
9
|
+
import p from "./node.js";
|
|
10
|
+
class P {
|
|
11
|
+
constructor(e, t, s) {
|
|
12
|
+
a(this, "nodes", []);
|
|
13
|
+
a(this, "flatNodes", []);
|
|
14
|
+
a(this, "config", {});
|
|
15
|
+
// 初始化节点状态,附加状态信息字段: _checked,_halfChecked,parent,disabled
|
|
16
|
+
a(this, "_calcNodes", (e, t) => e ? e.map((s, r) => new p({ ...s, _index: r }, this.config, t)) : []);
|
|
17
|
+
// this.flatNodes 保存所有可能的选中项
|
|
18
|
+
a(this, "_updateFlatNodes", () => {
|
|
19
|
+
const e = !this.config.changeOnSelect;
|
|
20
|
+
this.flatNodes = [];
|
|
21
|
+
const t = (s) => {
|
|
22
|
+
s && ((!e || s.isLeaf) && this.flatNodes.push(s), d(s.children) && s.children.forEach((r) => {
|
|
23
|
+
t(r);
|
|
24
|
+
}));
|
|
25
|
+
};
|
|
26
|
+
this.nodes.forEach((s) => {
|
|
27
|
+
t(s);
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
/**
|
|
31
|
+
* values: 全部的选中值
|
|
32
|
+
* 根据values更新节点状态。不包含在values的节点都设置为未选中状态
|
|
33
|
+
* @memberof Store
|
|
34
|
+
*/
|
|
35
|
+
a(this, "setNodeCheckedByValue", (e) => {
|
|
36
|
+
const t = m(e);
|
|
37
|
+
this.flatNodes.forEach((s) => {
|
|
38
|
+
let r = !1;
|
|
39
|
+
this.config.showParent ? s.pathValue.some(
|
|
40
|
+
(o, h, f) => n(t, f.slice(0, h + 1))
|
|
41
|
+
) && (r = !0) : n(t, s.pathValue) && (r = !0), s.setCheckedStateIgnoreDisabled(r);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
/**
|
|
45
|
+
* 为当前节点插入子节点。动态加载时候用到
|
|
46
|
+
*/
|
|
47
|
+
a(this, "appendOptionChildren", (e, t) => {
|
|
48
|
+
if (t && e) {
|
|
49
|
+
const s = this._calcNodes(t, e);
|
|
50
|
+
e.children = s, this._updateFlatNodes(), this.config.changeOnSelect || e.setCheckedState(!1);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
/**
|
|
54
|
+
* 通过 value 查找对应的node节点。
|
|
55
|
+
* value: 是路径节点的value组成的数组
|
|
56
|
+
*/
|
|
57
|
+
a(this, "findNodeByValue", (e) => {
|
|
58
|
+
let t = null;
|
|
59
|
+
return !e || !e.length || this.flatNodes.some((s) => {
|
|
60
|
+
u(s.pathValue, e) && (t = s);
|
|
61
|
+
}), t;
|
|
62
|
+
});
|
|
63
|
+
/**
|
|
64
|
+
* 搜索所有label含有关键字的节点
|
|
65
|
+
*/
|
|
66
|
+
a(this, "searchNodeByLabel", (e) => {
|
|
67
|
+
if (!e)
|
|
68
|
+
return this.flatNodes;
|
|
69
|
+
const { filterOption: t } = this.config, s = N(t) ? t : (r, o) => g(o.label) && o.label.indexOf(r) > -1;
|
|
70
|
+
return this.flatNodes.filter((r) => r.getPathNodes().some((h) => s(e, h._data)));
|
|
71
|
+
});
|
|
72
|
+
/** 获取所有节点 */
|
|
73
|
+
a(this, "getOptions", () => this.nodes);
|
|
74
|
+
/** 获取所有选中状态的节点。 aggregation: 是否聚合节点 */
|
|
75
|
+
a(this, "getCheckedNodes", () => this.config.showParent ? this.getCheckedParentNodes() : this.flatNodes.filter((e) => e._checked));
|
|
76
|
+
// 按照父节点纬度聚合当前所有选中节点。
|
|
77
|
+
a(this, "getCheckedParentNodes", () => {
|
|
78
|
+
const e = /* @__PURE__ */ new Set();
|
|
79
|
+
return this.flatNodes.forEach((t) => {
|
|
80
|
+
t._checked && t.getPathNodes().some((r) => {
|
|
81
|
+
if (r._checked)
|
|
82
|
+
return e.has(r) || e.add(r), !0;
|
|
83
|
+
});
|
|
84
|
+
}), Array.from(e);
|
|
85
|
+
});
|
|
86
|
+
this.config = { ...s };
|
|
87
|
+
const r = Array.isArray(t) ? t : [];
|
|
88
|
+
this.nodes = this._calcNodes(e, null), this._updateFlatNodes(), this.setNodeCheckedByValue(r);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
export {
|
|
92
|
+
P as default
|
|
93
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { useRef as o } from "react";
|
|
2
|
+
import u from "../../hooks/useForceUpdate.js";
|
|
3
|
+
import c from "../../hooks/useUpdateEffect.js";
|
|
4
|
+
function m(e, t) {
|
|
5
|
+
const r = o(null), f = u();
|
|
6
|
+
return r.current || (r.current = e()), c(() => {
|
|
7
|
+
r.current = e(), f();
|
|
8
|
+
}, [...t]), r.current;
|
|
9
|
+
}
|
|
10
|
+
export {
|
|
11
|
+
m as default
|
|
12
|
+
};
|