@douyinfe/semi-ui 2.36.0-beta.0 → 2.36.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/umd/semi-ui.js +45123 -59672
- package/dist/umd/semi-ui.js.map +1 -1
- package/dist/umd/semi-ui.min.js +1 -1
- package/dist/umd/semi-ui.min.js.LICENSE.txt +3 -3
- package/dist/umd/semi-ui.min.js.map +1 -1
- package/lib/cjs/_base/base.d.ts +3 -3
- package/lib/cjs/_base/baseComponent.d.ts +1 -1
- package/lib/cjs/_base/baseComponent.js +5 -16
- package/lib/cjs/_base/reactUtils.js +3 -9
- package/lib/cjs/_cssAnimation/index.js +4 -25
- package/lib/cjs/_portal/index.js +0 -31
- package/lib/cjs/_utils/hooks/usePrevFocus.js +0 -6
- package/lib/cjs/_utils/index.js +6 -45
- package/lib/cjs/anchor/anchor-context.d.ts +1 -1
- package/lib/cjs/anchor/anchor-context.js +0 -4
- package/lib/cjs/anchor/index.js +2 -48
- package/lib/cjs/anchor/link.js +4 -36
- package/lib/cjs/autoComplete/index.d.ts +1 -1
- package/lib/cjs/autoComplete/index.js +3 -42
- package/lib/cjs/autoComplete/option.js +26 -54
- package/lib/cjs/avatar/avatarGroup.js +9 -42
- package/lib/cjs/avatar/index.js +15 -56
- package/lib/cjs/avatar/interface.d.ts +6 -6
- package/lib/cjs/backtop/index.js +9 -34
- package/lib/cjs/badge/index.d.ts +3 -3
- package/lib/cjs/badge/index.js +16 -38
- package/lib/cjs/banner/index.d.ts +1 -1
- package/lib/cjs/banner/index.js +3 -31
- package/lib/cjs/breadcrumb/bread-context.js +0 -4
- package/lib/cjs/breadcrumb/index.d.ts +1 -1
- package/lib/cjs/breadcrumb/index.js +1 -45
- package/lib/cjs/breadcrumb/item.d.ts +1 -1
- package/lib/cjs/breadcrumb/item.js +16 -56
- package/lib/cjs/button/Button.d.ts +4 -4
- package/lib/cjs/button/Button.js +18 -37
- package/lib/cjs/button/buttonGroup.d.ts +1 -1
- package/lib/cjs/button/buttonGroup.js +10 -35
- package/lib/cjs/button/index.js +0 -9
- package/lib/cjs/button/splitButtonGroup.js +0 -11
- package/lib/cjs/calendar/dayCalendar.js +0 -29
- package/lib/cjs/calendar/dayCol.js +1 -28
- package/lib/cjs/calendar/index.js +4 -22
- package/lib/cjs/calendar/interface.d.ts +5 -5
- package/lib/cjs/calendar/monthCalendar.js +6 -62
- package/lib/cjs/calendar/rangeCalendar.js +1 -34
- package/lib/cjs/calendar/timeCol.js +0 -20
- package/lib/cjs/calendar/weekCalendar.js +0 -35
- package/lib/cjs/card/cardGroup.d.ts +1 -1
- package/lib/cjs/card/cardGroup.js +8 -24
- package/lib/cjs/card/index.d.ts +1 -1
- package/lib/cjs/card/index.js +7 -38
- package/lib/cjs/card/meta.d.ts +1 -1
- package/lib/cjs/card/meta.js +8 -27
- package/lib/cjs/carousel/CarouselArrow.d.ts +2 -2
- package/lib/cjs/carousel/CarouselArrow.js +1 -13
- package/lib/cjs/carousel/CarouselIndicator.js +9 -33
- package/lib/cjs/carousel/index.js +1 -49
- package/lib/cjs/cascader/index.d.ts +2 -2
- package/lib/cjs/cascader/index.js +12 -144
- package/lib/cjs/cascader/item.js +2 -63
- package/lib/cjs/checkbox/checkbox.d.ts +1 -1
- package/lib/cjs/checkbox/checkbox.js +21 -55
- package/lib/cjs/checkbox/checkboxGroup.d.ts +4 -4
- package/lib/cjs/checkbox/checkboxGroup.js +9 -29
- package/lib/cjs/checkbox/checkboxInner.js +1 -15
- package/lib/cjs/checkbox/context.d.ts +1 -1
- package/lib/cjs/checkbox/context.js +0 -4
- package/lib/cjs/checkbox/index.js +0 -5
- package/lib/cjs/collapse/collapse-context.js +0 -4
- package/lib/cjs/collapse/index.js +14 -42
- package/lib/cjs/collapse/item.js +13 -41
- package/lib/cjs/collapsible/index.js +0 -34
- package/lib/cjs/configProvider/context.js +0 -4
- package/lib/cjs/configProvider/index.js +5 -21
- package/lib/cjs/datePicker/dateInput.js +39 -93
- package/lib/cjs/datePicker/datePicker.d.ts +1 -1
- package/lib/cjs/datePicker/datePicker.js +11 -119
- package/lib/cjs/datePicker/footer.js +0 -6
- package/lib/cjs/datePicker/index.js +2 -17
- package/lib/cjs/datePicker/insetInput.js +0 -9
- package/lib/cjs/datePicker/month.d.ts +1 -1
- package/lib/cjs/datePicker/month.js +25 -90
- package/lib/cjs/datePicker/monthsGrid.d.ts +1 -1
- package/lib/cjs/datePicker/monthsGrid.js +21 -96
- package/lib/cjs/datePicker/navigation.js +7 -24
- package/lib/cjs/datePicker/quickControl.js +1 -17
- package/lib/cjs/datePicker/yearAndMonth.d.ts +1 -1
- package/lib/cjs/datePicker/yearAndMonth.js +6 -52
- package/lib/cjs/descriptions/descriptions-context.d.ts +1 -1
- package/lib/cjs/descriptions/descriptions-context.js +0 -4
- package/lib/cjs/descriptions/index.d.ts +1 -1
- package/lib/cjs/descriptions/index.js +0 -15
- package/lib/cjs/descriptions/item.js +0 -14
- package/lib/cjs/divider/index.js +9 -23
- package/lib/cjs/dropdown/context.js +0 -4
- package/lib/cjs/dropdown/dropdownDivider.d.ts +1 -1
- package/lib/cjs/dropdown/dropdownDivider.js +0 -8
- package/lib/cjs/dropdown/dropdownItem.d.ts +1 -1
- package/lib/cjs/dropdown/dropdownItem.js +0 -21
- package/lib/cjs/dropdown/dropdownMenu.d.ts +1 -1
- package/lib/cjs/dropdown/dropdownMenu.js +6 -24
- package/lib/cjs/dropdown/dropdownTitle.d.ts +1 -1
- package/lib/cjs/dropdown/dropdownTitle.js +0 -12
- package/lib/cjs/dropdown/index.d.ts +1 -1
- package/lib/cjs/dropdown/index.js +21 -62
- package/lib/cjs/empty/index.js +0 -20
- package/lib/cjs/form/arrayField.js +15 -47
- package/lib/cjs/form/baseForm.js +26 -72
- package/lib/cjs/form/context.js +1 -10
- package/lib/cjs/form/errorMessage.d.ts +1 -1
- package/lib/cjs/form/errorMessage.js +1 -20
- package/lib/cjs/form/field.js +4 -23
- package/lib/cjs/form/group.js +11 -48
- package/lib/cjs/form/hoc/withField.js +69 -144
- package/lib/cjs/form/hoc/withFormApi.js +0 -7
- package/lib/cjs/form/hoc/withFormState.js +0 -7
- package/lib/cjs/form/hooks/index.js +0 -8
- package/lib/cjs/form/hooks/useArrayFieldState.js +0 -4
- package/lib/cjs/form/hooks/useFieldApi.js +0 -5
- package/lib/cjs/form/hooks/useFieldState.js +0 -8
- package/lib/cjs/form/hooks/useFormApi.js +0 -3
- package/lib/cjs/form/hooks/useFormState.js +0 -4
- package/lib/cjs/form/hooks/useFormUpdater.js +0 -3
- package/lib/cjs/form/hooks/useStateWithGetter.js +0 -5
- package/lib/cjs/form/index.js +0 -9
- package/lib/cjs/form/interface.d.ts +4 -4
- package/lib/cjs/form/interface.js +1 -8
- package/lib/cjs/form/label.js +0 -16
- package/lib/cjs/form/section.js +1 -11
- package/lib/cjs/form/slot.js +10 -51
- package/lib/cjs/grid/col.js +10 -29
- package/lib/cjs/grid/index.js +0 -3
- package/lib/cjs/grid/row.d.ts +2 -2
- package/lib/cjs/grid/row.js +10 -34
- package/lib/cjs/highlight/index.js +0 -11
- package/lib/cjs/iconButton/index.d.ts +1 -1
- package/lib/cjs/iconButton/index.js +18 -42
- package/lib/cjs/icons/index.js +0 -3
- package/lib/cjs/image/image.d.ts +0 -3
- package/lib/cjs/image/image.js +19 -88
- package/lib/cjs/image/index.js +0 -6
- package/lib/cjs/image/interface.d.ts +1 -1
- package/lib/cjs/image/preview.d.ts +4 -0
- package/lib/cjs/image/preview.js +53 -61
- package/lib/cjs/image/previewContext.js +0 -2
- package/lib/cjs/image/previewFooter.js +9 -62
- package/lib/cjs/image/previewHeader.js +0 -13
- package/lib/cjs/image/previewImage.js +46 -79
- package/lib/cjs/image/previewInner.js +70 -126
- package/lib/cjs/index.js +0 -86
- package/lib/cjs/input/index.d.ts +3 -3
- package/lib/cjs/input/index.js +35 -103
- package/lib/cjs/input/inputGroup.d.ts +1 -1
- package/lib/cjs/input/inputGroup.js +20 -44
- package/lib/cjs/input/textarea.d.ts +1 -1
- package/lib/cjs/input/textarea.js +33 -77
- package/lib/cjs/inputNumber/index.js +127 -199
- package/lib/cjs/layout/Sider.js +7 -32
- package/lib/cjs/layout/index.js +16 -40
- package/lib/cjs/layout/layout-context.js +0 -5
- package/lib/cjs/list/index.js +0 -26
- package/lib/cjs/list/item.js +6 -30
- package/lib/cjs/list/list-context.js +0 -4
- package/lib/cjs/locale/context.js +0 -4
- package/lib/cjs/locale/localeConsumer.d.ts +1 -1
- package/lib/cjs/locale/localeConsumer.js +0 -16
- package/lib/cjs/locale/localeProvider.js +0 -11
- package/lib/cjs/locale/source/ar.js +2 -4
- package/lib/cjs/locale/source/de.js +2 -4
- package/lib/cjs/locale/source/en_GB.js +2 -4
- package/lib/cjs/locale/source/en_US.js +2 -4
- package/lib/cjs/locale/source/es.js +0 -2
- package/lib/cjs/locale/source/fr.js +2 -4
- package/lib/cjs/locale/source/id_ID.js +2 -4
- package/lib/cjs/locale/source/it.js +2 -4
- package/lib/cjs/locale/source/ja_JP.js +2 -4
- package/lib/cjs/locale/source/ko_KR.js +2 -4
- package/lib/cjs/locale/source/ms_MY.js +2 -4
- package/lib/cjs/locale/source/nl_NL.js +0 -2
- package/lib/cjs/locale/source/pl_PL.js +0 -2
- package/lib/cjs/locale/source/pt_BR.js +2 -4
- package/lib/cjs/locale/source/ro.js +0 -2
- package/lib/cjs/locale/source/ru_RU.js +2 -4
- package/lib/cjs/locale/source/sv_SE.js +0 -2
- package/lib/cjs/locale/source/th_TH.js +2 -4
- package/lib/cjs/locale/source/tr_TR.js +2 -4
- package/lib/cjs/locale/source/vi_VN.js +2 -4
- package/lib/cjs/locale/source/zh_CN.js +2 -4
- package/lib/cjs/locale/source/zh_TW.js +2 -4
- package/lib/cjs/modal/ConfirmModal.js +9 -29
- package/lib/cjs/modal/Modal.d.ts +2 -2
- package/lib/cjs/modal/Modal.js +17 -80
- package/lib/cjs/modal/ModalContent.js +13 -72
- package/lib/cjs/modal/confirm.d.ts +9 -3
- package/lib/cjs/modal/confirm.js +4 -28
- package/lib/cjs/modal/index.d.ts +1 -1
- package/lib/cjs/modal/index.js +0 -4
- package/lib/cjs/modal/useModal/HookModal.js +4 -18
- package/lib/cjs/modal/useModal/index.d.ts +1 -1
- package/lib/cjs/modal/useModal/index.js +4 -18
- package/lib/cjs/navigation/CollapseButton.js +0 -11
- package/lib/cjs/navigation/Footer.js +0 -20
- package/lib/cjs/navigation/Header.d.ts +1 -1
- package/lib/cjs/navigation/Header.js +0 -18
- package/lib/cjs/navigation/Item.js +3 -51
- package/lib/cjs/navigation/SubNav.js +7 -67
- package/lib/cjs/navigation/index.d.ts +2 -2
- package/lib/cjs/navigation/index.js +5 -60
- package/lib/cjs/navigation/nav-context.js +0 -4
- package/lib/cjs/notification/index.d.ts +1 -1
- package/lib/cjs/notification/index.js +4 -56
- package/lib/cjs/notification/notice.js +24 -58
- package/lib/cjs/notification/useNotification/HookNotice.js +3 -18
- package/lib/cjs/notification/useNotification/index.js +4 -25
- package/lib/cjs/overflowList/index.d.ts +41 -24
- package/lib/cjs/overflowList/index.js +7 -65
- package/lib/cjs/overflowList/intersectionObserver.js +2 -21
- package/lib/cjs/pagination/index.d.ts +2 -2
- package/lib/cjs/pagination/index.js +7 -59
- package/lib/cjs/popconfirm/index.js +9 -54
- package/lib/cjs/popover/Arrow.js +6 -19
- package/lib/cjs/popover/index.js +11 -38
- package/lib/cjs/progress/index.js +8 -48
- package/lib/cjs/radio/context.d.ts +2 -2
- package/lib/cjs/radio/context.js +0 -4
- package/lib/cjs/radio/index.js +0 -5
- package/lib/cjs/radio/radio.d.ts +3 -3
- package/lib/cjs/radio/radio.js +1 -36
- package/lib/cjs/radio/radioGroup.d.ts +2 -2
- package/lib/cjs/radio/radioGroup.js +0 -24
- package/lib/cjs/radio/radioInner.d.ts +1 -1
- package/lib/cjs/radio/radioInner.js +0 -21
- package/lib/cjs/rating/index.js +4 -51
- package/lib/cjs/rating/item.d.ts +1 -1
- package/lib/cjs/rating/item.js +2 -27
- package/lib/cjs/resizeObserver/index.js +4 -28
- package/lib/cjs/scrollList/index.js +0 -13
- package/lib/cjs/scrollList/scrollItem.js +15 -113
- package/lib/cjs/select/index.d.ts +6 -6
- package/lib/cjs/select/index.js +27 -164
- package/lib/cjs/select/option.js +27 -55
- package/lib/cjs/select/optionGroup.js +0 -12
- package/lib/cjs/select/utils.js +8 -24
- package/lib/cjs/select/virtualRow.js +0 -2
- package/lib/cjs/sideSheet/SideSheetContent.js +2 -40
- package/lib/cjs/sideSheet/index.js +21 -66
- package/lib/cjs/skeleton/index.js +9 -28
- package/lib/cjs/skeleton/item.d.ts +2 -2
- package/lib/cjs/skeleton/item.js +8 -29
- package/lib/cjs/slider/index.js +7 -68
- package/lib/cjs/space/index.d.ts +3 -3
- package/lib/cjs/space/index.js +0 -20
- package/lib/cjs/space/utils.js +0 -9
- package/lib/cjs/spin/icon.js +4 -17
- package/lib/cjs/spin/index.d.ts +1 -1
- package/lib/cjs/spin/index.js +0 -20
- package/lib/cjs/steps/basicStep.d.ts +2 -2
- package/lib/cjs/steps/basicStep.js +0 -22
- package/lib/cjs/steps/basicSteps.d.ts +3 -3
- package/lib/cjs/steps/basicSteps.js +0 -15
- package/lib/cjs/steps/context.js +0 -4
- package/lib/cjs/steps/fillStep.d.ts +1 -1
- package/lib/cjs/steps/fillStep.js +0 -19
- package/lib/cjs/steps/fillSteps.d.ts +2 -2
- package/lib/cjs/steps/fillSteps.js +0 -17
- package/lib/cjs/steps/index.d.ts +1 -1
- package/lib/cjs/steps/index.js +4 -26
- package/lib/cjs/steps/navStep.js +0 -11
- package/lib/cjs/steps/navSteps.d.ts +1 -1
- package/lib/cjs/steps/navSteps.js +0 -13
- package/lib/cjs/steps/step.d.ts +1 -1
- package/lib/cjs/steps/step.js +0 -15
- package/lib/cjs/switch/index.js +1 -22
- package/lib/cjs/table/Body/BaseRow.d.ts +1 -1
- package/lib/cjs/table/Body/BaseRow.js +37 -101
- package/lib/cjs/table/Body/ExpandedRow.d.ts +1 -1
- package/lib/cjs/table/Body/ExpandedRow.js +5 -30
- package/lib/cjs/table/Body/SectionRow.js +8 -46
- package/lib/cjs/table/Body/index.js +38 -153
- package/lib/cjs/table/ColGroup.js +2 -14
- package/lib/cjs/table/Column.js +0 -7
- package/lib/cjs/table/ColumnFilter.js +4 -30
- package/lib/cjs/table/ColumnSelection.js +5 -24
- package/lib/cjs/table/ColumnShape.js +0 -4
- package/lib/cjs/table/ColumnSorter.js +0 -13
- package/lib/cjs/table/CustomExpandIcon.js +0 -16
- package/lib/cjs/table/HeadTable.js +0 -23
- package/lib/cjs/table/ResizableHeaderCell.d.ts +1 -1
- package/lib/cjs/table/ResizableHeaderCell.js +9 -20
- package/lib/cjs/table/ResizableTable.js +5 -47
- package/lib/cjs/table/Table.d.ts +2 -2
- package/lib/cjs/table/Table.js +534 -771
- package/lib/cjs/table/TableCell.js +20 -81
- package/lib/cjs/table/TableContextProvider.js +0 -7
- package/lib/cjs/table/TableHeader.js +5 -33
- package/lib/cjs/table/TableHeaderRow.js +8 -45
- package/lib/cjs/table/TablePagination.js +1 -12
- package/lib/cjs/table/getColumns.js +0 -11
- package/lib/cjs/table/index.js +2 -20
- package/lib/cjs/table/interface.d.ts +58 -58
- package/lib/cjs/table/table-context.js +1 -5
- package/lib/cjs/table/utils.js +6 -30
- package/lib/cjs/tabs/TabBar.js +13 -61
- package/lib/cjs/tabs/TabItem.js +18 -31
- package/lib/cjs/tabs/TabPane.js +10 -35
- package/lib/cjs/tabs/index.js +20 -83
- package/lib/cjs/tabs/interface.d.ts +3 -3
- package/lib/cjs/tabs/tabs-context.js +0 -4
- package/lib/cjs/tag/group.js +0 -27
- package/lib/cjs/tag/index.js +23 -60
- package/lib/cjs/tag/interface.d.ts +5 -5
- package/lib/cjs/tagInput/index.d.ts +3 -3
- package/lib/cjs/tagInput/index.js +2 -77
- package/lib/cjs/timePicker/Combobox.d.ts +2 -2
- package/lib/cjs/timePicker/Combobox.js +7 -54
- package/lib/cjs/timePicker/PanelShape.js +0 -3
- package/lib/cjs/timePicker/TimeInput.d.ts +1 -1
- package/lib/cjs/timePicker/TimeInput.js +32 -64
- package/lib/cjs/timePicker/TimePicker.d.ts +3 -3
- package/lib/cjs/timePicker/TimePicker.js +39 -99
- package/lib/cjs/timePicker/TimeShape.js +0 -5
- package/lib/cjs/timePicker/index.d.ts +1 -1
- package/lib/cjs/timePicker/index.js +0 -9
- package/lib/cjs/timeline/index.js +0 -27
- package/lib/cjs/timeline/item.js +0 -13
- package/lib/cjs/toast/index.js +5 -59
- package/lib/cjs/toast/toast.js +1 -29
- package/lib/cjs/toast/useToast/HookToast.js +3 -18
- package/lib/cjs/toast/useToast/index.js +2 -17
- package/lib/cjs/tooltip/ArrowBoundingShape.js +0 -4
- package/lib/cjs/tooltip/TriangleArrow.js +4 -12
- package/lib/cjs/tooltip/TriangleArrowVertical.js +4 -12
- package/lib/cjs/tooltip/index.d.ts +2 -2
- package/lib/cjs/tooltip/index.js +24 -134
- package/lib/cjs/transfer/index.d.ts +5 -5
- package/lib/cjs/transfer/index.js +10 -93
- package/lib/cjs/tree/autoSizer.js +4 -24
- package/lib/cjs/tree/index.js +31 -122
- package/lib/cjs/tree/interface.d.ts +2 -2
- package/lib/cjs/tree/nodeCollapsible.js +4 -15
- package/lib/cjs/tree/nodeList.js +0 -22
- package/lib/cjs/tree/treeContext.js +0 -4
- package/lib/cjs/tree/treeNode.js +21 -94
- package/lib/cjs/tree/treeUtil.js +0 -6
- package/lib/cjs/treeSelect/index.d.ts +6 -6
- package/lib/cjs/treeSelect/index.js +46 -196
- package/lib/cjs/trigger/index.js +5 -16
- package/lib/cjs/typography/base.js +35 -130
- package/lib/cjs/typography/copyable.js +2 -30
- package/lib/cjs/typography/index.d.ts +1 -1
- package/lib/cjs/typography/index.js +0 -9
- package/lib/cjs/typography/interface.d.ts +9 -9
- package/lib/cjs/typography/numeral.d.ts +1 -1
- package/lib/cjs/typography/numeral.js +4 -20
- package/lib/cjs/typography/paragraph.d.ts +1 -1
- package/lib/cjs/typography/paragraph.js +0 -12
- package/lib/cjs/typography/text.d.ts +1 -1
- package/lib/cjs/typography/text.js +0 -10
- package/lib/cjs/typography/title.d.ts +2 -2
- package/lib/cjs/typography/title.js +6 -20
- package/lib/cjs/typography/typography.js +7 -23
- package/lib/cjs/typography/util.js +22 -50
- package/lib/cjs/upload/fileCard.js +2 -52
- package/lib/cjs/upload/index.js +1 -70
- package/lib/cjs/upload/interface.d.ts +5 -5
- package/lib/es/_base/base.d.ts +3 -3
- package/lib/es/_base/baseComponent.d.ts +1 -1
- package/lib/es/_base/baseComponent.js +4 -11
- package/lib/es/_base/reactUtils.js +4 -8
- package/lib/es/_cssAnimation/index.js +4 -22
- package/lib/es/_portal/index.js +0 -23
- package/lib/es/_utils/hooks/usePrevFocus.js +0 -2
- package/lib/es/_utils/index.js +6 -28
- package/lib/es/anchor/anchor-context.d.ts +1 -1
- package/lib/es/anchor/index.js +2 -32
- package/lib/es/anchor/link.js +4 -24
- package/lib/es/autoComplete/index.d.ts +1 -1
- package/lib/es/autoComplete/index.js +3 -25
- package/lib/es/autoComplete/option.js +26 -45
- package/lib/es/avatar/avatarGroup.js +9 -28
- package/lib/es/avatar/index.js +15 -41
- package/lib/es/avatar/interface.d.ts +6 -6
- package/lib/es/backtop/index.js +9 -22
- package/lib/es/badge/index.d.ts +3 -3
- package/lib/es/badge/index.js +16 -24
- package/lib/es/banner/index.d.ts +1 -1
- package/lib/es/banner/index.js +2 -15
- package/lib/es/breadcrumb/index.d.ts +1 -1
- package/lib/es/breadcrumb/index.js +0 -31
- package/lib/es/breadcrumb/item.d.ts +1 -1
- package/lib/es/breadcrumb/item.js +16 -38
- package/lib/es/button/Button.d.ts +4 -4
- package/lib/es/button/Button.js +18 -27
- package/lib/es/button/buttonGroup.d.ts +1 -1
- package/lib/es/button/buttonGroup.js +10 -24
- package/lib/es/button/index.js +0 -5
- package/lib/es/button/splitButtonGroup.js +0 -1
- package/lib/es/calendar/dayCalendar.js +0 -13
- package/lib/es/calendar/dayCol.js +0 -14
- package/lib/es/calendar/index.js +6 -12
- package/lib/es/calendar/interface.d.ts +5 -5
- package/lib/es/calendar/monthCalendar.js +6 -41
- package/lib/es/calendar/rangeCalendar.js +2 -18
- package/lib/es/calendar/timeCol.js +0 -7
- package/lib/es/calendar/weekCalendar.js +0 -17
- package/lib/es/card/cardGroup.d.ts +1 -1
- package/lib/es/card/cardGroup.js +8 -15
- package/lib/es/card/index.d.ts +1 -1
- package/lib/es/card/index.js +7 -23
- package/lib/es/card/meta.d.ts +1 -1
- package/lib/es/card/meta.js +8 -15
- package/lib/es/carousel/CarouselArrow.d.ts +2 -2
- package/lib/es/carousel/CarouselArrow.js +0 -8
- package/lib/es/carousel/CarouselIndicator.js +9 -27
- package/lib/es/carousel/index.js +0 -34
- package/lib/es/cascader/index.d.ts +2 -2
- package/lib/es/cascader/index.js +12 -105
- package/lib/es/cascader/item.js +2 -44
- package/lib/es/checkbox/checkbox.d.ts +1 -1
- package/lib/es/checkbox/checkbox.js +20 -42
- package/lib/es/checkbox/checkboxGroup.d.ts +4 -4
- package/lib/es/checkbox/checkboxGroup.js +8 -20
- package/lib/es/checkbox/checkboxInner.js +0 -6
- package/lib/es/checkbox/context.d.ts +1 -1
- package/lib/es/checkbox/index.js +0 -2
- package/lib/es/collapse/index.js +14 -31
- package/lib/es/collapse/item.js +13 -27
- package/lib/es/collapsible/index.js +0 -25
- package/lib/es/configProvider/index.js +5 -13
- package/lib/es/datePicker/dateInput.js +41 -81
- package/lib/es/datePicker/datePicker.d.ts +1 -1
- package/lib/es/datePicker/datePicker.js +10 -103
- package/lib/es/datePicker/index.js +2 -8
- package/lib/es/datePicker/insetInput.js +0 -6
- package/lib/es/datePicker/month.d.ts +1 -1
- package/lib/es/datePicker/month.js +24 -78
- package/lib/es/datePicker/monthsGrid.d.ts +1 -1
- package/lib/es/datePicker/monthsGrid.js +20 -76
- package/lib/es/datePicker/navigation.js +8 -13
- package/lib/es/datePicker/quickControl.js +0 -6
- package/lib/es/datePicker/yearAndMonth.d.ts +1 -1
- package/lib/es/datePicker/yearAndMonth.js +5 -36
- package/lib/es/descriptions/descriptions-context.d.ts +1 -1
- package/lib/es/descriptions/index.d.ts +1 -1
- package/lib/es/descriptions/index.js +0 -3
- package/lib/es/descriptions/item.js +0 -3
- package/lib/es/divider/index.js +9 -17
- package/lib/es/dropdown/dropdownDivider.d.ts +1 -1
- package/lib/es/dropdown/dropdownDivider.js +0 -2
- package/lib/es/dropdown/dropdownItem.d.ts +1 -1
- package/lib/es/dropdown/dropdownItem.js +0 -11
- package/lib/es/dropdown/dropdownMenu.d.ts +1 -1
- package/lib/es/dropdown/dropdownMenu.js +6 -15
- package/lib/es/dropdown/dropdownTitle.d.ts +1 -1
- package/lib/es/dropdown/dropdownTitle.js +0 -3
- package/lib/es/dropdown/index.d.ts +1 -1
- package/lib/es/dropdown/index.js +21 -47
- package/lib/es/empty/index.js +0 -10
- package/lib/es/form/arrayField.js +14 -41
- package/lib/es/form/baseForm.js +26 -49
- package/lib/es/form/errorMessage.d.ts +1 -1
- package/lib/es/form/errorMessage.js +0 -9
- package/lib/es/form/field.js +4 -4
- package/lib/es/form/group.js +11 -29
- package/lib/es/form/hoc/withField.js +68 -125
- package/lib/es/form/hoc/withFormApi.js +0 -3
- package/lib/es/form/hoc/withFormState.js +0 -3
- package/lib/es/form/hooks/index.js +2 -2
- package/lib/es/form/hooks/useArrayFieldState.js +0 -2
- package/lib/es/form/hooks/useFieldApi.js +0 -3
- package/lib/es/form/hooks/useFieldState.js +0 -3
- package/lib/es/form/hooks/useFormState.js +0 -2
- package/lib/es/form/hooks/useStateWithGetter.js +2 -5
- package/lib/es/form/index.js +4 -4
- package/lib/es/form/interface.d.ts +4 -4
- package/lib/es/form/interface.js +0 -1
- package/lib/es/form/label.js +0 -1
- package/lib/es/form/section.js +0 -1
- package/lib/es/form/slot.js +10 -39
- package/lib/es/grid/col.js +10 -23
- package/lib/es/grid/row.d.ts +2 -2
- package/lib/es/grid/row.js +10 -25
- package/lib/es/highlight/index.js +0 -3
- package/lib/es/iconButton/index.d.ts +1 -1
- package/lib/es/iconButton/index.js +18 -31
- package/lib/es/image/image.d.ts +0 -3
- package/lib/es/image/image.js +19 -70
- package/lib/es/image/interface.d.ts +1 -1
- package/lib/es/image/preview.d.ts +4 -0
- package/lib/es/image/preview.js +51 -48
- package/lib/es/image/previewFooter.js +9 -34
- package/lib/es/image/previewHeader.js +0 -4
- package/lib/es/image/previewImage.js +46 -69
- package/lib/es/image/previewInner.js +69 -110
- package/lib/es/index.js +0 -1
- package/lib/es/input/index.d.ts +3 -3
- package/lib/es/input/index.js +35 -88
- package/lib/es/input/inputGroup.d.ts +1 -1
- package/lib/es/input/inputGroup.js +20 -33
- package/lib/es/input/textarea.d.ts +1 -1
- package/lib/es/input/textarea.js +34 -65
- package/lib/es/inputNumber/index.js +127 -181
- package/lib/es/layout/Sider.js +7 -23
- package/lib/es/layout/index.js +16 -31
- package/lib/es/list/index.js +0 -11
- package/lib/es/list/item.js +6 -18
- package/lib/es/locale/localeConsumer.d.ts +1 -1
- package/lib/es/locale/localeConsumer.js +0 -7
- package/lib/es/locale/localeProvider.js +0 -2
- package/lib/es/locale/source/ar.js +2 -2
- package/lib/es/locale/source/de.js +2 -2
- package/lib/es/locale/source/en_GB.js +2 -2
- package/lib/es/locale/source/en_US.js +2 -2
- package/lib/es/locale/source/es.js +0 -1
- package/lib/es/locale/source/fr.js +2 -2
- package/lib/es/locale/source/id_ID.js +2 -2
- package/lib/es/locale/source/it.js +2 -2
- package/lib/es/locale/source/ja_JP.js +2 -2
- package/lib/es/locale/source/ko_KR.js +2 -2
- package/lib/es/locale/source/ms_MY.js +2 -2
- package/lib/es/locale/source/nl_NL.js +0 -1
- package/lib/es/locale/source/pl_PL.js +0 -1
- package/lib/es/locale/source/pt_BR.js +2 -2
- package/lib/es/locale/source/ro.js +0 -1
- package/lib/es/locale/source/ru_RU.js +2 -2
- package/lib/es/locale/source/sv_SE.js +0 -1
- package/lib/es/locale/source/th_TH.js +2 -2
- package/lib/es/locale/source/tr_TR.js +2 -2
- package/lib/es/locale/source/vi_VN.js +2 -2
- package/lib/es/locale/source/zh_CN.js +2 -2
- package/lib/es/locale/source/zh_TW.js +2 -2
- package/lib/es/modal/ConfirmModal.js +9 -20
- package/lib/es/modal/Modal.d.ts +2 -2
- package/lib/es/modal/Modal.js +17 -63
- package/lib/es/modal/ModalContent.js +14 -54
- package/lib/es/modal/confirm.d.ts +9 -3
- package/lib/es/modal/confirm.js +4 -11
- package/lib/es/modal/index.d.ts +1 -1
- package/lib/es/modal/useModal/HookModal.js +6 -14
- package/lib/es/modal/useModal/index.d.ts +1 -1
- package/lib/es/modal/useModal/index.js +4 -9
- package/lib/es/navigation/CollapseButton.js +0 -4
- package/lib/es/navigation/Footer.js +0 -7
- package/lib/es/navigation/Header.d.ts +1 -1
- package/lib/es/navigation/Header.js +0 -5
- package/lib/es/navigation/Item.js +2 -35
- package/lib/es/navigation/SubNav.js +6 -45
- package/lib/es/navigation/index.d.ts +2 -2
- package/lib/es/navigation/index.js +5 -38
- package/lib/es/notification/index.d.ts +1 -1
- package/lib/es/notification/index.js +4 -39
- package/lib/es/notification/notice.js +24 -46
- package/lib/es/notification/useNotification/HookNotice.js +3 -11
- package/lib/es/notification/useNotification/index.js +6 -16
- package/lib/es/overflowList/index.d.ts +41 -24
- package/lib/es/overflowList/index.js +6 -46
- package/lib/es/overflowList/intersectionObserver.js +2 -13
- package/lib/es/pagination/index.d.ts +2 -2
- package/lib/es/pagination/index.js +7 -37
- package/lib/es/popconfirm/index.js +9 -37
- package/lib/es/popover/Arrow.js +6 -18
- package/lib/es/popover/index.js +11 -27
- package/lib/es/progress/index.js +8 -37
- package/lib/es/radio/context.d.ts +2 -2
- package/lib/es/radio/index.js +0 -2
- package/lib/es/radio/radio.d.ts +3 -3
- package/lib/es/radio/radio.js +0 -23
- package/lib/es/radio/radioGroup.d.ts +2 -2
- package/lib/es/radio/radioGroup.js +0 -14
- package/lib/es/radio/radioInner.d.ts +1 -1
- package/lib/es/radio/radioInner.js +0 -11
- package/lib/es/rating/index.js +4 -36
- package/lib/es/rating/item.d.ts +1 -1
- package/lib/es/rating/item.js +2 -16
- package/lib/es/resizeObserver/index.js +4 -19
- package/lib/es/scrollList/index.js +2 -5
- package/lib/es/scrollList/scrollItem.js +15 -104
- package/lib/es/select/index.d.ts +6 -6
- package/lib/es/select/index.js +27 -123
- package/lib/es/select/option.js +27 -46
- package/lib/es/select/optionGroup.js +0 -5
- package/lib/es/select/utils.js +8 -19
- package/lib/es/select/virtualRow.js +0 -1
- package/lib/es/sideSheet/SideSheetContent.js +2 -28
- package/lib/es/sideSheet/index.js +21 -52
- package/lib/es/skeleton/index.js +9 -18
- package/lib/es/skeleton/item.d.ts +2 -2
- package/lib/es/skeleton/item.js +8 -17
- package/lib/es/slider/index.js +6 -53
- package/lib/es/space/index.d.ts +3 -3
- package/lib/es/space/index.js +0 -6
- package/lib/es/space/utils.js +0 -2
- package/lib/es/spin/icon.js +4 -15
- package/lib/es/spin/index.d.ts +1 -1
- package/lib/es/spin/index.js +0 -10
- package/lib/es/steps/basicStep.d.ts +2 -2
- package/lib/es/steps/basicStep.js +0 -15
- package/lib/es/steps/basicSteps.d.ts +3 -3
- package/lib/es/steps/basicSteps.js +0 -6
- package/lib/es/steps/fillStep.d.ts +1 -1
- package/lib/es/steps/fillStep.js +0 -13
- package/lib/es/steps/fillSteps.d.ts +2 -2
- package/lib/es/steps/fillSteps.js +0 -6
- package/lib/es/steps/index.d.ts +1 -1
- package/lib/es/steps/index.js +4 -15
- package/lib/es/steps/navStep.js +0 -5
- package/lib/es/steps/navSteps.d.ts +1 -1
- package/lib/es/steps/navSteps.js +0 -3
- package/lib/es/steps/step.d.ts +1 -1
- package/lib/es/steps/step.js +0 -7
- package/lib/es/switch/index.js +0 -13
- package/lib/es/table/Body/BaseRow.d.ts +1 -1
- package/lib/es/table/Body/BaseRow.js +37 -85
- package/lib/es/table/Body/ExpandedRow.d.ts +1 -1
- package/lib/es/table/Body/ExpandedRow.js +5 -18
- package/lib/es/table/Body/SectionRow.js +8 -35
- package/lib/es/table/Body/index.js +38 -149
- package/lib/es/table/ColGroup.js +2 -7
- package/lib/es/table/Column.js +0 -2
- package/lib/es/table/ColumnFilter.js +3 -20
- package/lib/es/table/ColumnSelection.js +5 -15
- package/lib/es/table/ColumnSorter.js +0 -1
- package/lib/es/table/CustomExpandIcon.js +0 -6
- package/lib/es/table/HeadTable.js +0 -15
- package/lib/es/table/ResizableHeaderCell.d.ts +1 -1
- package/lib/es/table/ResizableHeaderCell.js +9 -17
- package/lib/es/table/ResizableTable.js +5 -37
- package/lib/es/table/Table.d.ts +2 -2
- package/lib/es/table/Table.js +457 -664
- package/lib/es/table/TableCell.js +19 -65
- package/lib/es/table/TableContextProvider.js +0 -2
- package/lib/es/table/TableHeader.js +4 -23
- package/lib/es/table/TableHeaderRow.js +8 -39
- package/lib/es/table/TablePagination.js +0 -4
- package/lib/es/table/getColumns.js +0 -4
- package/lib/es/table/index.js +2 -10
- package/lib/es/table/interface.d.ts +58 -58
- package/lib/es/table/table-context.js +0 -1
- package/lib/es/table/utils.js +6 -19
- package/lib/es/tabs/TabBar.js +13 -46
- package/lib/es/tabs/TabItem.js +18 -24
- package/lib/es/tabs/TabPane.js +10 -25
- package/lib/es/tabs/index.js +20 -59
- package/lib/es/tabs/interface.d.ts +3 -3
- package/lib/es/tag/group.js +0 -14
- package/lib/es/tag/index.js +23 -45
- package/lib/es/tag/interface.d.ts +5 -5
- package/lib/es/tagInput/index.d.ts +3 -3
- package/lib/es/tagInput/index.js +2 -54
- package/lib/es/timePicker/Combobox.d.ts +2 -2
- package/lib/es/timePicker/Combobox.js +6 -42
- package/lib/es/timePicker/TimeInput.d.ts +1 -1
- package/lib/es/timePicker/TimeInput.js +32 -56
- package/lib/es/timePicker/TimePicker.d.ts +3 -3
- package/lib/es/timePicker/TimePicker.js +39 -80
- package/lib/es/timePicker/TimeShape.js +0 -1
- package/lib/es/timePicker/index.d.ts +1 -1
- package/lib/es/timePicker/index.js +0 -1
- package/lib/es/timeline/index.js +0 -16
- package/lib/es/timeline/item.js +0 -1
- package/lib/es/toast/index.js +4 -41
- package/lib/es/toast/toast.js +0 -17
- package/lib/es/toast/useToast/HookToast.js +3 -11
- package/lib/es/toast/useToast/index.js +4 -13
- package/lib/es/tooltip/TriangleArrow.js +4 -10
- package/lib/es/tooltip/TriangleArrowVertical.js +4 -10
- package/lib/es/tooltip/index.d.ts +2 -2
- package/lib/es/tooltip/index.js +24 -112
- package/lib/es/transfer/index.d.ts +5 -5
- package/lib/es/transfer/index.js +10 -67
- package/lib/es/tree/autoSizer.js +4 -13
- package/lib/es/tree/index.js +30 -96
- package/lib/es/tree/interface.d.ts +2 -2
- package/lib/es/tree/nodeCollapsible.js +4 -10
- package/lib/es/tree/nodeList.js +0 -14
- package/lib/es/tree/treeNode.js +21 -76
- package/lib/es/tree/treeUtil.js +0 -1
- package/lib/es/treeSelect/index.d.ts +6 -6
- package/lib/es/treeSelect/index.js +46 -156
- package/lib/es/trigger/index.js +5 -13
- package/lib/es/typography/base.js +35 -113
- package/lib/es/typography/copyable.js +2 -14
- package/lib/es/typography/index.d.ts +1 -1
- package/lib/es/typography/interface.d.ts +9 -9
- package/lib/es/typography/numeral.d.ts +1 -1
- package/lib/es/typography/numeral.js +4 -10
- package/lib/es/typography/paragraph.d.ts +1 -1
- package/lib/es/typography/paragraph.js +0 -1
- package/lib/es/typography/text.d.ts +1 -1
- package/lib/es/typography/text.js +0 -1
- package/lib/es/typography/title.d.ts +2 -2
- package/lib/es/typography/title.js +6 -11
- package/lib/es/typography/typography.js +7 -14
- package/lib/es/typography/util.js +22 -45
- package/lib/es/upload/fileCard.js +2 -31
- package/lib/es/upload/index.js +0 -57
- package/lib/es/upload/interface.d.ts +5 -5
- package/package.json +8 -8
package/lib/es/tree/index.js
CHANGED
|
@@ -2,7 +2,6 @@ import _isFunction from "lodash/isFunction";
|
|
|
2
2
|
import _get from "lodash/get";
|
|
3
3
|
import _isEqual from "lodash/isEqual";
|
|
4
4
|
import _isEmpty from "lodash/isEmpty";
|
|
5
|
-
|
|
6
5
|
/* eslint-disable max-lines-per-function */
|
|
7
6
|
import React from 'react';
|
|
8
7
|
import cls from 'classnames';
|
|
@@ -25,18 +24,14 @@ import { IconSearch } from '@douyinfe/semi-icons';
|
|
|
25
24
|
import CheckboxGroup from '../checkbox/checkboxGroup';
|
|
26
25
|
export * from './interface';
|
|
27
26
|
const prefixcls = cssClasses.PREFIX;
|
|
28
|
-
|
|
29
27
|
class Tree extends BaseComponent {
|
|
30
28
|
constructor(props) {
|
|
31
29
|
super(props);
|
|
32
|
-
|
|
33
30
|
this.search = value => {
|
|
34
31
|
this.foundation.handleInputChange(value);
|
|
35
32
|
};
|
|
36
|
-
|
|
37
33
|
this.scrollTo = scrollData => {
|
|
38
34
|
var _a;
|
|
39
|
-
|
|
40
35
|
const {
|
|
41
36
|
key,
|
|
42
37
|
align = 'center'
|
|
@@ -44,7 +39,6 @@ class Tree extends BaseComponent {
|
|
|
44
39
|
const {
|
|
45
40
|
flattenNodes
|
|
46
41
|
} = this.state;
|
|
47
|
-
|
|
48
42
|
if (key) {
|
|
49
43
|
const index = flattenNodes === null || flattenNodes === void 0 ? void 0 : flattenNodes.findIndex(node => {
|
|
50
44
|
return node.key === key;
|
|
@@ -52,12 +46,10 @@ class Tree extends BaseComponent {
|
|
|
52
46
|
index >= 0 && ((_a = this.virtualizedListRef.current) === null || _a === void 0 ? void 0 : _a.scrollToItem(index, align));
|
|
53
47
|
}
|
|
54
48
|
};
|
|
55
|
-
|
|
56
49
|
this.renderEmpty = () => {
|
|
57
50
|
const {
|
|
58
51
|
emptyContent
|
|
59
52
|
} = this.props;
|
|
60
|
-
|
|
61
53
|
if (emptyContent) {
|
|
62
54
|
return /*#__PURE__*/React.createElement(TreeNode, {
|
|
63
55
|
empty: true,
|
|
@@ -72,11 +64,9 @@ class Tree extends BaseComponent {
|
|
|
72
64
|
}));
|
|
73
65
|
}
|
|
74
66
|
};
|
|
75
|
-
|
|
76
67
|
this.onNodeSelect = (e, treeNode) => {
|
|
77
68
|
this.foundation.handleNodeSelect(e, treeNode);
|
|
78
69
|
};
|
|
79
|
-
|
|
80
70
|
this.onNodeLoad = data => new Promise(resolve => {
|
|
81
71
|
// We need to get the latest state of loading/loaded keys
|
|
82
72
|
this.setState(_ref => {
|
|
@@ -87,47 +77,36 @@ class Tree extends BaseComponent {
|
|
|
87
77
|
return this.foundation.handleNodeLoad(loadedKeys, loadingKeys, data, resolve);
|
|
88
78
|
});
|
|
89
79
|
});
|
|
90
|
-
|
|
91
80
|
this.onNodeCheck = (e, treeNode) => {
|
|
92
81
|
this.foundation.handleNodeSelect(e, treeNode);
|
|
93
82
|
};
|
|
94
|
-
|
|
95
83
|
this.onNodeExpand = (e, treeNode) => {
|
|
96
84
|
this.foundation.handleNodeExpand(e, treeNode);
|
|
97
85
|
};
|
|
98
|
-
|
|
99
86
|
this.onNodeRightClick = (e, treeNode) => {
|
|
100
87
|
this.foundation.handleNodeRightClick(e, treeNode);
|
|
101
88
|
};
|
|
102
|
-
|
|
103
89
|
this.onNodeDoubleClick = (e, treeNode) => {
|
|
104
90
|
this.foundation.handleNodeDoubleClick(e, treeNode);
|
|
105
91
|
};
|
|
106
|
-
|
|
107
92
|
this.onNodeDragStart = (e, treeNode) => {
|
|
108
93
|
this.foundation.handleNodeDragStart(e, treeNode);
|
|
109
94
|
};
|
|
110
|
-
|
|
111
95
|
this.onNodeDragEnter = (e, treeNode) => {
|
|
112
96
|
this.foundation.handleNodeDragEnter(e, treeNode, this.dragNode);
|
|
113
97
|
};
|
|
114
|
-
|
|
115
98
|
this.onNodeDragOver = (e, treeNode) => {
|
|
116
99
|
this.foundation.handleNodeDragOver(e, treeNode, this.dragNode);
|
|
117
100
|
};
|
|
118
|
-
|
|
119
101
|
this.onNodeDragLeave = (e, treeNode) => {
|
|
120
102
|
this.foundation.handleNodeDragLeave(e, treeNode);
|
|
121
103
|
};
|
|
122
|
-
|
|
123
104
|
this.onNodeDragEnd = (e, treeNode) => {
|
|
124
105
|
this.foundation.handleNodeDragEnd(e, treeNode);
|
|
125
106
|
};
|
|
126
|
-
|
|
127
107
|
this.onNodeDrop = (e, treeNode) => {
|
|
128
108
|
this.foundation.handleNodeDrop(e, treeNode, this.dragNode);
|
|
129
109
|
};
|
|
130
|
-
|
|
131
110
|
this.getTreeNodeRequiredProps = () => {
|
|
132
111
|
const {
|
|
133
112
|
expandedKeys,
|
|
@@ -146,7 +125,6 @@ class Tree extends BaseComponent {
|
|
|
146
125
|
keyEntities
|
|
147
126
|
};
|
|
148
127
|
};
|
|
149
|
-
|
|
150
128
|
this.getTreeNodeKey = treeNode => {
|
|
151
129
|
const {
|
|
152
130
|
data
|
|
@@ -156,7 +134,6 @@ class Tree extends BaseComponent {
|
|
|
156
134
|
} = data;
|
|
157
135
|
return key;
|
|
158
136
|
};
|
|
159
|
-
|
|
160
137
|
this.renderTreeNode = (treeNode, ind, style) => {
|
|
161
138
|
const {
|
|
162
139
|
data
|
|
@@ -165,25 +142,21 @@ class Tree extends BaseComponent {
|
|
|
165
142
|
key
|
|
166
143
|
} = data;
|
|
167
144
|
const treeNodeProps = this.foundation.getTreeNodeProps(key);
|
|
168
|
-
|
|
169
145
|
if (!treeNodeProps) {
|
|
170
146
|
return null;
|
|
171
147
|
}
|
|
172
|
-
|
|
173
148
|
return /*#__PURE__*/React.createElement(TreeNode, Object.assign({}, treeNodeProps, data, {
|
|
174
149
|
key: key,
|
|
175
150
|
data: data,
|
|
176
151
|
style: _isEmpty(style) ? {} : style
|
|
177
152
|
}));
|
|
178
153
|
};
|
|
179
|
-
|
|
180
154
|
this.itemKey = (index, data) => {
|
|
181
155
|
// Find the item at the specified index.
|
|
182
|
-
const item = data[index];
|
|
183
|
-
|
|
156
|
+
const item = data[index];
|
|
157
|
+
// Return a value that uniquely identifies this item.
|
|
184
158
|
return item.key;
|
|
185
159
|
};
|
|
186
|
-
|
|
187
160
|
this.state = {
|
|
188
161
|
inputValue: '',
|
|
189
162
|
keyEntities: {},
|
|
@@ -220,11 +193,8 @@ class Tree extends BaseComponent {
|
|
|
220
193
|
* Process of getDerivedStateFromProps was inspired by rc-tree
|
|
221
194
|
* https://github.com/react-component/tree
|
|
222
195
|
*/
|
|
223
|
-
|
|
224
|
-
|
|
225
196
|
static getDerivedStateFromProps(props, prevState) {
|
|
226
197
|
var _a;
|
|
227
|
-
|
|
228
198
|
const {
|
|
229
199
|
prevProps
|
|
230
200
|
} = prevState;
|
|
@@ -235,22 +205,20 @@ class Tree extends BaseComponent {
|
|
|
235
205
|
const newState = {
|
|
236
206
|
prevProps: props
|
|
237
207
|
};
|
|
238
|
-
const isExpandControlled = ('expandedKeys' in props);
|
|
239
|
-
|
|
208
|
+
const isExpandControlled = ('expandedKeys' in props);
|
|
209
|
+
// Accept a props field as a parameter to determine whether to update the field
|
|
240
210
|
const needUpdate = name => {
|
|
241
211
|
const firstInProps = !prevProps && name in props;
|
|
242
212
|
const nameHasChange = prevProps && !_isEqual(prevProps[name], props[name]);
|
|
243
213
|
return firstInProps || nameHasChange;
|
|
244
|
-
};
|
|
245
|
-
|
|
246
|
-
|
|
214
|
+
};
|
|
215
|
+
// Determine whether treeData has changed
|
|
247
216
|
const needUpdateData = () => {
|
|
248
217
|
const firstInProps = !prevProps && 'treeData' in props;
|
|
249
218
|
const treeDataHasChange = prevProps && prevProps.treeData !== props.treeData;
|
|
250
219
|
return firstInProps || treeDataHasChange;
|
|
251
|
-
};
|
|
252
|
-
|
|
253
|
-
|
|
220
|
+
};
|
|
221
|
+
// Update the data of tree in state
|
|
254
222
|
if (needUpdate('treeData') || props.draggable && needUpdateData()) {
|
|
255
223
|
// eslint-disable-next-line prefer-destructuring
|
|
256
224
|
treeData = props.treeData;
|
|
@@ -269,24 +237,21 @@ class Tree extends BaseComponent {
|
|
|
269
237
|
keyEntities = newState.keyEntities;
|
|
270
238
|
newState.cachedKeyValuePairs = Object.assign({}, entitiesMap.valueEntities);
|
|
271
239
|
valueEntities = newState.cachedKeyValuePairs;
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
|
|
240
|
+
}
|
|
241
|
+
// If treeData keys changes, we won't show animation
|
|
275
242
|
if (treeData && props.motion) {
|
|
276
243
|
if (prevProps && props.motion) {
|
|
277
244
|
newState.motionKeys = new Set([]);
|
|
278
245
|
newState.motionType = null;
|
|
279
246
|
}
|
|
280
247
|
}
|
|
281
|
-
|
|
282
248
|
const dataUpdated = needUpdate('treeDataSimpleJson') || needUpdate('treeData');
|
|
283
249
|
const expandAllWhenDataChange = dataUpdated && props.expandAll;
|
|
284
|
-
|
|
285
250
|
if (!isSeaching) {
|
|
286
251
|
// Update expandedKeys
|
|
287
252
|
if (needUpdate('expandedKeys') || prevProps && needUpdate('autoExpandParent')) {
|
|
288
|
-
newState.expandedKeys = calcExpandedKeys(props.expandedKeys, keyEntities, props.autoExpandParent || !prevProps);
|
|
289
|
-
|
|
253
|
+
newState.expandedKeys = calcExpandedKeys(props.expandedKeys, keyEntities, props.autoExpandParent || !prevProps);
|
|
254
|
+
// only show animation when treeData does not change
|
|
290
255
|
if (prevProps && props.motion && !treeData) {
|
|
291
256
|
const {
|
|
292
257
|
motionKeys,
|
|
@@ -294,7 +259,6 @@ class Tree extends BaseComponent {
|
|
|
294
259
|
} = calcMotionKeys(prevState.expandedKeys, newState.expandedKeys, keyEntities);
|
|
295
260
|
newState.motionKeys = new Set(motionKeys);
|
|
296
261
|
newState.motionType = motionType;
|
|
297
|
-
|
|
298
262
|
if (motionType === 'hide') {
|
|
299
263
|
// cache flatten nodes: expandedKeys changed may not be triggered by interaction
|
|
300
264
|
newState.cachedFlattenNodes = cloneDeep(prevState.flattenNodes);
|
|
@@ -319,19 +283,17 @@ class Tree extends BaseComponent {
|
|
|
319
283
|
newState.expandedKeys = calcExpandedKeysForValues(props.value, keyEntities, props.multiple, valueEntities);
|
|
320
284
|
}
|
|
321
285
|
}
|
|
322
|
-
|
|
323
286
|
if (!newState.expandedKeys) {
|
|
324
287
|
delete newState.expandedKeys;
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
|
|
288
|
+
}
|
|
289
|
+
// Update flattenNodes
|
|
328
290
|
if (treeData || newState.expandedKeys) {
|
|
329
291
|
const flattenNodes = flattenTreeData(treeData || prevState.treeData, newState.expandedKeys || prevState.expandedKeys);
|
|
330
292
|
newState.flattenNodes = flattenNodes;
|
|
331
293
|
}
|
|
332
294
|
} else {
|
|
333
|
-
let filteredState;
|
|
334
|
-
|
|
295
|
+
let filteredState;
|
|
296
|
+
// treeData changed while searching
|
|
335
297
|
if (treeData) {
|
|
336
298
|
// Get filter data
|
|
337
299
|
filteredState = filterTreeData({
|
|
@@ -348,15 +310,13 @@ class Tree extends BaseComponent {
|
|
|
348
310
|
newState.filteredKeys = filteredState.filteredKeys;
|
|
349
311
|
newState.filteredShownKeys = filteredState.filteredShownKeys;
|
|
350
312
|
newState.filteredExpandedKeys = filteredState.filteredExpandedKeys;
|
|
351
|
-
}
|
|
352
|
-
|
|
353
|
-
|
|
313
|
+
}
|
|
314
|
+
// expandedKeys changed while searching
|
|
354
315
|
if (props.expandedKeys) {
|
|
355
316
|
newState.filteredExpandedKeys = calcExpandedKeys(props.expandedKeys, keyEntities, props.autoExpandParent || !prevProps);
|
|
356
|
-
|
|
357
317
|
if (prevProps && props.motion) {
|
|
358
|
-
const prevKeys = prevState ? prevState.filteredExpandedKeys : new Set([]);
|
|
359
|
-
|
|
318
|
+
const prevKeys = prevState ? prevState.filteredExpandedKeys : new Set([]);
|
|
319
|
+
// only show animation when treeData does not change
|
|
360
320
|
if (!treeData) {
|
|
361
321
|
const motionResult = calcMotionKeys(prevKeys, newState.filteredExpandedKeys, keyEntities);
|
|
362
322
|
let {
|
|
@@ -365,33 +325,28 @@ class Tree extends BaseComponent {
|
|
|
365
325
|
const {
|
|
366
326
|
motionType
|
|
367
327
|
} = motionResult;
|
|
368
|
-
|
|
369
328
|
if (props.showFilteredOnly) {
|
|
370
329
|
motionKeys = motionKeys.filter(key => prevState.filteredShownKeys.has(key));
|
|
371
330
|
}
|
|
372
|
-
|
|
373
331
|
if (motionType === 'hide') {
|
|
374
332
|
// cache flatten nodes: expandedKeys changed may not be triggered by interaction
|
|
375
333
|
newState.cachedFlattenNodes = cloneDeep(prevState.flattenNodes);
|
|
376
334
|
}
|
|
377
|
-
|
|
378
335
|
newState.motionKeys = new Set(motionKeys);
|
|
379
336
|
newState.motionType = motionType;
|
|
380
337
|
}
|
|
381
338
|
}
|
|
382
|
-
|
|
383
339
|
newState.flattenNodes = flattenTreeData(treeData || prevState.treeData, newState.filteredExpandedKeys || prevState.filteredExpandedKeys, props.showFilteredOnly && prevState.filteredShownKeys);
|
|
384
340
|
}
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
|
|
341
|
+
}
|
|
342
|
+
// Handle single selection and multiple selection in controlled mode
|
|
388
343
|
const withObject = props.onChangeWithObject;
|
|
389
344
|
const isMultiple = props.multiple;
|
|
390
|
-
|
|
391
345
|
if (!isMultiple) {
|
|
392
346
|
// When getting single selection, the selected node
|
|
393
347
|
if (needUpdate('value')) {
|
|
394
|
-
newState.selectedKeys = findKeysForValues(
|
|
348
|
+
newState.selectedKeys = findKeysForValues(
|
|
349
|
+
// In both cases whether withObject is turned on, the value is standardized to string
|
|
395
350
|
normalizeValue(props.value, withObject), valueEntities, isMultiple);
|
|
396
351
|
} else if (!prevProps && props.defaultValue) {
|
|
397
352
|
newState.selectedKeys = findKeysForValues(normalizeValue(props.defaultValue, withObject), valueEntities, isMultiple);
|
|
@@ -402,8 +357,8 @@ class Tree extends BaseComponent {
|
|
|
402
357
|
}
|
|
403
358
|
}
|
|
404
359
|
} else {
|
|
405
|
-
let checkedKeyValues;
|
|
406
|
-
|
|
360
|
+
let checkedKeyValues;
|
|
361
|
+
// Get the selected node during multiple selection
|
|
407
362
|
if (needUpdate('value')) {
|
|
408
363
|
checkedKeyValues = findKeysForValues(normalizeValue(props.value, withObject), valueEntities, isMultiple);
|
|
409
364
|
} else if (!prevProps && props.defaultValue) {
|
|
@@ -416,7 +371,6 @@ class Tree extends BaseComponent {
|
|
|
416
371
|
checkedKeyValues = updateKeys(prevState.checkedKeys, keyEntities);
|
|
417
372
|
}
|
|
418
373
|
}
|
|
419
|
-
|
|
420
374
|
if (checkedKeyValues) {
|
|
421
375
|
if (props.checkRelation === 'unRelated') {
|
|
422
376
|
newState.realCheckedKeys = new Set(checkedKeyValues);
|
|
@@ -429,21 +383,17 @@ class Tree extends BaseComponent {
|
|
|
429
383
|
newState.halfCheckedKeys = halfCheckedKeys;
|
|
430
384
|
}
|
|
431
385
|
}
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
|
|
386
|
+
}
|
|
387
|
+
// update loadedKeys
|
|
435
388
|
if (needUpdate('loadedKeys')) {
|
|
436
389
|
newState.loadedKeys = new Set(props.loadedKeys);
|
|
437
|
-
}
|
|
438
|
-
|
|
439
|
-
|
|
390
|
+
}
|
|
391
|
+
// update disableStrictly
|
|
440
392
|
if (treeData && props.disableStrictly && props.checkRelation === 'related') {
|
|
441
393
|
newState.disabledKeys = calcDisabledKeys(keyEntities);
|
|
442
394
|
}
|
|
443
|
-
|
|
444
395
|
return newState;
|
|
445
396
|
}
|
|
446
|
-
|
|
447
397
|
get adapter() {
|
|
448
398
|
const filterAdapter = {
|
|
449
399
|
updateInputValue: value => {
|
|
@@ -455,7 +405,6 @@ class Tree extends BaseComponent {
|
|
|
455
405
|
const {
|
|
456
406
|
preventScroll
|
|
457
407
|
} = this.props;
|
|
458
|
-
|
|
459
408
|
if (this.inputRef && this.inputRef.current) {
|
|
460
409
|
this.inputRef.current.focus({
|
|
461
410
|
preventScroll
|
|
@@ -476,7 +425,6 @@ class Tree extends BaseComponent {
|
|
|
476
425
|
expanded: bool,
|
|
477
426
|
node
|
|
478
427
|
});
|
|
479
|
-
|
|
480
428
|
if (bool && this.props.loadData) {
|
|
481
429
|
this.onNodeLoad(node);
|
|
482
430
|
}
|
|
@@ -506,7 +454,6 @@ class Tree extends BaseComponent {
|
|
|
506
454
|
}
|
|
507
455
|
});
|
|
508
456
|
}
|
|
509
|
-
|
|
510
457
|
renderInput() {
|
|
511
458
|
const {
|
|
512
459
|
searchClassName,
|
|
@@ -535,22 +482,18 @@ class Tree extends BaseComponent {
|
|
|
535
482
|
componentName: "Tree"
|
|
536
483
|
}, locale => {
|
|
537
484
|
inputProps.placeholder = searchPlaceholder || _get(locale, 'searchPlaceholder');
|
|
538
|
-
|
|
539
485
|
if (_isFunction(searchRender)) {
|
|
540
486
|
return searchRender(Object.assign({}, inputProps));
|
|
541
487
|
}
|
|
542
|
-
|
|
543
488
|
if (searchRender === false) {
|
|
544
489
|
return null;
|
|
545
490
|
}
|
|
546
|
-
|
|
547
491
|
return /*#__PURE__*/React.createElement(Input, Object.assign({
|
|
548
492
|
"aria-label": 'Filter Tree',
|
|
549
493
|
ref: this.inputRef
|
|
550
494
|
}, inputProps));
|
|
551
495
|
}));
|
|
552
496
|
}
|
|
553
|
-
|
|
554
497
|
renderNodeList() {
|
|
555
498
|
const {
|
|
556
499
|
flattenNodes,
|
|
@@ -565,11 +508,9 @@ class Tree extends BaseComponent {
|
|
|
565
508
|
const {
|
|
566
509
|
direction
|
|
567
510
|
} = this.context;
|
|
568
|
-
|
|
569
511
|
if (_isEmpty(flattenNodes)) {
|
|
570
512
|
return undefined;
|
|
571
513
|
}
|
|
572
|
-
|
|
573
514
|
if (!virtualize || _isEmpty(virtualize)) {
|
|
574
515
|
return /*#__PURE__*/React.createElement(NodeList, {
|
|
575
516
|
flattenNodes: flattenNodes,
|
|
@@ -580,7 +521,6 @@ class Tree extends BaseComponent {
|
|
|
580
521
|
renderTreeNode: this.renderTreeNode
|
|
581
522
|
});
|
|
582
523
|
}
|
|
583
|
-
|
|
584
524
|
const option = _ref3 => {
|
|
585
525
|
let {
|
|
586
526
|
index,
|
|
@@ -589,7 +529,6 @@ class Tree extends BaseComponent {
|
|
|
589
529
|
} = _ref3;
|
|
590
530
|
return this.renderTreeNode(data[index], index, style);
|
|
591
531
|
};
|
|
592
|
-
|
|
593
532
|
return /*#__PURE__*/React.createElement(AutoSizer, {
|
|
594
533
|
defaultHeight: virtualize.height,
|
|
595
534
|
defaultWidth: virtualize.width
|
|
@@ -613,7 +552,6 @@ class Tree extends BaseComponent {
|
|
|
613
552
|
}, option);
|
|
614
553
|
});
|
|
615
554
|
}
|
|
616
|
-
|
|
617
555
|
render() {
|
|
618
556
|
const {
|
|
619
557
|
keyEntities,
|
|
@@ -655,11 +593,9 @@ class Tree extends BaseComponent {
|
|
|
655
593
|
const ariaAttr = {
|
|
656
594
|
role: noData ? 'none' : 'tree'
|
|
657
595
|
};
|
|
658
|
-
|
|
659
596
|
if (ariaAttr.role === 'tree') {
|
|
660
597
|
ariaAttr['aria-multiselectable'] = multiple ? true : false;
|
|
661
598
|
}
|
|
662
|
-
|
|
663
599
|
return /*#__PURE__*/React.createElement(TreeContext.Provider, {
|
|
664
600
|
value: {
|
|
665
601
|
treeDisabled: disabled,
|
|
@@ -706,9 +642,7 @@ class Tree extends BaseComponent {
|
|
|
706
642
|
value: Array.from(checkRelation === 'related' ? checkedKeys : realCheckedKeys)
|
|
707
643
|
}, this.renderNodeList()) : this.renderNodeList())));
|
|
708
644
|
}
|
|
709
|
-
|
|
710
645
|
}
|
|
711
|
-
|
|
712
646
|
Tree.contextType = ConfigContext;
|
|
713
647
|
Tree.propTypes = {
|
|
714
648
|
blockNode: PropTypes.bool,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React, { ReactNode, MouseEvent } from 'react';
|
|
2
2
|
import { BasicTreeProps, BasicExpandedOtherProps, BasicRenderFullLabelProps, BasicSearchRenderProps, BasicTreeInnerData, BasicKeyEntities, BasicKeyEntity, BasicTreeNodeProps, BasicFlattenNode, BasicTreeNodeData, BasicOnDragProps } from '@douyinfe/semi-foundation/lib/es/tree/foundation';
|
|
3
|
-
export
|
|
3
|
+
export type Value = string | number | TreeNodeData | Array<TreeNodeData | number | string>;
|
|
4
4
|
export interface DragTreeNode extends TreeNodeData {
|
|
5
5
|
expanded: boolean;
|
|
6
6
|
/**
|
|
@@ -113,7 +113,7 @@ export interface NodeListProps {
|
|
|
113
113
|
searchTargetIsDeep?: boolean;
|
|
114
114
|
renderTreeNode: (treeNode: FlattenNode, ind?: number, style?: React.CSSProperties) => ReactNode;
|
|
115
115
|
}
|
|
116
|
-
export
|
|
116
|
+
export type TransitionNodes<T> = Array<T | Array<T>>;
|
|
117
117
|
export interface NodeListState {
|
|
118
118
|
transitionNodes: TransitionNodes<FlattenNode>;
|
|
119
119
|
cachedMotionKeys?: Set<string>;
|
|
@@ -1,24 +1,19 @@
|
|
|
1
1
|
var __rest = this && this.__rest || function (s, e) {
|
|
2
2
|
var t = {};
|
|
3
|
-
|
|
4
3
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
5
|
-
|
|
6
4
|
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
5
|
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
8
6
|
}
|
|
9
7
|
return t;
|
|
10
8
|
};
|
|
11
|
-
|
|
12
9
|
import React, { useState, useEffect } from 'react';
|
|
13
10
|
import Collapsible from '../collapsible';
|
|
14
|
-
|
|
15
11
|
function NodeCollapsible(props) {
|
|
16
12
|
const {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
13
|
+
open,
|
|
14
|
+
children
|
|
15
|
+
} = props,
|
|
16
|
+
rest = __rest(props, ["open", "children"]);
|
|
22
17
|
const [isOpen, setIsOpen] = useState(props.open);
|
|
23
18
|
useEffect(() => {
|
|
24
19
|
// Why do we need to change isOPen value in setTimeout?
|
|
@@ -31,5 +26,4 @@ function NodeCollapsible(props) {
|
|
|
31
26
|
isOpen: isOpen
|
|
32
27
|
}), children);
|
|
33
28
|
}
|
|
34
|
-
|
|
35
29
|
export default NodeCollapsible;
|
package/lib/es/tree/nodeList.js
CHANGED
|
@@ -2,7 +2,6 @@ import _isEqual from "lodash/isEqual";
|
|
|
2
2
|
import React, { PureComponent } from 'react';
|
|
3
3
|
import TreeContext from './treeContext';
|
|
4
4
|
import NodeCollapsible from './nodeCollapsible';
|
|
5
|
-
|
|
6
5
|
const getTreeNodeKey = treeNode => {
|
|
7
6
|
const {
|
|
8
7
|
data
|
|
@@ -12,23 +11,19 @@ const getTreeNodeKey = treeNode => {
|
|
|
12
11
|
} = data;
|
|
13
12
|
return key;
|
|
14
13
|
};
|
|
15
|
-
|
|
16
14
|
export default class NodeList extends PureComponent {
|
|
17
15
|
constructor(props) {
|
|
18
16
|
super(props);
|
|
19
|
-
|
|
20
17
|
this.onMotionEnd = () => {
|
|
21
18
|
typeof this.props.onMotionEnd === 'function' && this.props.onMotionEnd();
|
|
22
19
|
this.setState({
|
|
23
20
|
transitionNodes: []
|
|
24
21
|
});
|
|
25
22
|
};
|
|
26
|
-
|
|
27
23
|
this.state = {
|
|
28
24
|
transitionNodes: []
|
|
29
25
|
};
|
|
30
26
|
}
|
|
31
|
-
|
|
32
27
|
static getDerivedStateFromProps(props, prevState) {
|
|
33
28
|
const {
|
|
34
29
|
flattenNodes = [],
|
|
@@ -38,11 +33,9 @@ export default class NodeList extends PureComponent {
|
|
|
38
33
|
} = props;
|
|
39
34
|
const hasChanged = !_isEqual(prevState.cachedMotionKeys, motionKeys) || !_isEqual(prevState.cachedData.map(i => i.key), flattenNodes.map(i => i.key));
|
|
40
35
|
const motionArr = [...motionKeys];
|
|
41
|
-
|
|
42
36
|
if (!hasChanged || !motionArr.length) {
|
|
43
37
|
return null;
|
|
44
38
|
}
|
|
45
|
-
|
|
46
39
|
const transitionNodes = [];
|
|
47
40
|
const transitionRange = [];
|
|
48
41
|
let rangeStart = 0;
|
|
@@ -50,10 +43,8 @@ export default class NodeList extends PureComponent {
|
|
|
50
43
|
const lookUpTarget = motionType === 'hide' && flattenList ? flattenList : flattenNodes;
|
|
51
44
|
lookUpTarget.forEach((treeNode, ind) => {
|
|
52
45
|
const nodeKey = getTreeNodeKey(treeNode);
|
|
53
|
-
|
|
54
46
|
if (motionKeys.has(nodeKey)) {
|
|
55
47
|
transitionRange.push(treeNode);
|
|
56
|
-
|
|
57
48
|
if (nodeKey === motionArr[0]) {
|
|
58
49
|
rangeStart = ind;
|
|
59
50
|
}
|
|
@@ -70,7 +61,6 @@ export default class NodeList extends PureComponent {
|
|
|
70
61
|
};
|
|
71
62
|
return newState;
|
|
72
63
|
}
|
|
73
|
-
|
|
74
64
|
render() {
|
|
75
65
|
const {
|
|
76
66
|
flattenNodes,
|
|
@@ -84,11 +74,9 @@ export default class NodeList extends PureComponent {
|
|
|
84
74
|
const mapData = transitionNodes.length && !searchTargetIsDeep ? transitionNodes : flattenNodes;
|
|
85
75
|
const options = mapData.map(treeNode => {
|
|
86
76
|
const isMotionNode = Array.isArray(treeNode);
|
|
87
|
-
|
|
88
77
|
if (isMotionNode && !treeNode.length) {
|
|
89
78
|
return null;
|
|
90
79
|
}
|
|
91
|
-
|
|
92
80
|
if (isMotionNode && treeNode.length) {
|
|
93
81
|
const nodeKey = getTreeNodeKey(treeNode[0]);
|
|
94
82
|
return /*#__PURE__*/React.createElement(NodeCollapsible, {
|
|
@@ -99,11 +87,9 @@ export default class NodeList extends PureComponent {
|
|
|
99
87
|
onMotionEnd: this.onMotionEnd
|
|
100
88
|
}, treeNode.map(node => renderTreeNode(node)));
|
|
101
89
|
}
|
|
102
|
-
|
|
103
90
|
return renderTreeNode(treeNode);
|
|
104
91
|
});
|
|
105
92
|
return options;
|
|
106
93
|
}
|
|
107
|
-
|
|
108
94
|
}
|
|
109
95
|
NodeList.contextType = TreeContext;
|