@vkontakte/vkui 5.7.2 → 5.8.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/README.md +4 -4
- package/dist/cjs/components/Accordion/Accordion.d.ts +1 -1
- package/dist/cjs/components/Accordion/Accordion.js +6 -11
- package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
- package/dist/cjs/components/ActionSheet/ActionSheet.d.ts +6 -1
- package/dist/cjs/components/ActionSheet/ActionSheet.js +12 -9
- package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/cjs/components/ActionSheet/ActionSheetContext.d.ts +6 -1
- package/dist/cjs/components/ActionSheet/ActionSheetContext.js.map +1 -1
- package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +2 -1
- package/dist/cjs/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
- package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +6 -1
- package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +15 -4
- package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
- package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +22 -8
- package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
- package/dist/cjs/components/AppRoot/AppRoot.d.ts +19 -2
- package/dist/cjs/components/AppRoot/AppRoot.js +58 -20
- package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/cjs/components/AppRoot/AppRootContext.d.ts +1 -0
- package/dist/cjs/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/cjs/components/AppearanceProvider/AppearanceProvider.d.ts +1 -1
- package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
- package/dist/cjs/components/AspectRatio/AspectRatio.d.ts +3 -3
- package/dist/cjs/components/AspectRatio/AspectRatio.js +6 -8
- package/dist/cjs/components/AspectRatio/AspectRatio.js.map +1 -1
- package/dist/cjs/components/Badge/Badge.d.ts +3 -2
- package/dist/cjs/components/Badge/Badge.js +10 -8
- package/dist/cjs/components/Badge/Badge.js.map +1 -1
- package/dist/cjs/components/Banner/Banner.d.ts +3 -3
- package/dist/cjs/components/Banner/Banner.js +10 -9
- package/dist/cjs/components/Banner/Banner.js.map +1 -1
- package/dist/cjs/components/BaseGallery/BaseGallery.d.ts +1 -1
- package/dist/cjs/components/BaseGallery/BaseGallery.js +10 -9
- package/dist/cjs/components/BaseGallery/BaseGallery.js.map +1 -1
- package/dist/cjs/components/BaseGallery/types.d.ts +2 -2
- package/dist/cjs/components/BaseGallery/types.js.map +1 -1
- package/dist/cjs/components/Button/Button.js +26 -22
- package/dist/cjs/components/Button/Button.js.map +1 -1
- package/dist/cjs/components/ButtonGroup/ButtonGroup.d.ts +3 -3
- package/dist/cjs/components/ButtonGroup/ButtonGroup.js +21 -21
- package/dist/cjs/components/ButtonGroup/ButtonGroup.js.map +1 -1
- package/dist/cjs/components/Calendar/Calendar.d.ts +3 -3
- package/dist/cjs/components/Calendar/Calendar.js +4 -6
- package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
- package/dist/cjs/components/CalendarDays/CalendarDays.d.ts +3 -2
- package/dist/cjs/components/CalendarDays/CalendarDays.js +11 -8
- package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +3 -2
- package/dist/cjs/components/CalendarHeader/CalendarHeader.js +24 -7
- package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/cjs/components/CalendarRange/CalendarRange.d.ts +3 -3
- package/dist/cjs/components/CalendarRange/CalendarRange.js +4 -6
- package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/cjs/components/Card/Card.d.ts +4 -4
- package/dist/cjs/components/Card/Card.js +7 -9
- package/dist/cjs/components/Card/Card.js.map +1 -1
- package/dist/cjs/components/CardGrid/CardGrid.d.ts +3 -2
- package/dist/cjs/components/CardGrid/CardGrid.js +11 -11
- package/dist/cjs/components/CardGrid/CardGrid.js.map +1 -1
- package/dist/cjs/components/CardScroll/CardScroll.d.ts +3 -2
- package/dist/cjs/components/CardScroll/CardScroll.js +10 -9
- package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/cjs/components/Cell/CellDragger/CellDragger.d.ts +2 -1
- package/dist/cjs/components/Cell/CellDragger/CellDragger.js.map +1 -1
- package/dist/cjs/components/Checkbox/Checkbox.js +3 -4
- package/dist/cjs/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/cjs/components/Chip/Chip.d.ts +3 -2
- package/dist/cjs/components/Chip/Chip.js +6 -7
- package/dist/cjs/components/Chip/Chip.js.map +1 -1
- package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js +4 -2
- package/dist/cjs/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
- package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +7 -0
- package/dist/cjs/components/ConfigProvider/ConfigProvider.js +24 -6
- package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/cjs/components/ConfigProvider/ConfigProviderContext.d.ts +47 -3
- package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js +6 -1
- package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
- package/dist/cjs/components/Counter/Counter.d.ts +2 -1
- package/dist/cjs/components/Counter/Counter.js.map +1 -1
- package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +1 -1
- package/dist/cjs/components/CustomSelect/CustomSelect.js +1 -1
- package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -2
- package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
- package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/cjs/components/DatePicker/DatePicker.d.ts +2 -1
- package/dist/cjs/components/DatePicker/DatePicker.js +5 -5
- package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
- package/dist/cjs/components/Div/Div.d.ts +3 -4
- package/dist/cjs/components/Div/Div.js +5 -13
- package/dist/cjs/components/Div/Div.js.map +1 -1
- package/dist/cjs/components/DropdownIcon/DropdownIcon.d.ts +2 -1
- package/dist/cjs/components/DropdownIcon/DropdownIcon.js.map +1 -1
- package/dist/cjs/components/Epic/Epic.d.ts +3 -2
- package/dist/cjs/components/Epic/Epic.js +7 -7
- package/dist/cjs/components/Epic/Epic.js.map +1 -1
- package/dist/cjs/components/FixedLayout/FixedLayout.d.ts +2 -2
- package/dist/cjs/components/FixedLayout/FixedLayout.js +5 -4
- package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
- package/dist/cjs/components/FocusTrap/FocusTrap.d.ts +2 -2
- package/dist/cjs/components/FocusTrap/FocusTrap.js.map +1 -1
- package/dist/cjs/components/FocusVisible/FocusVisible.d.ts +2 -1
- package/dist/cjs/components/FocusVisible/FocusVisible.js +8 -6
- package/dist/cjs/components/FocusVisible/FocusVisible.js.map +1 -1
- package/dist/cjs/components/FormField/FormField.js +5 -4
- package/dist/cjs/components/FormField/FormField.js.map +1 -1
- package/dist/cjs/components/FormItem/FormItem.d.ts +6 -1
- package/dist/cjs/components/FormItem/FormItem.js +11 -10
- package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
- package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -3
- package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +6 -6
- package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
- package/dist/cjs/components/FormStatus/FormStatus.d.ts +2 -2
- package/dist/cjs/components/FormStatus/FormStatus.js.map +1 -1
- package/dist/cjs/components/Gradient/Gradient.d.ts +3 -2
- package/dist/cjs/components/Gradient/Gradient.js +15 -14
- package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
- package/dist/cjs/components/Group/Group.d.ts +3 -3
- package/dist/cjs/components/Group/Group.js +35 -21
- package/dist/cjs/components/Group/Group.js.map +1 -1
- package/dist/cjs/components/Header/Header.d.ts +3 -3
- package/dist/cjs/components/Header/Header.js +12 -11
- package/dist/cjs/components/Header/Header.js.map +1 -1
- package/dist/cjs/components/HorizontalCell/HorizontalCell.js +6 -5
- package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
- package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +3 -3
- package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +4 -4
- package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
- package/dist/cjs/components/ImageBase/ImageBase.d.ts +2 -2
- package/dist/cjs/components/ImageBase/ImageBase.js +5 -7
- package/dist/cjs/components/ImageBase/ImageBase.js.map +1 -1
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js +8 -9
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/cjs/components/InfoRow/InfoRow.d.ts +2 -1
- package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
- package/dist/cjs/components/InputLike/InputLike.d.ts +3 -3
- package/dist/cjs/components/InputLike/InputLike.js +6 -8
- package/dist/cjs/components/InputLike/InputLike.js.map +1 -1
- package/dist/cjs/components/List/List.d.ts +3 -2
- package/dist/cjs/components/List/List.js +5 -5
- package/dist/cjs/components/List/List.js.map +1 -1
- package/dist/cjs/components/MiniInfoCell/MiniInfoCell.d.ts +2 -1
- package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +14 -11
- package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
- package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
- package/dist/cjs/components/ModalCard/ModalCard.js +5 -7
- package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
- package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +3 -3
- package/dist/cjs/components/ModalCardBase/ModalCardBase.js +4 -6
- package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
- package/dist/cjs/components/ModalDismissButton/ModalDismissButton.d.ts +2 -1
- package/dist/cjs/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
- package/dist/cjs/components/ModalPage/ModalPage.d.ts +3 -2
- package/dist/cjs/components/ModalPage/ModalPage.js +9 -6
- package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
- package/dist/cjs/components/ModalRoot/ModalRoot.js +6 -4
- package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/cjs/components/ModalRoot/ModalRootContext.js +3 -0
- package/dist/cjs/components/ModalRoot/ModalRootContext.js.map +1 -1
- package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +2 -2
- package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
- package/dist/cjs/components/ModalRoot/types.d.ts +1 -0
- package/dist/cjs/components/ModalRoot/types.js.map +1 -1
- package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts +8 -0
- package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js +43 -0
- package/dist/cjs/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -0
- package/dist/cjs/components/Pagination/Pagination.d.ts +3 -3
- package/dist/cjs/components/Pagination/Pagination.js +17 -33
- package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageButton.d.ts +12 -0
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageButton.js +48 -0
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -0
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts +6 -0
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageEllipsis.js +32 -0
- package/dist/cjs/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -0
- package/dist/cjs/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts +5 -0
- package/dist/cjs/components/Pagination/PaginationPage/usePaginationPageClasses.js +20 -0
- package/dist/cjs/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -0
- package/dist/cjs/components/Pagination/utils.d.ts +1 -0
- package/dist/cjs/components/Pagination/utils.js +15 -0
- package/dist/cjs/components/Pagination/utils.js.map +1 -0
- package/dist/cjs/components/Panel/Panel.d.ts +3 -3
- package/dist/cjs/components/Panel/Panel.js +7 -7
- package/dist/cjs/components/Panel/Panel.js.map +1 -1
- package/dist/cjs/components/PanelHeader/PanelHeader.d.ts +3 -3
- package/dist/cjs/components/PanelHeader/PanelHeader.js +15 -10
- package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.d.ts +3 -2
- package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js +4 -6
- package/dist/cjs/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
- package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -1
- package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
- package/dist/cjs/components/Placeholder/Placeholder.d.ts +24 -11
- package/dist/cjs/components/Placeholder/Placeholder.js +49 -21
- package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
- package/dist/cjs/components/PopoutRoot/PopoutRoot.d.ts +3 -3
- package/dist/cjs/components/PopoutRoot/PopoutRoot.js +12 -17
- package/dist/cjs/components/PopoutRoot/PopoutRoot.js.map +1 -1
- package/dist/cjs/components/PopoutWrapper/PopoutWrapper.d.ts +3 -2
- package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +16 -16
- package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
- package/dist/cjs/components/Popper/Popper.d.ts +7 -3
- package/dist/cjs/components/Popper/Popper.js +19 -10
- package/dist/cjs/components/Popper/Popper.js.map +1 -1
- package/dist/cjs/components/Progress/Progress.d.ts +3 -3
- package/dist/cjs/components/Progress/Progress.js +9 -10
- package/dist/cjs/components/Progress/Progress.js.map +1 -1
- package/dist/cjs/components/PromoBanner/PromoBanner.d.ts +3 -2
- package/dist/cjs/components/PromoBanner/PromoBanner.js +5 -6
- package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
- package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts +25 -0
- package/dist/cjs/components/PullToRefresh/PullToRefresh.js +5 -2
- package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.d.ts +7 -7
- package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +14 -6
- package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
- package/dist/cjs/components/RadioGroup/RadioGroup.d.ts +3 -2
- package/dist/cjs/components/RadioGroup/RadioGroup.js +6 -7
- package/dist/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/cjs/components/Removable/Removable.d.ts +3 -3
- package/dist/cjs/components/Removable/Removable.js +4 -8
- package/dist/cjs/components/Removable/Removable.js.map +1 -1
- package/dist/cjs/components/RichCell/RichCell.d.ts +1 -1
- package/dist/cjs/components/RichCell/RichCellIcon/RichCellIcon.d.ts +3 -1
- package/dist/cjs/components/RichCell/RichCellIcon/RichCellIcon.js +5 -11
- package/dist/cjs/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
- package/dist/cjs/components/RichTooltip/RichTooltip.js +7 -6
- package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
- package/dist/cjs/components/Root/Root.d.ts +3 -2
- package/dist/cjs/components/Root/Root.js +13 -10
- package/dist/cjs/components/Root/Root.js.map +1 -1
- package/dist/cjs/components/RootComponent/RootComponent.d.ts +9 -0
- package/dist/cjs/components/RootComponent/RootComponent.js +29 -0
- package/dist/cjs/components/RootComponent/RootComponent.js.map +1 -0
- package/dist/cjs/components/ScrollArrow/ScrollArrow.d.ts +1 -1
- package/dist/cjs/components/ScrollArrow/ScrollArrow.js +13 -12
- package/dist/cjs/components/ScrollArrow/ScrollArrow.js.map +1 -1
- package/dist/cjs/components/Search/Search.d.ts +3 -3
- package/dist/cjs/components/Search/Search.js +4 -2
- package/dist/cjs/components/Search/Search.js.map +1 -1
- package/dist/cjs/components/SegmentedControl/SegmentedControl.d.ts +3 -3
- package/dist/cjs/components/SegmentedControl/SegmentedControl.js +4 -6
- package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -3
- package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +4 -2
- package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
- package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +2 -2
- package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
- package/dist/cjs/components/SelectTypography/SelectTypography.d.ts +2 -2
- package/dist/cjs/components/SelectTypography/SelectTypography.js.map +1 -1
- package/dist/cjs/components/Separator/Separator.d.ts +3 -2
- package/dist/cjs/components/Separator/Separator.js +5 -5
- package/dist/cjs/components/Separator/Separator.js.map +1 -1
- package/dist/cjs/components/Slider/Slider.d.ts +4 -3
- package/dist/cjs/components/Slider/Slider.js +5 -2
- package/dist/cjs/components/Slider/Slider.js.map +1 -1
- package/dist/cjs/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
- package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js +56 -5
- package/dist/cjs/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
- package/dist/cjs/components/Snackbar/Snackbar.d.ts +3 -2
- package/dist/cjs/components/Snackbar/Snackbar.js +8 -7
- package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/cjs/components/Spacing/Spacing.d.ts +3 -3
- package/dist/cjs/components/Spacing/Spacing.js +5 -6
- package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
- package/dist/cjs/components/Spinner/Spinner.d.ts +3 -2
- package/dist/cjs/components/Spinner/Spinner.js +6 -6
- package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
- package/dist/cjs/components/SplitCol/SplitCol.d.ts +2 -1
- package/dist/cjs/components/SplitCol/SplitCol.js +8 -6
- package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
- package/dist/cjs/components/SplitLayout/SplitLayout.d.ts +2 -2
- package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/cjs/components/SubnavigationBar/SubnavigationBar.d.ts +3 -2
- package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +7 -9
- package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
- package/dist/cjs/components/Tabbar/Tabbar.d.ts +3 -2
- package/dist/cjs/components/Tabbar/Tabbar.js +6 -7
- package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
- package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +1 -1
- package/dist/cjs/components/TabbarItem/TabbarItem.js +7 -7
- package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
- package/dist/cjs/components/Tabs/Tabs.d.ts +3 -3
- package/dist/cjs/components/Tabs/Tabs.js +4 -6
- package/dist/cjs/components/Tabs/Tabs.js.map +1 -1
- package/dist/cjs/components/TabsItem/TabsItem.d.ts +2 -1
- package/dist/cjs/components/TabsItem/TabsItem.js +6 -5
- package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cjs/components/Tappable/Tappable.d.ts +6 -1
- package/dist/cjs/components/Tappable/Tappable.js +12 -9
- package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
- package/dist/cjs/components/TextTooltip/TextTooltip.js +7 -6
- package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
- package/dist/cjs/components/Tooltip/Tooltip.d.ts +1 -1
- package/dist/cjs/components/Tooltip/Tooltip.js +5 -3
- package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/cjs/components/TooltipBase/TooltipBase.d.ts +8 -1
- package/dist/cjs/components/TooltipBase/TooltipBase.js +21 -8
- package/dist/cjs/components/TooltipBase/TooltipBase.js.map +1 -1
- package/dist/cjs/components/Typography/Caption/Caption.js +6 -5
- package/dist/cjs/components/Typography/Caption/Caption.js.map +1 -1
- package/dist/cjs/components/Typography/Headline/Headline.js +5 -4
- package/dist/cjs/components/Typography/Headline/Headline.js.map +1 -1
- package/dist/cjs/components/Typography/Title/Title.js +6 -5
- package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
- package/dist/cjs/components/Typography/Typography.d.ts +1 -1
- package/dist/cjs/components/Typography/Typography.js +12 -13
- package/dist/cjs/components/Typography/Typography.js.map +1 -1
- package/dist/cjs/components/UsersStack/UsersStack.d.ts +3 -2
- package/dist/cjs/components/UsersStack/UsersStack.js +14 -12
- package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
- package/dist/cjs/components/View/View.d.ts +2 -1
- package/dist/cjs/components/View/View.js +7 -3
- package/dist/cjs/components/View/View.js.map +1 -1
- package/dist/cjs/components/View/ViewInfinite.d.ts +10 -3
- package/dist/cjs/components/View/ViewInfinite.js +17 -6
- package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
- package/dist/cjs/components/VisuallyHidden/VisuallyHidden.d.ts +1 -1
- package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js +8 -9
- package/dist/cjs/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
- package/dist/cjs/helpers/appearance.d.ts +4 -0
- package/dist/cjs/helpers/appearance.js.map +1 -1
- package/dist/cjs/hooks/useAppearance.d.ts +1 -1
- package/dist/cjs/hooks/useAutoDetectAppearance.d.ts +4 -0
- package/dist/cjs/hooks/useAutoDetectAppearance.js.map +1 -1
- package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +5 -1
- package/dist/cjs/hooks/useBridgeAdaptivity.js +25 -20
- package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -1
- package/dist/cjs/hooks/useInsets.d.ts +5 -1
- package/dist/cjs/hooks/useInsets.js +11 -11
- package/dist/cjs/hooks/useInsets.js.map +1 -1
- package/dist/cjs/index.d.ts +6 -3
- package/dist/cjs/index.js +14 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/adaptivity/functions.d.ts +8 -0
- package/dist/cjs/lib/adaptivity/functions.js +30 -0
- package/dist/cjs/lib/adaptivity/functions.js.map +1 -1
- package/dist/cjs/lib/appearance/index.d.ts +1 -0
- package/dist/cjs/lib/appearance/index.js +6 -0
- package/dist/cjs/lib/appearance/index.js.map +1 -0
- package/dist/cjs/lib/appearance/types.d.ts +1 -0
- package/dist/cjs/lib/appearance/types.js +6 -0
- package/dist/cjs/lib/appearance/types.js.map +1 -0
- package/dist/cjs/lib/floating/index.d.ts +1 -1
- package/dist/cjs/lib/floating/index.js +3 -0
- package/dist/cjs/lib/floating/index.js.map +1 -1
- package/dist/cjs/lib/platform.js +11 -7
- package/dist/cjs/lib/platform.js.map +1 -1
- package/dist/cjs/lib/select.d.ts +1 -1
- package/dist/cjs/lib/taptic.d.ts +4 -0
- package/dist/cjs/lib/taptic.js.map +1 -1
- package/dist/cjs/lib/utils.d.ts +2 -0
- package/dist/cjs/lib/utils.js +22 -0
- package/dist/cjs/lib/utils.js.map +1 -1
- package/dist/cjs/types.d.ts +1 -0
- package/dist/cjs/types.js.map +1 -1
- package/dist/components/Accordion/Accordion.d.ts +1 -1
- package/dist/components/Accordion/Accordion.js +6 -11
- package/dist/components/Accordion/Accordion.js.map +1 -1
- package/dist/components/ActionSheet/ActionSheet.d.ts +6 -1
- package/dist/components/ActionSheet/ActionSheet.js +12 -9
- package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/components/ActionSheet/ActionSheetContext.d.ts +6 -1
- package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
- package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +2 -1
- package/dist/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
- package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +6 -1
- package/dist/components/ActionSheetItem/ActionSheetItem.js +15 -4
- package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
- package/dist/components/AdaptivityProvider/AdaptivityProvider.js +22 -8
- package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
- package/dist/components/AppRoot/AppRoot.d.ts +19 -2
- package/dist/components/AppRoot/AppRoot.js +58 -20
- package/dist/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/components/AppRoot/AppRootContext.d.ts +1 -0
- package/dist/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/components/AppearanceProvider/AppearanceProvider.d.ts +1 -1
- package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
- package/dist/components/AspectRatio/AspectRatio.d.ts +3 -3
- package/dist/components/AspectRatio/AspectRatio.js +6 -8
- package/dist/components/AspectRatio/AspectRatio.js.map +1 -1
- package/dist/components/Badge/Badge.d.ts +3 -2
- package/dist/components/Badge/Badge.js +10 -8
- package/dist/components/Badge/Badge.js.map +1 -1
- package/dist/components/Banner/Banner.d.ts +3 -3
- package/dist/components/Banner/Banner.js +10 -9
- package/dist/components/Banner/Banner.js.map +1 -1
- package/dist/components/BaseGallery/BaseGallery.d.ts +1 -1
- package/dist/components/BaseGallery/BaseGallery.js +10 -9
- package/dist/components/BaseGallery/BaseGallery.js.map +1 -1
- package/dist/components/BaseGallery/types.d.ts +2 -2
- package/dist/components/BaseGallery/types.js.map +1 -1
- package/dist/components/Button/Button.js +26 -22
- package/dist/components/Button/Button.js.map +1 -1
- package/dist/components/ButtonGroup/ButtonGroup.d.ts +3 -3
- package/dist/components/ButtonGroup/ButtonGroup.js +21 -21
- package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
- package/dist/components/Calendar/Calendar.d.ts +3 -3
- package/dist/components/Calendar/Calendar.js +4 -6
- package/dist/components/Calendar/Calendar.js.map +1 -1
- package/dist/components/CalendarDays/CalendarDays.d.ts +3 -2
- package/dist/components/CalendarDays/CalendarDays.js +11 -8
- package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/components/CalendarHeader/CalendarHeader.d.ts +3 -2
- package/dist/components/CalendarHeader/CalendarHeader.js +24 -7
- package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/components/CalendarRange/CalendarRange.d.ts +3 -3
- package/dist/components/CalendarRange/CalendarRange.js +4 -6
- package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/components/Card/Card.d.ts +4 -4
- package/dist/components/Card/Card.js +7 -9
- package/dist/components/Card/Card.js.map +1 -1
- package/dist/components/CardGrid/CardGrid.d.ts +3 -2
- package/dist/components/CardGrid/CardGrid.js +11 -11
- package/dist/components/CardGrid/CardGrid.js.map +1 -1
- package/dist/components/CardScroll/CardScroll.d.ts +3 -2
- package/dist/components/CardScroll/CardScroll.js +10 -9
- package/dist/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/components/Cell/CellDragger/CellDragger.d.ts +2 -1
- package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
- package/dist/components/Checkbox/Checkbox.js +3 -4
- package/dist/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/components/Chip/Chip.d.ts +3 -2
- package/dist/components/Chip/Chip.js +6 -7
- package/dist/components/Chip/Chip.js.map +1 -1
- package/dist/components/ChipsInputBase/ChipsInputBase.js +4 -2
- package/dist/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.d.ts +7 -0
- package/dist/components/ConfigProvider/ConfigProvider.js +25 -7
- package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +47 -3
- package/dist/components/ConfigProvider/ConfigProviderContext.js +6 -1
- package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
- package/dist/components/Counter/Counter.d.ts +2 -1
- package/dist/components/Counter/Counter.js.map +1 -1
- package/dist/components/CustomSelect/CustomSelect.d.ts +1 -1
- package/dist/components/CustomSelect/CustomSelect.js +1 -1
- package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -2
- package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
- package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/components/DatePicker/DatePicker.d.ts +2 -1
- package/dist/components/DatePicker/DatePicker.js +6 -6
- package/dist/components/DatePicker/DatePicker.js.map +1 -1
- package/dist/components/Div/Div.d.ts +3 -4
- package/dist/components/Div/Div.js +5 -13
- package/dist/components/Div/Div.js.map +1 -1
- package/dist/components/DropdownIcon/DropdownIcon.d.ts +2 -1
- package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
- package/dist/components/Epic/Epic.d.ts +3 -2
- package/dist/components/Epic/Epic.js +7 -7
- package/dist/components/Epic/Epic.js.map +1 -1
- package/dist/components/FixedLayout/FixedLayout.d.ts +2 -2
- package/dist/components/FixedLayout/FixedLayout.js +5 -4
- package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
- package/dist/components/FocusTrap/FocusTrap.d.ts +2 -2
- package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
- package/dist/components/FocusVisible/FocusVisible.d.ts +2 -1
- package/dist/components/FocusVisible/FocusVisible.js +8 -6
- package/dist/components/FocusVisible/FocusVisible.js.map +1 -1
- package/dist/components/FormField/FormField.js +5 -4
- package/dist/components/FormField/FormField.js.map +1 -1
- package/dist/components/FormItem/FormItem.d.ts +6 -1
- package/dist/components/FormItem/FormItem.js +11 -10
- package/dist/components/FormItem/FormItem.js.map +1 -1
- package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -3
- package/dist/components/FormLayoutGroup/FormLayoutGroup.js +6 -6
- package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
- package/dist/components/FormStatus/FormStatus.d.ts +2 -2
- package/dist/components/FormStatus/FormStatus.js.map +1 -1
- package/dist/components/Gradient/Gradient.d.ts +3 -2
- package/dist/components/Gradient/Gradient.js +15 -14
- package/dist/components/Gradient/Gradient.js.map +1 -1
- package/dist/components/Group/Group.d.ts +3 -3
- package/dist/components/Group/Group.js +35 -21
- package/dist/components/Group/Group.js.map +1 -1
- package/dist/components/Header/Header.d.ts +3 -3
- package/dist/components/Header/Header.js +12 -11
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/HorizontalCell/HorizontalCell.js +6 -5
- package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
- package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +3 -3
- package/dist/components/HorizontalScroll/HorizontalScroll.js +4 -4
- package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
- package/dist/components/ImageBase/ImageBase.d.ts +2 -2
- package/dist/components/ImageBase/ImageBase.js +5 -7
- package/dist/components/ImageBase/ImageBase.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js +8 -9
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/components/InfoRow/InfoRow.d.ts +2 -1
- package/dist/components/InfoRow/InfoRow.js.map +1 -1
- package/dist/components/InputLike/InputLike.d.ts +3 -3
- package/dist/components/InputLike/InputLike.js +6 -8
- package/dist/components/InputLike/InputLike.js.map +1 -1
- package/dist/components/List/List.d.ts +3 -2
- package/dist/components/List/List.js +5 -5
- package/dist/components/List/List.js.map +1 -1
- package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +2 -1
- package/dist/components/MiniInfoCell/MiniInfoCell.js +14 -11
- package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
- package/dist/components/ModalCard/ModalCard.d.ts +1 -1
- package/dist/components/ModalCard/ModalCard.js +5 -7
- package/dist/components/ModalCard/ModalCard.js.map +1 -1
- package/dist/components/ModalCardBase/ModalCardBase.d.ts +3 -3
- package/dist/components/ModalCardBase/ModalCardBase.js +4 -6
- package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
- package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +2 -1
- package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
- package/dist/components/ModalPage/ModalPage.d.ts +3 -2
- package/dist/components/ModalPage/ModalPage.js +9 -6
- package/dist/components/ModalPage/ModalPage.js.map +1 -1
- package/dist/components/ModalRoot/ModalRoot.js +7 -5
- package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/components/ModalRoot/ModalRootContext.js +3 -0
- package/dist/components/ModalRoot/ModalRootContext.js.map +1 -1
- package/dist/components/ModalRoot/ModalRootDesktop.js +3 -3
- package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
- package/dist/components/ModalRoot/types.d.ts +1 -0
- package/dist/components/ModalRoot/types.js.map +1 -1
- package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts +8 -0
- package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js +24 -0
- package/dist/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -0
- package/dist/components/Pagination/Pagination.d.ts +3 -3
- package/dist/components/Pagination/Pagination.js +17 -33
- package/dist/components/Pagination/Pagination.js.map +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.d.ts +12 -0
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.js +37 -0
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -0
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts +6 -0
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js +21 -0
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -0
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts +5 -0
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js +10 -0
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -0
- package/dist/components/Pagination/utils.d.ts +1 -0
- package/dist/components/Pagination/utils.js +5 -0
- package/dist/components/Pagination/utils.js.map +1 -0
- package/dist/components/Panel/Panel.d.ts +3 -3
- package/dist/components/Panel/Panel.js +7 -7
- package/dist/components/Panel/Panel.js.map +1 -1
- package/dist/components/PanelHeader/PanelHeader.d.ts +3 -3
- package/dist/components/PanelHeader/PanelHeader.js +16 -11
- package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +3 -2
- package/dist/components/PanelHeaderContent/PanelHeaderContent.js +4 -6
- package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
- package/dist/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -1
- package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
- package/dist/components/Placeholder/Placeholder.d.ts +24 -11
- package/dist/components/Placeholder/Placeholder.js +49 -21
- package/dist/components/Placeholder/Placeholder.js.map +1 -1
- package/dist/components/PopoutRoot/PopoutRoot.d.ts +3 -3
- package/dist/components/PopoutRoot/PopoutRoot.js +12 -17
- package/dist/components/PopoutRoot/PopoutRoot.js.map +1 -1
- package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +3 -2
- package/dist/components/PopoutWrapper/PopoutWrapper.js +16 -16
- package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
- package/dist/components/Popper/Popper.d.ts +7 -3
- package/dist/components/Popper/Popper.js +20 -11
- package/dist/components/Popper/Popper.js.map +1 -1
- package/dist/components/Progress/Progress.d.ts +3 -3
- package/dist/components/Progress/Progress.js +9 -10
- package/dist/components/Progress/Progress.js.map +1 -1
- package/dist/components/PromoBanner/PromoBanner.d.ts +3 -2
- package/dist/components/PromoBanner/PromoBanner.js +5 -6
- package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.d.ts +25 -0
- package/dist/components/PullToRefresh/PullToRefresh.js +5 -2
- package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts +7 -7
- package/dist/components/PullToRefresh/PullToRefreshSpinner.js +14 -6
- package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
- package/dist/components/RadioGroup/RadioGroup.d.ts +3 -2
- package/dist/components/RadioGroup/RadioGroup.js +6 -7
- package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/components/Removable/Removable.d.ts +3 -3
- package/dist/components/Removable/Removable.js +4 -8
- package/dist/components/Removable/Removable.js.map +1 -1
- package/dist/components/RichCell/RichCell.d.ts +1 -1
- package/dist/components/RichCell/RichCellIcon/RichCellIcon.d.ts +3 -1
- package/dist/components/RichCell/RichCellIcon/RichCellIcon.js +5 -11
- package/dist/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
- package/dist/components/RichTooltip/RichTooltip.js +7 -6
- package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
- package/dist/components/Root/Root.d.ts +3 -2
- package/dist/components/Root/Root.js +13 -10
- package/dist/components/Root/Root.js.map +1 -1
- package/dist/components/RootComponent/RootComponent.d.ts +9 -0
- package/dist/components/RootComponent/RootComponent.js +20 -0
- package/dist/components/RootComponent/RootComponent.js.map +1 -0
- package/dist/components/ScrollArrow/ScrollArrow.d.ts +1 -1
- package/dist/components/ScrollArrow/ScrollArrow.js +13 -12
- package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
- package/dist/components/Search/Search.d.ts +3 -3
- package/dist/components/Search/Search.js +4 -2
- package/dist/components/Search/Search.js.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControl.d.ts +3 -3
- package/dist/components/SegmentedControl/SegmentedControl.js +4 -6
- package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -3
- package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +4 -2
- package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
- package/dist/components/SelectMimicry/SelectMimicry.d.ts +2 -2
- package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
- package/dist/components/SelectTypography/SelectTypography.d.ts +2 -2
- package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
- package/dist/components/Separator/Separator.d.ts +3 -2
- package/dist/components/Separator/Separator.js +5 -5
- package/dist/components/Separator/Separator.js.map +1 -1
- package/dist/components/Slider/Slider.d.ts +4 -3
- package/dist/components/Slider/Slider.js +5 -2
- package/dist/components/Slider/Slider.js.map +1 -1
- package/dist/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
- package/dist/components/Slider/SliderThumb/SliderThumb.js +56 -5
- package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
- package/dist/components/Snackbar/Snackbar.d.ts +3 -2
- package/dist/components/Snackbar/Snackbar.js +8 -7
- package/dist/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/components/Spacing/Spacing.d.ts +3 -3
- package/dist/components/Spacing/Spacing.js +5 -6
- package/dist/components/Spacing/Spacing.js.map +1 -1
- package/dist/components/Spinner/Spinner.d.ts +3 -2
- package/dist/components/Spinner/Spinner.js +6 -6
- package/dist/components/Spinner/Spinner.js.map +1 -1
- package/dist/components/SplitCol/SplitCol.d.ts +2 -1
- package/dist/components/SplitCol/SplitCol.js +8 -6
- package/dist/components/SplitCol/SplitCol.js.map +1 -1
- package/dist/components/SplitLayout/SplitLayout.d.ts +2 -2
- package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +3 -2
- package/dist/components/SubnavigationBar/SubnavigationBar.js +7 -9
- package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
- package/dist/components/Tabbar/Tabbar.d.ts +3 -2
- package/dist/components/Tabbar/Tabbar.js +6 -7
- package/dist/components/Tabbar/Tabbar.js.map +1 -1
- package/dist/components/TabbarItem/TabbarItem.d.ts +1 -1
- package/dist/components/TabbarItem/TabbarItem.js +7 -7
- package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
- package/dist/components/Tabs/Tabs.d.ts +3 -3
- package/dist/components/Tabs/Tabs.js +4 -6
- package/dist/components/Tabs/Tabs.js.map +1 -1
- package/dist/components/TabsItem/TabsItem.d.ts +2 -1
- package/dist/components/TabsItem/TabsItem.js +6 -5
- package/dist/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/components/Tappable/Tappable.d.ts +6 -1
- package/dist/components/Tappable/Tappable.js +12 -9
- package/dist/components/Tappable/Tappable.js.map +1 -1
- package/dist/components/TextTooltip/TextTooltip.js +7 -6
- package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
- package/dist/components/Tooltip/Tooltip.d.ts +1 -1
- package/dist/components/Tooltip/Tooltip.js +6 -4
- package/dist/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/components/TooltipBase/TooltipBase.d.ts +8 -1
- package/dist/components/TooltipBase/TooltipBase.js +10 -5
- package/dist/components/TooltipBase/TooltipBase.js.map +1 -1
- package/dist/components/Typography/Caption/Caption.js +6 -5
- package/dist/components/Typography/Caption/Caption.js.map +1 -1
- package/dist/components/Typography/Headline/Headline.js +5 -4
- package/dist/components/Typography/Headline/Headline.js.map +1 -1
- package/dist/components/Typography/Title/Title.js +6 -5
- package/dist/components/Typography/Title/Title.js.map +1 -1
- package/dist/components/Typography/Typography.d.ts +1 -1
- package/dist/components/Typography/Typography.js +12 -13
- package/dist/components/Typography/Typography.js.map +1 -1
- package/dist/components/UsersStack/UsersStack.d.ts +3 -2
- package/dist/components/UsersStack/UsersStack.js +14 -12
- package/dist/components/UsersStack/UsersStack.js.map +1 -1
- package/dist/components/View/View.d.ts +2 -1
- package/dist/components/View/View.js +7 -3
- package/dist/components/View/View.js.map +1 -1
- package/dist/components/View/ViewInfinite.d.ts +10 -3
- package/dist/components/View/ViewInfinite.js +7 -4
- package/dist/components/View/ViewInfinite.js.map +1 -1
- package/dist/components/VisuallyHidden/VisuallyHidden.d.ts +1 -1
- package/dist/components/VisuallyHidden/VisuallyHidden.js +8 -9
- package/dist/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
- package/dist/components.css +19 -18
- package/dist/components.css.map +1 -1
- package/dist/components.js.tmp +6990 -4428
- package/dist/cssm/components/Accordion/Accordion.d.ts +1 -1
- package/dist/cssm/components/Accordion/Accordion.js +5 -5
- package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheet.d.ts +6 -1
- package/dist/cssm/components/ActionSheet/ActionSheet.js +11 -9
- package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheetContext.d.ts +6 -1
- package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js +1 -0
- package/dist/cssm/components/ActionSheet/ActionSheetDefaultIosCloseItem.js.map +1 -1
- package/dist/cssm/components/ActionSheetItem/ActionSheetItem.d.ts +6 -1
- package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +13 -3
- package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
- package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +22 -8
- package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRoot.d.ts +19 -2
- package/dist/cssm/components/AppRoot/AppRoot.js +49 -15
- package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRootContext.d.ts +1 -0
- package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/cssm/components/AppearanceProvider/AppearanceProvider.d.ts +1 -1
- package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
- package/dist/cssm/components/AspectRatio/AspectRatio.d.ts +3 -3
- package/dist/cssm/components/AspectRatio/AspectRatio.js +5 -5
- package/dist/cssm/components/AspectRatio/AspectRatio.js.map +1 -1
- package/dist/cssm/components/Badge/Badge.d.ts +3 -2
- package/dist/cssm/components/Badge/Badge.js +8 -5
- package/dist/cssm/components/Badge/Badge.js.map +1 -1
- package/dist/cssm/components/Banner/Banner.d.ts +3 -3
- package/dist/cssm/components/Banner/Banner.js +9 -7
- package/dist/cssm/components/Banner/Banner.js.map +1 -1
- package/dist/cssm/components/BaseGallery/BaseGallery.d.ts +1 -1
- package/dist/cssm/components/BaseGallery/BaseGallery.js +10 -8
- package/dist/cssm/components/BaseGallery/BaseGallery.js.map +1 -1
- package/dist/cssm/components/BaseGallery/types.d.ts +2 -2
- package/dist/cssm/components/BaseGallery/types.js.map +1 -1
- package/dist/cssm/components/Button/Button.js +26 -22
- package/dist/cssm/components/Button/Button.js.map +1 -1
- package/dist/cssm/components/ButtonGroup/ButtonGroup.d.ts +3 -3
- package/dist/cssm/components/ButtonGroup/ButtonGroup.js +19 -16
- package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
- package/dist/cssm/components/Calendar/Calendar.d.ts +3 -3
- package/dist/cssm/components/Calendar/Calendar.js +4 -4
- package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
- package/dist/cssm/components/CalendarDays/CalendarDays.d.ts +3 -2
- package/dist/cssm/components/CalendarDays/CalendarDays.js +9 -6
- package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +3 -2
- package/dist/cssm/components/CalendarHeader/CalendarHeader.js +6 -4
- package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/cssm/components/CalendarRange/CalendarRange.d.ts +3 -3
- package/dist/cssm/components/CalendarRange/CalendarRange.js +4 -5
- package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/cssm/components/Card/Card.d.ts +4 -4
- package/dist/cssm/components/Card/Card.js +6 -5
- package/dist/cssm/components/Card/Card.js.map +1 -1
- package/dist/cssm/components/Card/Card.module.css +1 -1
- package/dist/cssm/components/CardGrid/CardGrid.d.ts +3 -2
- package/dist/cssm/components/CardGrid/CardGrid.js +10 -8
- package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
- package/dist/cssm/components/CardGrid/CardGrid.module.css +0 -7
- package/dist/cssm/components/CardScroll/CardScroll.d.ts +3 -2
- package/dist/cssm/components/CardScroll/CardScroll.js +9 -7
- package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/cssm/components/Cell/CellDragger/CellDragger.d.ts +2 -1
- package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
- package/dist/cssm/components/Checkbox/Checkbox.js +2 -3
- package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/cssm/components/Chip/Chip.d.ts +3 -2
- package/dist/cssm/components/Chip/Chip.js +5 -5
- package/dist/cssm/components/Chip/Chip.js.map +1 -1
- package/dist/cssm/components/Chip/Chip.module.css +24 -0
- package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js +4 -2
- package/dist/cssm/components/ChipsInputBase/ChipsInputBase.js.map +1 -1
- package/dist/cssm/components/ChipsInputBase/ChipsInputBase.module.css +1 -4
- package/dist/cssm/components/ConfigProvider/ConfigProvider.d.ts +7 -0
- package/dist/cssm/components/ConfigProvider/ConfigProvider.js +32 -7
- package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/cssm/components/ConfigProvider/ConfigProviderContext.d.ts +47 -3
- package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js +6 -1
- package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
- package/dist/cssm/components/Counter/Counter.d.ts +2 -1
- package/dist/cssm/components/Counter/Counter.js.map +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelect.js +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -2
- package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
- package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/cssm/components/DatePicker/DatePicker.d.ts +2 -1
- package/dist/cssm/components/DatePicker/DatePicker.js +5 -4
- package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
- package/dist/cssm/components/Div/Div.d.ts +3 -4
- package/dist/cssm/components/Div/Div.js +5 -8
- package/dist/cssm/components/Div/Div.js.map +1 -1
- package/dist/cssm/components/DropdownIcon/DropdownIcon.d.ts +2 -1
- package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
- package/dist/cssm/components/Epic/Epic.d.ts +3 -2
- package/dist/cssm/components/Epic/Epic.js +4 -4
- package/dist/cssm/components/Epic/Epic.js.map +1 -1
- package/dist/cssm/components/FixedLayout/FixedLayout.d.ts +2 -2
- package/dist/cssm/components/FixedLayout/FixedLayout.js +5 -4
- package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
- package/dist/cssm/components/FocusTrap/FocusTrap.d.ts +2 -2
- package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
- package/dist/cssm/components/FocusVisible/FocusVisible.d.ts +2 -1
- package/dist/cssm/components/FocusVisible/FocusVisible.js +8 -6
- package/dist/cssm/components/FocusVisible/FocusVisible.js.map +1 -1
- package/dist/cssm/components/FormField/FormField.js +5 -4
- package/dist/cssm/components/FormField/FormField.js.map +1 -1
- package/dist/cssm/components/FormItem/FormItem.d.ts +6 -1
- package/dist/cssm/components/FormItem/FormItem.js +9 -7
- package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
- package/dist/cssm/components/FormItem/FormItem.module.css +3 -0
- package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.d.ts +3 -3
- package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +5 -4
- package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
- package/dist/cssm/components/FormStatus/FormStatus.d.ts +2 -2
- package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
- package/dist/cssm/components/Gradient/Gradient.d.ts +3 -2
- package/dist/cssm/components/Gradient/Gradient.js +14 -11
- package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
- package/dist/cssm/components/Group/Group.d.ts +3 -3
- package/dist/cssm/components/Group/Group.js +34 -19
- package/dist/cssm/components/Group/Group.js.map +1 -1
- package/dist/cssm/components/Group/Group.module.css +36 -4
- package/dist/cssm/components/Header/Header.d.ts +3 -3
- package/dist/cssm/components/Header/Header.js +10 -8
- package/dist/cssm/components/Header/Header.js.map +1 -1
- package/dist/cssm/components/HorizontalCell/HorizontalCell.js +6 -5
- package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
- package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +3 -3
- package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +4 -3
- package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBase.d.ts +2 -2
- package/dist/cssm/components/ImageBase/ImageBase.js +5 -5
- package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js +7 -6
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/cssm/components/InfoRow/InfoRow.d.ts +2 -1
- package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
- package/dist/cssm/components/Input/Input.module.css +15 -0
- package/dist/cssm/components/InputLike/InputLike.d.ts +3 -3
- package/dist/cssm/components/InputLike/InputLike.js +5 -5
- package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
- package/dist/cssm/components/List/List.d.ts +3 -2
- package/dist/cssm/components/List/List.js +4 -3
- package/dist/cssm/components/List/List.js.map +1 -1
- package/dist/cssm/components/MiniInfoCell/MiniInfoCell.d.ts +2 -1
- package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +14 -11
- package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
- package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
- package/dist/cssm/components/ModalCard/ModalCard.js +4 -4
- package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
- package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +3 -3
- package/dist/cssm/components/ModalCardBase/ModalCardBase.js +4 -4
- package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
- package/dist/cssm/components/ModalDismissButton/ModalDismissButton.d.ts +2 -1
- package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
- package/dist/cssm/components/ModalPage/ModalPage.d.ts +3 -2
- package/dist/cssm/components/ModalPage/ModalPage.js +8 -4
- package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
- package/dist/cssm/components/ModalPage/ModalPage.module.css +7 -3
- package/dist/cssm/components/ModalRoot/ModalRoot.js +6 -4
- package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/cssm/components/ModalRoot/ModalRoot.module.css +1 -1
- package/dist/cssm/components/ModalRoot/ModalRootContext.js +2 -1
- package/dist/cssm/components/ModalRoot/ModalRootContext.js.map +1 -1
- package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +3 -3
- package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
- package/dist/cssm/components/ModalRoot/types.d.ts +1 -0
- package/dist/cssm/components/ModalRoot/types.js.map +1 -1
- package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.d.ts +8 -0
- package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js +22 -0
- package/dist/cssm/components/NavTransitionDirectionContext/NavTransitionDirectionContext.js.map +1 -0
- package/dist/cssm/components/Pagination/Pagination.d.ts +3 -3
- package/dist/cssm/components/Pagination/Pagination.js +16 -31
- package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
- package/dist/cssm/components/Pagination/Pagination.module.css +0 -51
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPage.module.css +43 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.d.ts +12 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js +30 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts +6 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js +17 -0
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -0
- package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts +5 -0
- package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js +10 -0
- package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -0
- package/dist/cssm/components/Pagination/utils.d.ts +1 -0
- package/dist/cssm/components/Pagination/utils.js +5 -0
- package/dist/cssm/components/Pagination/utils.js.map +1 -0
- package/dist/cssm/components/Panel/Panel.d.ts +3 -3
- package/dist/cssm/components/Panel/Panel.js +6 -4
- package/dist/cssm/components/Panel/Panel.js.map +1 -1
- package/dist/cssm/components/Panel/Panel.module.css +9 -2
- package/dist/cssm/components/PanelHeader/PanelHeader.d.ts +3 -3
- package/dist/cssm/components/PanelHeader/PanelHeader.js +17 -10
- package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/cssm/components/PanelHeader/PanelHeader.module.css +0 -4
- package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.d.ts +3 -2
- package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js +4 -4
- package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
- package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.d.ts +2 -1
- package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
- package/dist/cssm/components/Placeholder/Placeholder.d.ts +24 -11
- package/dist/cssm/components/Placeholder/Placeholder.js +32 -15
- package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
- package/dist/cssm/components/PopoutRoot/PopoutRoot.d.ts +3 -3
- package/dist/cssm/components/PopoutRoot/PopoutRoot.js +12 -15
- package/dist/cssm/components/PopoutRoot/PopoutRoot.js.map +1 -1
- package/dist/cssm/components/PopoutWrapper/PopoutWrapper.d.ts +3 -2
- package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +15 -14
- package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
- package/dist/cssm/components/Popper/Popper.d.ts +7 -3
- package/dist/cssm/components/Popper/Popper.js +18 -10
- package/dist/cssm/components/Popper/Popper.js.map +1 -1
- package/dist/cssm/components/Progress/Progress.d.ts +3 -3
- package/dist/cssm/components/Progress/Progress.js +9 -8
- package/dist/cssm/components/Progress/Progress.js.map +1 -1
- package/dist/cssm/components/PromoBanner/PromoBanner.d.ts +3 -2
- package/dist/cssm/components/PromoBanner/PromoBanner.js +4 -4
- package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts +25 -0
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js +5 -2
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.d.ts +7 -7
- package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +6 -5
- package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
- package/dist/cssm/components/RadioGroup/RadioGroup.d.ts +3 -2
- package/dist/cssm/components/RadioGroup/RadioGroup.js +4 -3
- package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/cssm/components/Removable/Removable.d.ts +3 -3
- package/dist/cssm/components/Removable/Removable.js +4 -6
- package/dist/cssm/components/Removable/Removable.js.map +1 -1
- package/dist/cssm/components/RichCell/RichCell.d.ts +1 -1
- package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.d.ts +3 -1
- package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.js +6 -6
- package/dist/cssm/components/RichCell/RichCellIcon/RichCellIcon.js.map +1 -1
- package/dist/cssm/components/RichTooltip/RichTooltip.js +7 -6
- package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
- package/dist/cssm/components/Root/Root.d.ts +3 -2
- package/dist/cssm/components/Root/Root.js +12 -8
- package/dist/cssm/components/Root/Root.js.map +1 -1
- package/dist/cssm/components/RootComponent/RootComponent.d.ts +9 -0
- package/dist/cssm/components/RootComponent/RootComponent.js +11 -0
- package/dist/cssm/components/RootComponent/RootComponent.js.map +1 -0
- package/dist/cssm/components/ScrollArrow/ScrollArrow.d.ts +1 -1
- package/dist/cssm/components/ScrollArrow/ScrollArrow.js +13 -10
- package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
- package/dist/cssm/components/Search/Search.d.ts +3 -3
- package/dist/cssm/components/Search/Search.js +2 -1
- package/dist/cssm/components/Search/Search.js.map +1 -1
- package/dist/cssm/components/SegmentedControl/SegmentedControl.d.ts +3 -3
- package/dist/cssm/components/SegmentedControl/SegmentedControl.js +4 -4
- package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +3 -3
- package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
- package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
- package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +2 -2
- package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
- package/dist/cssm/components/SelectTypography/SelectTypography.d.ts +2 -2
- package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
- package/dist/cssm/components/Separator/Separator.d.ts +3 -2
- package/dist/cssm/components/Separator/Separator.js +3 -2
- package/dist/cssm/components/Separator/Separator.js.map +1 -1
- package/dist/cssm/components/Slider/Slider.d.ts +4 -3
- package/dist/cssm/components/Slider/Slider.js +3 -1
- package/dist/cssm/components/Slider/Slider.js.map +1 -1
- package/dist/cssm/components/Slider/SliderThumb/SliderThumb.d.ts +2 -1
- package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js +54 -5
- package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
- package/dist/cssm/components/Snackbar/Snackbar.d.ts +3 -2
- package/dist/cssm/components/Snackbar/Snackbar.js +8 -6
- package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/cssm/components/Spacing/Spacing.d.ts +3 -3
- package/dist/cssm/components/Spacing/Spacing.js +4 -4
- package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
- package/dist/cssm/components/Spinner/Spinner.d.ts +3 -2
- package/dist/cssm/components/Spinner/Spinner.js +5 -4
- package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
- package/dist/cssm/components/SplitCol/SplitCol.d.ts +2 -1
- package/dist/cssm/components/SplitCol/SplitCol.js +7 -5
- package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
- package/dist/cssm/components/SplitLayout/SplitLayout.d.ts +2 -2
- package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/cssm/components/SubnavigationBar/SubnavigationBar.d.ts +3 -2
- package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +6 -6
- package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
- package/dist/cssm/components/Tabbar/Tabbar.d.ts +3 -2
- package/dist/cssm/components/Tabbar/Tabbar.js +5 -4
- package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
- package/dist/cssm/components/TabbarItem/TabbarItem.d.ts +1 -1
- package/dist/cssm/components/TabbarItem/TabbarItem.js +5 -4
- package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
- package/dist/cssm/components/Tabs/Tabs.d.ts +3 -3
- package/dist/cssm/components/Tabs/Tabs.js +4 -4
- package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.d.ts +2 -1
- package/dist/cssm/components/TabsItem/TabsItem.js +6 -5
- package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cssm/components/Tappable/Tappable.d.ts +6 -1
- package/dist/cssm/components/Tappable/Tappable.js +10 -8
- package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
- package/dist/cssm/components/Tappable/Tappable.module.css +4 -0
- package/dist/cssm/components/TextTooltip/TextTooltip.js +7 -6
- package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
- package/dist/cssm/components/Tooltip/Tooltip.d.ts +1 -1
- package/dist/cssm/components/Tooltip/Tooltip.js +4 -3
- package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/cssm/components/TooltipBase/TooltipBase.d.ts +8 -1
- package/dist/cssm/components/TooltipBase/TooltipBase.js +9 -4
- package/dist/cssm/components/TooltipBase/TooltipBase.js.map +1 -1
- package/dist/cssm/components/TooltipBase/TooltipBase.module.css +0 -1
- package/dist/cssm/components/Typography/Caption/Caption.js +6 -5
- package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
- package/dist/cssm/components/Typography/Headline/Headline.js +5 -4
- package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
- package/dist/cssm/components/Typography/Title/Title.js +6 -5
- package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
- package/dist/cssm/components/Typography/Typography.d.ts +1 -1
- package/dist/cssm/components/Typography/Typography.js +10 -8
- package/dist/cssm/components/Typography/Typography.js.map +1 -1
- package/dist/cssm/components/Typography/Typography.module.css +6 -0
- package/dist/cssm/components/UsersStack/UsersStack.d.ts +3 -2
- package/dist/cssm/components/UsersStack/UsersStack.js +14 -11
- package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
- package/dist/cssm/components/View/View.d.ts +2 -1
- package/dist/cssm/components/View/View.js +7 -3
- package/dist/cssm/components/View/View.js.map +1 -1
- package/dist/cssm/components/View/ViewInfinite.d.ts +10 -3
- package/dist/cssm/components/View/ViewInfinite.js +7 -4
- package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
- package/dist/cssm/components/VisuallyHidden/VisuallyHidden.d.ts +1 -1
- package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js +4 -6
- package/dist/cssm/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
- package/dist/cssm/helpers/appearance.d.ts +4 -0
- package/dist/cssm/helpers/appearance.js +4 -1
- package/dist/cssm/helpers/appearance.js.map +1 -1
- package/dist/cssm/hooks/useAppearance.d.ts +1 -1
- package/dist/cssm/hooks/useAutoDetectAppearance.d.ts +4 -0
- package/dist/cssm/hooks/useAutoDetectAppearance.js +4 -1
- package/dist/cssm/hooks/useAutoDetectAppearance.js.map +1 -1
- package/dist/cssm/hooks/useBridgeAdaptivity.d.ts +5 -1
- package/dist/cssm/hooks/useBridgeAdaptivity.js +29 -22
- package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -1
- package/dist/cssm/hooks/useInsets.d.ts +5 -1
- package/dist/cssm/hooks/useInsets.js +15 -13
- package/dist/cssm/hooks/useInsets.js.map +1 -1
- package/dist/cssm/index.d.ts +6 -3
- package/dist/cssm/index.js +3 -1
- package/dist/cssm/index.js.map +1 -1
- package/dist/cssm/lib/adaptivity/functions.d.ts +8 -0
- package/dist/cssm/lib/adaptivity/functions.js +29 -1
- package/dist/cssm/lib/adaptivity/functions.js.map +1 -1
- package/dist/cssm/lib/appearance/index.d.ts +1 -0
- package/dist/cssm/lib/appearance/index.js +3 -0
- package/dist/cssm/lib/appearance/index.js.map +1 -0
- package/dist/cssm/lib/appearance/types.d.ts +1 -0
- package/dist/cssm/lib/appearance/types.js +3 -0
- package/dist/cssm/lib/appearance/types.js.map +1 -0
- package/dist/cssm/lib/floating/index.d.ts +1 -1
- package/dist/cssm/lib/floating/index.js +1 -1
- package/dist/cssm/lib/floating/index.js.map +1 -1
- package/dist/cssm/lib/platform.js +9 -7
- package/dist/cssm/lib/platform.js.map +1 -1
- package/dist/cssm/lib/select.d.ts +1 -1
- package/dist/cssm/lib/taptic.d.ts +4 -0
- package/dist/cssm/lib/taptic.js +4 -1
- package/dist/cssm/lib/taptic.js.map +1 -1
- package/dist/cssm/lib/utils.d.ts +2 -0
- package/dist/cssm/lib/utils.js +14 -0
- package/dist/cssm/lib/utils.js.map +1 -1
- package/dist/cssm/styles/common.css +8 -2
- package/dist/cssm/styles/themes.css +226 -133
- package/dist/cssm/types.d.ts +1 -0
- package/dist/cssm/types.js.map +1 -1
- package/dist/helpers/appearance.d.ts +4 -0
- package/dist/helpers/appearance.js +4 -1
- package/dist/helpers/appearance.js.map +1 -1
- package/dist/hooks/useAppearance.d.ts +1 -1
- package/dist/hooks/useAutoDetectAppearance.d.ts +4 -0
- package/dist/hooks/useAutoDetectAppearance.js +4 -1
- package/dist/hooks/useAutoDetectAppearance.js.map +1 -1
- package/dist/hooks/useBridgeAdaptivity.d.ts +5 -1
- package/dist/hooks/useBridgeAdaptivity.js +29 -21
- package/dist/hooks/useBridgeAdaptivity.js.map +1 -1
- package/dist/hooks/useInsets.d.ts +5 -1
- package/dist/hooks/useInsets.js +15 -12
- package/dist/hooks/useInsets.js.map +1 -1
- package/dist/index.d.ts +6 -3
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/lib/adaptivity/functions.d.ts +8 -0
- package/dist/lib/adaptivity/functions.js +29 -1
- package/dist/lib/adaptivity/functions.js.map +1 -1
- package/dist/lib/appearance/index.d.ts +1 -0
- package/dist/lib/appearance/index.js +3 -0
- package/dist/lib/appearance/index.js.map +1 -0
- package/dist/lib/appearance/types.d.ts +1 -0
- package/dist/lib/appearance/types.js +3 -0
- package/dist/lib/appearance/types.js.map +1 -0
- package/dist/lib/floating/index.d.ts +1 -1
- package/dist/lib/floating/index.js +1 -1
- package/dist/lib/floating/index.js.map +1 -1
- package/dist/lib/platform.js +11 -7
- package/dist/lib/platform.js.map +1 -1
- package/dist/lib/select.d.ts +1 -1
- package/dist/lib/taptic.d.ts +4 -0
- package/dist/lib/taptic.js +4 -1
- package/dist/lib/taptic.js.map +1 -1
- package/dist/lib/utils.d.ts +2 -0
- package/dist/lib/utils.js +16 -0
- package/dist/lib/utils.js.map +1 -1
- package/dist/types.d.ts +1 -0
- package/dist/types.js.map +1 -1
- package/dist/vkui.css +20 -19
- package/dist/vkui.css.map +1 -1
- package/dist/vkui.js.tmp +6990 -4428
- package/package.json +3 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/View/View.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { usePrevious } from '../../hooks/usePrevious';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { useWaitTransitionFinish } from '../../hooks/useWaitTransitionFinish';\nimport { blurActiveElement, canUseDOM, useDOM } from '../../lib/dom';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { animationEvent } from '../../lib/supportEvents';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport { swipeBackExcluded } from './utils';\nimport styles from './View.module.css';\n\nconst SWIPE_BACK_AREA = 70;\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: number | undefined;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\nexport let scrollsCache: ViewsScrolls = {};\n\nexport interface ViewProps extends React.HTMLAttributes<HTMLElement>, NavIdProps {\n activePanel: string;\n onTransition?(params: { isBack: boolean; from: string; to: string }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?(activePanel: string | null): void | 'prevent';\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nexport interface ViewState {\n animated: boolean;\n\n visiblePanels: string[];\n activePanel: string | null;\n isBack: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/View\n */\nexport const View = ({\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n className,\n ...restProps\n}: ViewProps) => {\n const scrolls = React.useRef(scrollsCache[getNavId({ nav, id: restProps.id }) as string] || {});\n const afterTransition = React.useRef(noop);\n\n React.useEffect(() => () => {\n const id = getNavId({ nav, id: restProps.id });\n if (id) {\n scrollsCache[id] = scrolls.current;\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(activePanelProp);\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const [swipingBack, setSwipingBack] = React.useState<boolean>(false);\n const [swipeBackPrevented, setSwipeBackPrevented] = React.useState<boolean>(false);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<string | null>(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<string | null>(null);\n const [swipeBackResult, setSwipeBackResult] = React.useState<SwipeBackResults | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = usePrevious(activePanelProp);\n const prevSwipingBack = usePrevious(swipingBack);\n const prevBrowserSwipe = usePrevious(browserSwipe);\n const prevSwipeBackResult = usePrevious(swipeBackResult);\n const prevSwipeBackPrevPanel = usePrevious(swipeBackPrevPanel);\n const prevOnTransition = usePrevious(onTransition);\n\n const panels = (React.Children.toArray(children) as React.ReactElement[]).filter(\n (panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n },\n );\n\n const disableAnimation =\n configProvider?.transitionMotionEnabled === false ||\n !splitCol?.animate ||\n platform === Platform.VKCOM;\n\n const pickPanel = (id: string | null) => {\n if (id === null) {\n return null;\n }\n return panelNodes.current[id];\n };\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.current[prevPanel] = 0;\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(undefined);\n\n afterTransition.current = () => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.current[activePanelProp] : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n };\n },\n [activePanelProp, onTransition, scroll],\n );\n\n useIsomorphicLayoutEffect(() => {\n afterTransition.current();\n afterTransition.current = noop;\n }, [afterTransition.current]);\n\n const transitionEndHandler = React.useCallback(\n (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n styles['animation-ios-next-forward'],\n styles['animation-ios-prev-back'],\n styles['animation-view-next-forward'],\n styles['animation-view-prev-back'],\n ].includes(e.animationName)) &&\n prevPanel !== null\n ) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n },\n [flushTransition, isBack, prevPanel],\n );\n\n const { waitTransitionFinish } = useWaitTransitionFinish();\n const animationFinishTimeout = useTimeout(\n transitionEndHandler,\n platform === Platform.IOS ? 600 : 300,\n );\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(\n (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e?.propertyName.includes('transform') && e?.target === pickPanel(swipeBackNextPanel))\n ) {\n switch (swipeBackResult) {\n case SwipeBackResults.fail:\n onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n onSwipeBackSuccess();\n }\n }\n },\n [onSwipeBackCancel, onSwipeBackSuccess, swipeBackNextPanel, swipeBackResult],\n );\n\n const onMoveX = (event: TouchEvent): void => {\n if (\n platform !== Platform.IOS ||\n swipeBackPrevented ||\n swipeBackExcluded(event) ||\n disableAnimation\n ) {\n return;\n }\n\n if (!configProvider?.isWebView) {\n if (\n (event.startX <= SWIPE_BACK_AREA || event.startX >= window!.innerWidth - SWIPE_BACK_AREA) &&\n !browserSwipe\n ) {\n setBrowserSwipe(true);\n }\n\n return;\n }\n\n if (!onSwipeBack || (animated && event.startX <= SWIPE_BACK_AREA)) {\n return;\n }\n\n if (!swipingBack && event.startX <= SWIPE_BACK_AREA && history && history.length > 1) {\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n setSwipeBackPrevented(true);\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.current[activePanel] = scroll?.getScroll().y;\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(event.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n\n if (swipingBack) {\n let swipeBackShift = 0;\n if (event.shiftX < 0) {\n swipeBackShift = 0;\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n swipeBackShift = window!.innerWidth;\n } else {\n swipeBackShift = event.shiftX;\n }\n setSwipeBackShift(swipeBackShift);\n }\n };\n\n const onEnd = React.useCallback(\n (event: TouchEvent): void => {\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * 1000;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackStartX + swipeBackShift > window!.innerWidth / 2) {\n setSwipeBackResult(SwipeBackResults.success);\n } else {\n setSwipeBackResult(SwipeBackResults.fail);\n }\n }\n if (swipeBackPrevented) {\n setSwipeBackPrevented(false);\n }\n },\n [\n onSwipeBackCancel,\n onSwipeBackSuccess,\n swipeBackShift,\n swipeBackStartX,\n swipingBack,\n swipeBackPrevented,\n window,\n ],\n );\n\n const calcPanelSwipeStyles = (panelId: string | undefined): React.CSSProperties => {\n if (!canUseDOM || !window) {\n return {};\n }\n\n const isPrev = panelId === swipeBackPrevPanel;\n const isNext = panelId === swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${swipeBackShift}px`;\n let nextPanelTranslate = `${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%`;\n let prevPanelShadow = (0.3 * (window.innerWidth - swipeBackShift)) / window.innerWidth;\n\n if (swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n !prevSwipingBack &&\n !prevBrowserSwipe\n ) {\n const firstLayerId = (React.Children.toArray(children) as React.ReactElement[])\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.current[prevActivePanel] = scroll?.getScroll().y;\n\n if (disableAnimation) {\n flushTransition(prevActivePanel, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel, activePanelProp]);\n setPrevPanel(prevActivePanel);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n animationFinishTimeout.set();\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevActivePanel && prevActivePanel !== activePanelProp && prevSwipingBack) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel;\n if (prevSwipeBackPrevPanel) {\n scrolls.current[prevSwipeBackPrevPanel] = 0;\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n\n afterTransition.current = () => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.current[nextPanel]);\n }\n prevOnTransition &&\n prevOnTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n };\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevSwipeBackResult && swipeBackResult) {\n waitTransitionFinish(\n pickPanel(swipeBackNextPanel),\n swipingBackTransitionEndHandler,\n platform === Platform.IOS ? 600 : 300,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (prevSwipeBackResult === SwipeBackResults.fail && !swipeBackResult && activePanel !== null) {\n scroll?.scrollTo(0, scrolls.current[activePanel]);\n }\n\n // Закончился Safari свайп\n if (prevActivePanel !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n animationFinishTimeout,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n onSwipeBackStart,\n panels,\n platform,\n prevActivePanel,\n prevBrowserSwipe,\n prevOnTransition,\n prevSwipeBackPrevPanel,\n prevSwipeBackResult,\n prevSwipingBack,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n swipingBackTransitionEndHandler,\n waitTransitionFinish,\n ]);\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles['View'],\n platform === Platform.IOS && classNames(styles['View--ios'], 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles['View--animated'],\n !disableAnimation && swipingBack && styles['View--swiping-back'],\n disableAnimation && styles['View--no-motion'],\n className,\n )}\n onMoveX={onMoveX}\n onEnd={onEnd}\n >\n <div className={styles['View__panels']}>\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n\n return (\n <div\n className={classNames(\n styles['View__panel'],\n panelId === activePanel && styles['View__panel--active'],\n panelId === prevPanel && styles['View__panel--prev'],\n panelId === nextPanel && styles['View__panel--next'],\n panelId === swipeBackPrevPanel && styles['View__panel--swipe-back-prev'],\n panelId === swipeBackNextPanel && styles['View__panel--swipe-back-next'],\n swipeBackResult === SwipeBackResults.success &&\n styles['View__panel--swipe-back-success'],\n swipeBackResult === SwipeBackResults.fail &&\n styles['View__panel--swipe-back-failed'],\n )}\n onAnimationEnd={isTransitionTarget ? transitionEndHandler : undefined}\n ref={(el) => panelId !== undefined && (panelNodes.current[panelId] = el)}\n style={calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles['View__panel-in']}\n style={{\n marginTop: compensateScroll ? -(scrolls.current[panelId] ?? 0) : undefined,\n }}\n >\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n );\n};\n"],"names":["React","classNames","noop","usePlatform","usePrevious","useTimeout","useWaitTransitionFinish","blurActiveElement","canUseDOM","useDOM","getNavId","Platform","animationEvent","useIsomorphicLayoutEffect","warnOnce","useScroll","useConfigProvider","NavTransitionProvider","useSplitCol","Touch","swipeBackExcluded","SWIPE_BACK_AREA","SwipeBackResults","fail","success","scrollsCache","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","configProvider","splitCol","scrolls","useRef","id","afterTransition","useEffect","current","panelNodes","window","document","scroll","platform","useState","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","undefined","isBack","setIsBack","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipingBack","setSwipingBack","swipeBackPrevented","setSwipeBackPrevented","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","VKCOM","pickPanel","flushTransition","useCallback","isBackTransition","scrollTo","from","to","transitionEndHandler","e","animationName","Boolean","waitTransitionFinish","animationFinishTimeout","IOS","onSwipeBackSuccess","swipingBackTransitionEndHandler","propertyName","target","onMoveX","event","isWebView","startX","innerWidth","length","payload","getScroll","y","slice","shiftX","onEnd","speed","duration","calcPanelSwipeStyles","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","firstLayerId","map","find","supported","set","Component","div","isTransitionTarget","compensateScroll","onAnimationEnd","ref","el","style","key","marginTop","entering"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/View/View.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { usePrevious } from '../../hooks/usePrevious';\nimport { useTimeout } from '../../hooks/useTimeout';\nimport { useWaitTransitionFinish } from '../../hooks/useWaitTransitionFinish';\nimport { blurActiveElement, canUseDOM, useDOM } from '../../lib/dom';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { animationEvent } from '../../lib/supportEvents';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport { swipeBackExcluded } from './utils';\nimport styles from './View.module.css';\n\nconst SWIPE_BACK_AREA = 70;\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: number | undefined;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\nexport let scrollsCache: ViewsScrolls = {};\n\nexport interface ViewProps extends HTMLAttributesWithRootRef<HTMLElement>, NavIdProps {\n activePanel: string;\n onTransition?(params: { isBack: boolean; from: string; to: string }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?(activePanel: string | null): void | 'prevent';\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nexport interface ViewState {\n animated: boolean;\n\n visiblePanels: string[];\n activePanel: string | null;\n isBack: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkcom.github.io/VKUI/#/View\n */\nexport const View = ({\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n className,\n ...restProps\n}: ViewProps) => {\n const scrolls = React.useRef(scrollsCache[getNavId({ nav, id: restProps.id }) as string] || {});\n const afterTransition = React.useRef(noop);\n\n React.useEffect(() => () => {\n const id = getNavId({ nav, id: restProps.id });\n if (id) {\n scrollsCache[id] = scrolls.current;\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(activePanelProp);\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const [swipingBack, setSwipingBack] = React.useState<boolean | undefined>(undefined);\n const [swipeBackPrevented, setSwipeBackPrevented] = React.useState<boolean>(false);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<string | null>(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<string | null>(null);\n const [swipeBackResult, setSwipeBackResult] = React.useState<SwipeBackResults | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = usePrevious(activePanelProp);\n const prevSwipingBack = usePrevious(swipingBack);\n const prevBrowserSwipe = usePrevious(browserSwipe);\n const prevSwipeBackResult = usePrevious(swipeBackResult);\n const prevSwipeBackPrevPanel = usePrevious(swipeBackPrevPanel);\n const prevOnTransition = usePrevious(onTransition);\n\n const panels = (React.Children.toArray(children) as React.ReactElement[]).filter(\n (panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n },\n );\n\n const disableAnimation =\n configProvider?.transitionMotionEnabled === false ||\n !splitCol?.animate ||\n platform === Platform.VKCOM;\n\n const pickPanel = (id: string | null) => {\n if (id === null) {\n return null;\n }\n return panelNodes.current[id];\n };\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.current[prevPanel] = 0;\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(isBackTransition);\n\n afterTransition.current = () => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.current[activePanelProp] : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n };\n },\n [activePanelProp, onTransition, scroll],\n );\n\n useIsomorphicLayoutEffect(() => {\n afterTransition.current();\n afterTransition.current = noop;\n }, [afterTransition.current]);\n\n const transitionEndHandler = React.useCallback(\n (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n styles['animation-ios-next-forward'],\n styles['animation-ios-prev-back'],\n styles['animation-view-next-forward'],\n styles['animation-view-prev-back'],\n ].includes(e.animationName)) &&\n prevPanel !== null\n ) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n },\n [flushTransition, isBack, prevPanel],\n );\n\n const { waitTransitionFinish } = useWaitTransitionFinish();\n const animationFinishTimeout = useTimeout(\n transitionEndHandler,\n platform === Platform.IOS ? 600 : 300,\n );\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(\n (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e?.propertyName.includes('transform') && e?.target === pickPanel(swipeBackNextPanel))\n ) {\n switch (swipeBackResult) {\n case SwipeBackResults.fail:\n onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n onSwipeBackSuccess();\n }\n }\n },\n [onSwipeBackCancel, onSwipeBackSuccess, swipeBackNextPanel, swipeBackResult],\n );\n\n const onMoveX = (event: TouchEvent): void => {\n if (\n platform !== Platform.IOS ||\n swipeBackPrevented ||\n swipeBackExcluded(event) ||\n disableAnimation\n ) {\n return;\n }\n\n if (!configProvider?.isWebView) {\n if (\n (event.startX <= SWIPE_BACK_AREA || event.startX >= window!.innerWidth - SWIPE_BACK_AREA) &&\n !browserSwipe\n ) {\n setBrowserSwipe(true);\n }\n\n return;\n }\n\n if (!onSwipeBack || (animated && event.startX <= SWIPE_BACK_AREA)) {\n return;\n }\n\n if (!swipingBack && event.startX <= SWIPE_BACK_AREA && history && history.length > 1) {\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n setSwipeBackPrevented(true);\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.current[activePanel] = scroll?.getScroll().y;\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(event.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n\n if (swipingBack) {\n let swipeBackShift = 0;\n if (event.shiftX < 0) {\n swipeBackShift = 0;\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n swipeBackShift = window!.innerWidth;\n } else {\n swipeBackShift = event.shiftX;\n }\n setSwipeBackShift(swipeBackShift);\n }\n };\n\n const onEnd = React.useCallback(\n (event: TouchEvent): void => {\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * 1000;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackStartX + swipeBackShift > window!.innerWidth / 2) {\n setSwipeBackResult(SwipeBackResults.success);\n } else {\n setSwipeBackResult(SwipeBackResults.fail);\n }\n }\n if (swipeBackPrevented) {\n setSwipeBackPrevented(false);\n }\n },\n [\n onSwipeBackCancel,\n onSwipeBackSuccess,\n swipeBackShift,\n swipeBackStartX,\n swipingBack,\n swipeBackPrevented,\n window,\n ],\n );\n\n const calcPanelSwipeStyles = (panelId: string | undefined): React.CSSProperties => {\n if (!canUseDOM || !window) {\n return {};\n }\n\n const isPrev = panelId === swipeBackPrevPanel;\n const isNext = panelId === swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${swipeBackShift}px`;\n let nextPanelTranslate = `${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%`;\n let prevPanelShadow = (0.3 * (window.innerWidth - swipeBackShift)) / window.innerWidth;\n\n if (swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel &&\n prevActivePanel !== activePanelProp &&\n !prevSwipingBack &&\n !prevBrowserSwipe\n ) {\n const firstLayerId = (React.Children.toArray(children) as React.ReactElement[])\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.current[prevActivePanel] = scroll?.getScroll().y;\n\n if (disableAnimation) {\n flushTransition(prevActivePanel, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel, activePanelProp]);\n setPrevPanel(prevActivePanel);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n animationFinishTimeout.set();\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevActivePanel && prevActivePanel !== activePanelProp && prevSwipingBack) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel;\n if (prevSwipeBackPrevPanel) {\n scrolls.current[prevSwipeBackPrevPanel] = 0;\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n setIsBack(true);\n\n afterTransition.current = () => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.current[nextPanel]);\n }\n prevOnTransition &&\n prevOnTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n };\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevSwipeBackResult && swipeBackResult) {\n waitTransitionFinish(\n pickPanel(swipeBackNextPanel),\n swipingBackTransitionEndHandler,\n platform === Platform.IOS ? 600 : 300,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (prevSwipeBackResult === SwipeBackResults.fail && !swipeBackResult && activePanel !== null) {\n scroll?.scrollTo(0, scrolls.current[activePanel]);\n }\n\n // Закончился Safari свайп\n if (prevActivePanel !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n animationFinishTimeout,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n onSwipeBackStart,\n panels,\n platform,\n prevActivePanel,\n prevBrowserSwipe,\n prevOnTransition,\n prevSwipeBackPrevPanel,\n prevSwipeBackResult,\n prevSwipingBack,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n swipingBackTransitionEndHandler,\n waitTransitionFinish,\n ]);\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles['View'],\n platform === Platform.IOS && classNames(styles['View--ios'], 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles['View--animated'],\n !disableAnimation && swipingBack && styles['View--swiping-back'],\n disableAnimation && styles['View--no-motion'],\n className,\n )}\n onMoveX={onMoveX}\n onEnd={onEnd}\n >\n <div className={styles['View__panels']}>\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n\n return (\n <div\n className={classNames(\n styles['View__panel'],\n panelId === activePanel && styles['View__panel--active'],\n panelId === prevPanel && styles['View__panel--prev'],\n panelId === nextPanel && styles['View__panel--next'],\n panelId === swipeBackPrevPanel && styles['View__panel--swipe-back-prev'],\n panelId === swipeBackNextPanel && styles['View__panel--swipe-back-next'],\n swipeBackResult === SwipeBackResults.success &&\n styles['View__panel--swipe-back-success'],\n swipeBackResult === SwipeBackResults.fail &&\n styles['View__panel--swipe-back-failed'],\n )}\n onAnimationEnd={isTransitionTarget ? transitionEndHandler : undefined}\n ref={(el) => panelId !== undefined && (panelNodes.current[panelId] = el)}\n style={calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles['View__panel-in']}\n style={{\n marginTop: compensateScroll ? -(scrolls.current[panelId] ?? 0) : undefined,\n }}\n >\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n );\n};\n"],"names":["React","classNames","noop","usePlatform","usePrevious","useTimeout","useWaitTransitionFinish","blurActiveElement","canUseDOM","useDOM","getNavId","Platform","animationEvent","useIsomorphicLayoutEffect","warnOnce","useScroll","useConfigProvider","NavTransitionProvider","NavTransitionDirectionProvider","useSplitCol","Touch","swipeBackExcluded","SWIPE_BACK_AREA","SwipeBackResults","fail","success","scrollsCache","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","configProvider","splitCol","scrolls","useRef","id","afterTransition","useEffect","current","panelNodes","window","document","scroll","platform","useState","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","undefined","isBack","setIsBack","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipingBack","setSwipingBack","swipeBackPrevented","setSwipeBackPrevented","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","VKCOM","pickPanel","flushTransition","useCallback","isBackTransition","scrollTo","from","to","transitionEndHandler","e","animationName","Boolean","waitTransitionFinish","animationFinishTimeout","IOS","onSwipeBackSuccess","swipingBackTransitionEndHandler","propertyName","target","onMoveX","event","isWebView","startX","innerWidth","length","payload","getScroll","y","slice","shiftX","onEnd","speed","duration","calcPanelSwipeStyles","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","firstLayerId","map","find","supported","set","Component","div","isTransitionTarget","compensateScroll","onAnimationEnd","ref","el","style","key","marginTop","entering"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { NavIdProps } from '../../lib/getNavId';
|
|
3
|
-
import { HasPlatform } from '../../types';
|
|
3
|
+
import { HasPlatform, HTMLAttributesWithRootRef } from '../../types';
|
|
4
4
|
import { ScrollContextInterface } from '../AppRoot/ScrollContext';
|
|
5
5
|
import { ConfigProviderContextInterface } from '../ConfigProvider/ConfigProviderContext';
|
|
6
6
|
import { SplitColContextProps } from '../SplitCol/SplitColContext';
|
|
@@ -8,11 +8,18 @@ declare enum SwipeBackResults {
|
|
|
8
8
|
fail = 1,
|
|
9
9
|
success = 2
|
|
10
10
|
}
|
|
11
|
+
interface Scrolls {
|
|
12
|
+
[index: string]: Array<number | undefined>;
|
|
13
|
+
}
|
|
14
|
+
interface ViewsScrolls {
|
|
15
|
+
[index: string]: Scrolls;
|
|
16
|
+
}
|
|
17
|
+
export declare let scrollsCache: ViewsScrolls;
|
|
11
18
|
export type TransitionParams = {
|
|
12
19
|
from: string | null;
|
|
13
20
|
to: string | null;
|
|
14
21
|
};
|
|
15
|
-
export interface ViewInfiniteProps extends
|
|
22
|
+
export interface ViewInfiniteProps extends HTMLAttributesWithRootRef<HTMLElement>, HasPlatform, NavIdProps {
|
|
16
23
|
activePanel: string;
|
|
17
24
|
onTransition?(params: TransitionParams & {
|
|
18
25
|
isBack: boolean;
|
|
@@ -51,7 +58,7 @@ export interface ViewInfiniteState {
|
|
|
51
58
|
isBack?: boolean;
|
|
52
59
|
prevPanel: string | null;
|
|
53
60
|
nextPanel: string | null;
|
|
54
|
-
swipingBack
|
|
61
|
+
swipingBack?: boolean;
|
|
55
62
|
swipeBackPrevented: boolean;
|
|
56
63
|
swipeBackStartX: number;
|
|
57
64
|
swipeBackShift: number;
|
|
@@ -20,6 +20,7 @@ import { warnOnce } from "../../lib/warnOnce";
|
|
|
20
20
|
import { ScrollContext } from "../AppRoot/ScrollContext";
|
|
21
21
|
import { ConfigProviderContext } from "../ConfigProvider/ConfigProviderContext";
|
|
22
22
|
import { NavTransitionProvider } from "../NavTransitionContext/NavTransitionContext";
|
|
23
|
+
import { NavTransitionDirectionProvider } from "../NavTransitionDirectionContext/NavTransitionDirectionContext";
|
|
23
24
|
import { SplitColContext } from "../SplitCol/SplitColContext";
|
|
24
25
|
import { Touch } from "../Touch/Touch";
|
|
25
26
|
import { swipeBackExcluded } from "./utils";
|
|
@@ -29,7 +30,7 @@ var SwipeBackResults;
|
|
|
29
30
|
SwipeBackResults[SwipeBackResults["fail"] = 1] = "fail";
|
|
30
31
|
SwipeBackResults[SwipeBackResults["success"] = 2] = "success";
|
|
31
32
|
})(SwipeBackResults || (SwipeBackResults = {}));
|
|
32
|
-
var scrollsCache = {};
|
|
33
|
+
export var scrollsCache = {};
|
|
33
34
|
var _React_Component;
|
|
34
35
|
var ViewInfiniteComponent = /*#__PURE__*/ function(_superClass) {
|
|
35
36
|
"use strict";
|
|
@@ -153,7 +154,7 @@ var ViewInfiniteComponent = /*#__PURE__*/ function(_superClass) {
|
|
|
153
154
|
isBack: undefined,
|
|
154
155
|
prevPanel: null,
|
|
155
156
|
nextPanel: null,
|
|
156
|
-
swipingBack:
|
|
157
|
+
swipingBack: undefined,
|
|
157
158
|
swipeBackPrevented: false,
|
|
158
159
|
swipeBackStartX: 0,
|
|
159
160
|
swipeBackShift: 0,
|
|
@@ -367,7 +368,7 @@ var ViewInfiniteComponent = /*#__PURE__*/ function(_superClass) {
|
|
|
367
368
|
],
|
|
368
369
|
activePanel: activePanel,
|
|
369
370
|
animated: false,
|
|
370
|
-
isBack:
|
|
371
|
+
isBack: isBack
|
|
371
372
|
}, function() {
|
|
372
373
|
var _this_props_scroll;
|
|
373
374
|
(_this_props_scroll = _this.props.scroll) === null || _this_props_scroll === void 0 ? void 0 : _this_props_scroll.scrollTo(0, isBack ? scrollPosition : 0);
|
|
@@ -501,9 +502,11 @@ var ViewInfiniteComponent = /*#__PURE__*/ function(_superClass) {
|
|
|
501
502
|
style: {
|
|
502
503
|
marginTop: compensateScroll ? -scroll : undefined
|
|
503
504
|
}
|
|
505
|
+
}, /*#__PURE__*/ React.createElement(NavTransitionDirectionProvider, {
|
|
506
|
+
isBack: swipingBack || isBack
|
|
504
507
|
}, /*#__PURE__*/ React.createElement(NavTransitionProvider, {
|
|
505
508
|
entering: panelId === nextPanel || panelId === swipeBackNextPanel
|
|
506
|
-
}, panel)));
|
|
509
|
+
}, panel))));
|
|
507
510
|
})));
|
|
508
511
|
}
|
|
509
512
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { canUseDOM, DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { animationEvent, transitionEvent } from '../../lib/supportEvents';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasPlatform } from '../../types';\nimport { ScrollContext, ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { SplitColContext, SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport { swipeBackExcluded } from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: Array<number | undefined>;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nlet scrollsCache: ViewsScrolls = {};\n\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends React.HTMLAttributes<HTMLElement>,\n HasPlatform,\n NavIdProps {\n activePanel: string;\n onTransition?(params: TransitionParams & { isBack: boolean }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n */\n onSwipeBackStart?(activePanel: string | null): void | 'prevent';\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n isBackCheck?(params: TransitionParams): boolean;\n /**\n * @ignore\n */\n splitCol?: SplitColContextProps;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n /**\n * @ignore\n */\n scroll?: ScrollContextInterface;\n}\n\nexport interface ViewInfiniteState {\n animated: boolean;\n\n visiblePanels: Array<string | null>;\n activePanel: string | null;\n isBack?: boolean;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack: boolean;\n swipeBackPrevented: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\n> {\n private static readonly SWIPE_BACK_AREA = 70;\n\n constructor(props: ViewInfiniteProps) {\n super(props);\n\n this.state = {\n animated: false,\n\n visiblePanels: [props.activePanel],\n activePanel: props.activePanel,\n isBack: undefined,\n prevPanel: null,\n nextPanel: null,\n\n swipingBack: false,\n swipeBackPrevented: false,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n swipeBackNextPanel: null,\n swipeBackPrevPanel: null,\n swipeBackResult: null,\n\n browserSwipe: false,\n };\n }\n\n static defaultProps: Partial<ViewInfiniteProps> = {\n history: [],\n };\n\n private scrolls = scrollsCache[getNavId(this.props, warn) as string] || {};\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private animationFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n get panels() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache[id] = this.scrolls;\n }\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n }\n\n componentDidUpdate(prevProps: ViewInfiniteProps, prevState: ViewInfiniteState) {\n // Нужен переход\n if (\n prevProps.activePanel !== this.props.activePanel &&\n !prevState.swipingBack &&\n !prevState.browserSwipe\n ) {\n let isBack = false;\n\n if (this.props.isBackCheck) {\n isBack = this.props.isBackCheck({\n from: prevProps.activePanel,\n to: this.props.activePanel,\n });\n } else {\n const firstLayerId = this.panels\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevProps.activePanel || id === this.props.activePanel);\n isBack = firstLayerId === this.props.activePanel;\n }\n\n this.blurActiveElement();\n\n const prevScrolls = this.scrolls[prevProps.activePanel] || [];\n const scrolls = {\n ...this.scrolls,\n [prevProps.activePanel]: [...prevScrolls, this.props.scroll?.getScroll().y],\n };\n this.scrolls = scrolls;\n\n if (this.shouldDisableTransitionMotion()) {\n this.flushTransition(prevProps.activePanel, isBack);\n } else {\n this.setState({\n visiblePanels: [prevProps.activePanel, this.props.activePanel],\n prevPanel: prevProps.activePanel,\n nextPanel: this.props.activePanel,\n activePanel: null,\n animated: true,\n isBack,\n });\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n this.animationFinishTimeout = setTimeout(\n this.transitionEndHandler,\n this.props.platform === Platform.ANDROID || this.props.platform === Platform.VKCOM\n ? 300\n : 600,\n );\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevProps.activePanel !== this.props.activePanel && prevState.swipingBack) {\n const nextPanel = this.state.swipeBackNextPanel;\n const prevPanel = this.state.swipeBackPrevPanel;\n let scrollPosition: undefined | number = undefined;\n\n this.scrolls = {\n ...this.scrolls,\n };\n\n if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls[prevPanel] || [])].slice(0, -1);\n this.scrolls[prevPanel] = prevPanelScrolls;\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls[nextPanel] || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls[nextPanel] = newPanelScrolls;\n }\n\n this.setState(\n {\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n activePanel: nextPanel,\n visiblePanels: [nextPanel],\n },\n () => {\n this.props.scroll?.scrollTo(0, scrollPosition);\n prevProps.onTransition &&\n prevProps.onTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n },\n );\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevState.swipeBackResult && this.state.swipeBackResult) {\n this.waitTransitionFinish(\n this.pickPanel(this.state.swipeBackNextPanel),\n this.swipingBackTransitionEndHandler,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevState.swipeBackResult === SwipeBackResults.fail &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls[this.state.activePanel] || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls = {\n ...this.scrolls,\n [this.state.activePanel]: newPanelScrolls,\n };\n\n this.props.scroll?.scrollTo(0, scrollPosition);\n }\n\n // Закончился Safari свайп\n if (prevProps.activePanel !== this.props.activePanel && this.state.browserSwipe) {\n this.setState({\n browserSwipe: false,\n nextPanel: null,\n prevPanel: null,\n animated: false,\n visiblePanels: [this.props.activePanel],\n activePanel: this.props.activePanel,\n });\n }\n }\n\n shouldDisableTransitionMotion(): boolean {\n return (\n this.props.configProvider?.transitionMotionEnabled === false ||\n !this.props.splitCol?.animate ||\n this.props.platform === Platform.VKCOM\n );\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (transitionEvent.supported && transitionEvent.name && elem) {\n elem.removeEventListener(\n transitionEvent.name as keyof HTMLElementEventMap,\n eventHandler as EventListener,\n );\n elem.addEventListener(\n transitionEvent.name as keyof HTMLElementEventMap,\n eventHandler as EventListener,\n );\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === Platform.ANDROID || this.props.platform === Platform.VKCOM\n ? 300\n : 600,\n );\n }\n }\n\n blurActiveElement(): void {\n if (typeof this.window !== 'undefined' && this.document?.activeElement) {\n (this.document.activeElement as HTMLElement).blur();\n }\n }\n\n pickPanel(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.panelNodes[id];\n }\n\n flushTransition(prevPanel: string, isBack: boolean) {\n const activePanel = this.props.activePanel;\n\n const prevPanelScrolls = [...(this.scrolls[prevPanel] || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls[activePanel] || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls = {\n ...this.scrolls,\n [prevPanel]: prevPanelScrolls,\n [activePanel]: newPanelScrolls,\n };\n }\n\n this.setState(\n {\n prevPanel: null,\n nextPanel: null,\n visiblePanels: [activePanel],\n activePanel: activePanel,\n animated: false,\n isBack: undefined,\n },\n () => {\n this.props.scroll?.scrollTo(0, isBack ? scrollPosition : 0);\n this.props.onTransition &&\n this.props.onTransition({ isBack, from: prevPanel, to: activePanel });\n },\n );\n }\n\n transitionEndHandler = (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n styles['animation-ios-next-forward'],\n styles['animation-ios-prev-back'],\n styles['animation-view-next-forward'],\n styles['animation-view-prev-back'],\n ].includes(e.animationName)) &&\n this.state.prevPanel !== null\n ) {\n this.flushTransition(this.state.prevPanel, Boolean(this.state.isBack));\n }\n };\n\n swipingBackTransitionEndHandler = (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e.propertyName.includes('transform') &&\n e.target === this.pickPanel(this.state.swipeBackNextPanel))\n ) {\n switch (this.state.swipeBackResult) {\n case SwipeBackResults.fail:\n this.onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n this.onSwipeBackSuccess();\n }\n }\n };\n\n onSwipeBackSuccess(): void {\n this.props.onSwipeBack && this.props.onSwipeBack();\n }\n\n onSwipeBackCancel(): void {\n this.props.onSwipeBackCancel && this.props.onSwipeBackCancel();\n this.setState({\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n });\n }\n\n onMoveX = (event: TouchEvent): void => {\n if (\n !this.window ||\n this.props.platform !== Platform.IOS ||\n this.state.swipeBackPrevented ||\n swipeBackExcluded(event) ||\n this.shouldDisableTransitionMotion()\n ) {\n return;\n }\n\n if (!this.props.configProvider?.isWebView) {\n if (\n (event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA ||\n event.startX >= this.window.innerWidth - ViewInfiniteComponent.SWIPE_BACK_AREA) &&\n !this.state.browserSwipe\n ) {\n this.setState({ browserSwipe: true });\n }\n\n return;\n }\n\n if (\n !this.props.onSwipeBack ||\n (this.state.animated && event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA)\n ) {\n return;\n }\n\n if (\n !this.state.swipingBack &&\n event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA &&\n this.props.history &&\n this.props.history.length > 1\n ) {\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.setState({ swipeBackPrevented: true });\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls[this.state.activePanel] || [];\n this.scrolls = {\n ...this.scrolls,\n [this.state.activePanel]: [...prevScrolls, this.props.scroll?.getScroll().y],\n };\n }\n\n this.setState({\n swipingBack: true,\n swipeBackStartX: event.startX,\n swipeBackPrevPanel: this.state.activePanel,\n swipeBackNextPanel: this.props.history.slice(-2)[0],\n });\n }\n\n if (this.state.swipingBack) {\n let swipeBackShift;\n if (event.shiftX < 0) {\n swipeBackShift = 0;\n } else if (event.shiftX > this.window.innerWidth - this.state.swipeBackStartX) {\n swipeBackShift = this.window.innerWidth;\n } else {\n swipeBackShift = event.shiftX;\n }\n this.setState({ swipeBackShift });\n }\n };\n\n onEnd = (event: TouchEvent): void => {\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * 1000;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (\n speed > 250 ||\n this.state.swipeBackStartX + this.state.swipeBackShift > this.window.innerWidth / 2\n ) {\n this.setState({ swipeBackResult: SwipeBackResults.success });\n } else {\n this.setState({ swipeBackResult: SwipeBackResults.fail });\n }\n }\n if (this.state.swipeBackPrevented) {\n this.setState({ swipeBackPrevented: false });\n }\n };\n\n calcPanelSwipeStyles(panelId: string | undefined): React.CSSProperties {\n if (!canUseDOM || !this.window) {\n return {};\n }\n\n const isPrev = panelId === this.state.swipeBackPrevPanel;\n const isNext = panelId === this.state.swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || this.state.swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${this.state.swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (this.state.swipeBackShift * 100) / this.window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (this.window.innerWidth - this.state.swipeBackShift)) / this.window.innerWidth;\n\n if (this.state.swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n }\n\n render() {\n const {\n platform,\n activePanel: _1,\n splitCol,\n configProvider,\n history,\n id,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel,\n window,\n document,\n scroll,\n isBackCheck,\n className,\n ...restProps\n } = this.props;\n const {\n prevPanel,\n nextPanel,\n activePanel,\n isBack,\n animated,\n swipeBackPrevPanel,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n } = this.state;\n\n const panels = this.panels\n .filter((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && this.state.visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n })\n .sort((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrevPanel = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isNextPanel = panelId === nextPanel || panelId === swipeBackNextPanel;\n\n if (isNextPanel) {\n return swipingBack || this.state.isBack ? -1 : 1;\n }\n\n if (isPrevPanel) {\n return swipingBack || this.state.isBack ? 1 : -1;\n }\n\n return 0;\n });\n\n const disableAnimation = this.shouldDisableTransitionMotion();\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles['View'],\n platform === Platform.IOS && classNames(styles['View--ios'], 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles['View--animated'],\n !disableAnimation && this.state.swipingBack && styles['View--swiping-back'],\n disableAnimation && styles['View--no-motion'],\n className,\n )}\n onMoveX={this.onMoveX}\n onEnd={this.onEnd}\n >\n <div className={styles['View__panels']}>\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const scrollList = (panelId && this.scrolls[panelId]) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles['View__panel'],\n panelId === activePanel && styles['View__panel--active'],\n panelId === prevPanel && styles['View__panel--prev'],\n panelId === nextPanel && styles['View__panel--next'],\n panelId === swipeBackPrevPanel && styles['View__panel--swipe-back-prev'],\n panelId === swipeBackNextPanel && styles['View__panel--swipe-back-next'],\n swipeBackResult === SwipeBackResults.success &&\n styles['View__panel--swipe-back-success'],\n swipeBackResult === SwipeBackResults.fail &&\n styles['View__panel--swipe-back-failed'],\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => panelId !== undefined && (this.panelNodes[panelId] = el)}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles['View__panel-in']}\n style={{ marginTop: compensateScroll ? -scroll : undefined }}\n >\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n );\n }\n}\n\nexport const ViewInfinite = withContext(\n withContext(\n withContext(\n withPlatform(withDOM<ViewInfiniteProps>(ViewInfiniteComponent)),\n SplitColContext,\n 'splitCol',\n ),\n ConfigProviderContext,\n 'configProvider',\n ),\n ScrollContext,\n 'scroll',\n);\n"],"names":["React","classNames","withContext","withPlatform","canUseDOM","withDOM","getNavId","Platform","animationEvent","transitionEvent","warnOnce","ScrollContext","ConfigProviderContext","NavTransitionProvider","SplitColContext","Touch","swipeBackExcluded","warn","SwipeBackResults","fail","success","scrollsCache","ViewInfiniteComponent","props","scrolls","transitionFinishTimeout","undefined","animationFinishTimeout","panelNodes","transitionEndHandler","e","includes","animationName","state","prevPanel","flushTransition","Boolean","isBack","swipingBackTransitionEndHandler","propertyName","target","pickPanel","swipeBackNextPanel","swipeBackResult","onSwipeBackCancel","onSwipeBackSuccess","onMoveX","event","window","platform","IOS","swipeBackPrevented","shouldDisableTransitionMotion","configProvider","isWebView","startX","SWIPE_BACK_AREA","innerWidth","browserSwipe","setState","onSwipeBack","animated","swipingBack","history","length","onSwipeBackStart","payload","activePanel","blurActiveElement","prevScrolls","scroll","getScroll","y","swipeBackStartX","swipeBackPrevPanel","slice","swipeBackShift","shiftX","onEnd","speed","duration","visiblePanels","nextPanel","document","panels","Children","toArray","children","componentWillUnmount","id","clearTimeout","componentDidUpdate","prevProps","prevState","isBackCheck","from","to","firstLayerId","map","panel","find","supported","setTimeout","ANDROID","VKCOM","scrollPosition","prevPanelScrolls","newPanelScrolls","pop","scrollTo","onTransition","waitTransitionFinish","transitionMotionEnabled","splitCol","animate","elem","eventHandler","name","removeEventListener","addEventListener","activeElement","blur","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","render","_1","nav","className","restProps","filter","sort","isPrevPanel","isNextPanel","disableAnimation","Component","div","compensateScroll","isTransitionTarget","scrollList","onAnimationEnd","ref","el","style","key","marginTop","entering","defaultProps","ViewInfinite"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { canUseDOM, DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId, NavIdProps } from '../../lib/getNavId';\nimport { Platform } from '../../lib/platform';\nimport { animationEvent, transitionEvent } from '../../lib/supportEvents';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HasPlatform, HTMLAttributesWithRootRef } from '../../types';\nimport { ScrollContext, ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { SplitColContext, SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { Touch, TouchEvent } from '../Touch/Touch';\nimport { swipeBackExcluded } from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\nenum SwipeBackResults {\n fail = 1,\n success,\n}\n\ninterface Scrolls {\n [index: string]: Array<number | undefined>;\n}\n\ninterface ViewsScrolls {\n [index: string]: Scrolls;\n}\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nexport let scrollsCache: ViewsScrolls = {};\n\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends HTMLAttributesWithRootRef<HTMLElement>,\n HasPlatform,\n NavIdProps {\n activePanel: string;\n onTransition?(params: TransitionParams & { isBack: boolean }): void;\n /**\n * callback свайпа назад\n */\n onSwipeBack?(): void;\n /**\n * callback начала анимации свайпа назад.\n */\n onSwipeBackStart?(activePanel: string | null): void | 'prevent';\n /**\n * callback завершения анимации отмененного пользователем свайпа\n */\n onSwipeBackCancel?(): void;\n history?: string[];\n isBackCheck?(params: TransitionParams): boolean;\n /**\n * @ignore\n */\n splitCol?: SplitColContextProps;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface;\n /**\n * @ignore\n */\n scroll?: ScrollContextInterface;\n}\n\nexport interface ViewInfiniteState {\n animated: boolean;\n\n visiblePanels: Array<string | null>;\n activePanel: string | null;\n isBack?: boolean;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack?: boolean;\n swipeBackPrevented: boolean;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: SwipeBackResults | null;\n\n browserSwipe: boolean;\n}\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\n> {\n private static readonly SWIPE_BACK_AREA = 70;\n\n constructor(props: ViewInfiniteProps) {\n super(props);\n\n this.state = {\n animated: false,\n\n visiblePanels: [props.activePanel],\n activePanel: props.activePanel,\n isBack: undefined,\n prevPanel: null,\n nextPanel: null,\n\n swipingBack: undefined,\n swipeBackPrevented: false,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n swipeBackNextPanel: null,\n swipeBackPrevPanel: null,\n swipeBackResult: null,\n\n browserSwipe: false,\n };\n }\n\n static defaultProps: Partial<ViewInfiniteProps> = {\n history: [],\n };\n\n private scrolls = scrollsCache[getNavId(this.props, warn) as string] || {};\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private animationFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n get panels() {\n return React.Children.toArray(this.props.children) as React.ReactElement[];\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache[id] = this.scrolls;\n }\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n }\n\n componentDidUpdate(prevProps: ViewInfiniteProps, prevState: ViewInfiniteState) {\n // Нужен переход\n if (\n prevProps.activePanel !== this.props.activePanel &&\n !prevState.swipingBack &&\n !prevState.browserSwipe\n ) {\n let isBack = false;\n\n if (this.props.isBackCheck) {\n isBack = this.props.isBackCheck({\n from: prevProps.activePanel,\n to: this.props.activePanel,\n });\n } else {\n const firstLayerId = this.panels\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevProps.activePanel || id === this.props.activePanel);\n isBack = firstLayerId === this.props.activePanel;\n }\n\n this.blurActiveElement();\n\n const prevScrolls = this.scrolls[prevProps.activePanel] || [];\n const scrolls = {\n ...this.scrolls,\n [prevProps.activePanel]: [...prevScrolls, this.props.scroll?.getScroll().y],\n };\n this.scrolls = scrolls;\n\n if (this.shouldDisableTransitionMotion()) {\n this.flushTransition(prevProps.activePanel, isBack);\n } else {\n this.setState({\n visiblePanels: [prevProps.activePanel, this.props.activePanel],\n prevPanel: prevProps.activePanel,\n nextPanel: this.props.activePanel,\n activePanel: null,\n animated: true,\n isBack,\n });\n\n // Фолбек анимации перехода\n if (!animationEvent.supported) {\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n this.animationFinishTimeout = setTimeout(\n this.transitionEndHandler,\n this.props.platform === Platform.ANDROID || this.props.platform === Platform.VKCOM\n ? 300\n : 600,\n );\n }\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevProps.activePanel !== this.props.activePanel && prevState.swipingBack) {\n const nextPanel = this.state.swipeBackNextPanel;\n const prevPanel = this.state.swipeBackPrevPanel;\n let scrollPosition: undefined | number = undefined;\n\n this.scrolls = {\n ...this.scrolls,\n };\n\n if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls[prevPanel] || [])].slice(0, -1);\n this.scrolls[prevPanel] = prevPanelScrolls;\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls[nextPanel] || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls[nextPanel] = newPanelScrolls;\n }\n\n this.setState(\n {\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n activePanel: nextPanel,\n visiblePanels: [nextPanel],\n },\n () => {\n this.props.scroll?.scrollTo(0, scrollPosition);\n prevProps.onTransition &&\n prevProps.onTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n },\n );\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevState.swipeBackResult && this.state.swipeBackResult) {\n this.waitTransitionFinish(\n this.pickPanel(this.state.swipeBackNextPanel),\n this.swipingBackTransitionEndHandler,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevState.swipeBackResult === SwipeBackResults.fail &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls[this.state.activePanel] || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls = {\n ...this.scrolls,\n [this.state.activePanel]: newPanelScrolls,\n };\n\n this.props.scroll?.scrollTo(0, scrollPosition);\n }\n\n // Закончился Safari свайп\n if (prevProps.activePanel !== this.props.activePanel && this.state.browserSwipe) {\n this.setState({\n browserSwipe: false,\n nextPanel: null,\n prevPanel: null,\n animated: false,\n visiblePanels: [this.props.activePanel],\n activePanel: this.props.activePanel,\n });\n }\n }\n\n shouldDisableTransitionMotion(): boolean {\n return (\n this.props.configProvider?.transitionMotionEnabled === false ||\n !this.props.splitCol?.animate ||\n this.props.platform === Platform.VKCOM\n );\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (transitionEvent.supported && transitionEvent.name && elem) {\n elem.removeEventListener(\n transitionEvent.name as keyof HTMLElementEventMap,\n eventHandler as EventListener,\n );\n elem.addEventListener(\n transitionEvent.name as keyof HTMLElementEventMap,\n eventHandler as EventListener,\n );\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === Platform.ANDROID || this.props.platform === Platform.VKCOM\n ? 300\n : 600,\n );\n }\n }\n\n blurActiveElement(): void {\n if (typeof this.window !== 'undefined' && this.document?.activeElement) {\n (this.document.activeElement as HTMLElement).blur();\n }\n }\n\n pickPanel(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.panelNodes[id];\n }\n\n flushTransition(prevPanel: string, isBack: boolean) {\n const activePanel = this.props.activePanel;\n\n const prevPanelScrolls = [...(this.scrolls[prevPanel] || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls[activePanel] || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls = {\n ...this.scrolls,\n [prevPanel]: prevPanelScrolls,\n [activePanel]: newPanelScrolls,\n };\n }\n\n this.setState(\n {\n prevPanel: null,\n nextPanel: null,\n visiblePanels: [activePanel],\n activePanel: activePanel,\n animated: false,\n isBack,\n },\n () => {\n this.props.scroll?.scrollTo(0, isBack ? scrollPosition : 0);\n this.props.onTransition &&\n this.props.onTransition({ isBack, from: prevPanel, to: activePanel });\n },\n );\n }\n\n transitionEndHandler = (e?: React.AnimationEvent): void => {\n if (\n (!e ||\n [\n styles['animation-ios-next-forward'],\n styles['animation-ios-prev-back'],\n styles['animation-view-next-forward'],\n styles['animation-view-prev-back'],\n ].includes(e.animationName)) &&\n this.state.prevPanel !== null\n ) {\n this.flushTransition(this.state.prevPanel, Boolean(this.state.isBack));\n }\n };\n\n swipingBackTransitionEndHandler = (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e.propertyName.includes('transform') &&\n e.target === this.pickPanel(this.state.swipeBackNextPanel))\n ) {\n switch (this.state.swipeBackResult) {\n case SwipeBackResults.fail:\n this.onSwipeBackCancel();\n break;\n case SwipeBackResults.success:\n this.onSwipeBackSuccess();\n }\n }\n };\n\n onSwipeBackSuccess(): void {\n this.props.onSwipeBack && this.props.onSwipeBack();\n }\n\n onSwipeBackCancel(): void {\n this.props.onSwipeBackCancel && this.props.onSwipeBackCancel();\n this.setState({\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n });\n }\n\n onMoveX = (event: TouchEvent): void => {\n if (\n !this.window ||\n this.props.platform !== Platform.IOS ||\n this.state.swipeBackPrevented ||\n swipeBackExcluded(event) ||\n this.shouldDisableTransitionMotion()\n ) {\n return;\n }\n\n if (!this.props.configProvider?.isWebView) {\n if (\n (event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA ||\n event.startX >= this.window.innerWidth - ViewInfiniteComponent.SWIPE_BACK_AREA) &&\n !this.state.browserSwipe\n ) {\n this.setState({ browserSwipe: true });\n }\n\n return;\n }\n\n if (\n !this.props.onSwipeBack ||\n (this.state.animated && event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA)\n ) {\n return;\n }\n\n if (\n !this.state.swipingBack &&\n event.startX <= ViewInfiniteComponent.SWIPE_BACK_AREA &&\n this.props.history &&\n this.props.history.length > 1\n ) {\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.setState({ swipeBackPrevented: true });\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls[this.state.activePanel] || [];\n this.scrolls = {\n ...this.scrolls,\n [this.state.activePanel]: [...prevScrolls, this.props.scroll?.getScroll().y],\n };\n }\n\n this.setState({\n swipingBack: true,\n swipeBackStartX: event.startX,\n swipeBackPrevPanel: this.state.activePanel,\n swipeBackNextPanel: this.props.history.slice(-2)[0],\n });\n }\n\n if (this.state.swipingBack) {\n let swipeBackShift;\n if (event.shiftX < 0) {\n swipeBackShift = 0;\n } else if (event.shiftX > this.window.innerWidth - this.state.swipeBackStartX) {\n swipeBackShift = this.window.innerWidth;\n } else {\n swipeBackShift = event.shiftX;\n }\n this.setState({ swipeBackShift });\n }\n };\n\n onEnd = (event: TouchEvent): void => {\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * 1000;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (\n speed > 250 ||\n this.state.swipeBackStartX + this.state.swipeBackShift > this.window.innerWidth / 2\n ) {\n this.setState({ swipeBackResult: SwipeBackResults.success });\n } else {\n this.setState({ swipeBackResult: SwipeBackResults.fail });\n }\n }\n if (this.state.swipeBackPrevented) {\n this.setState({ swipeBackPrevented: false });\n }\n };\n\n calcPanelSwipeStyles(panelId: string | undefined): React.CSSProperties {\n if (!canUseDOM || !this.window) {\n return {};\n }\n\n const isPrev = panelId === this.state.swipeBackPrevPanel;\n const isNext = panelId === this.state.swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || this.state.swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${this.state.swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (this.state.swipeBackShift * 100) / this.window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (this.window.innerWidth - this.state.swipeBackShift)) / this.window.innerWidth;\n\n if (this.state.swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n WebkitTransform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n }\n\n render() {\n const {\n platform,\n activePanel: _1,\n splitCol,\n configProvider,\n history,\n id,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel,\n window,\n document,\n scroll,\n isBackCheck,\n className,\n ...restProps\n } = this.props;\n const {\n prevPanel,\n nextPanel,\n activePanel,\n isBack,\n animated,\n swipeBackPrevPanel,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n } = this.state;\n\n const panels = this.panels\n .filter((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && this.state.visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n })\n .sort((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrevPanel = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isNextPanel = panelId === nextPanel || panelId === swipeBackNextPanel;\n\n if (isNextPanel) {\n return swipingBack || this.state.isBack ? -1 : 1;\n }\n\n if (isPrevPanel) {\n return swipingBack || this.state.isBack ? 1 : -1;\n }\n\n return 0;\n });\n\n const disableAnimation = this.shouldDisableTransitionMotion();\n\n return (\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles['View'],\n platform === Platform.IOS && classNames(styles['View--ios'], 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles['View--animated'],\n !disableAnimation && this.state.swipingBack && styles['View--swiping-back'],\n disableAnimation && styles['View--no-motion'],\n className,\n )}\n onMoveX={this.onMoveX}\n onEnd={this.onEnd}\n >\n <div className={styles['View__panels']}>\n {panels.map((panel: React.ReactElement) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const scrollList = (panelId && this.scrolls[panelId]) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles['View__panel'],\n panelId === activePanel && styles['View__panel--active'],\n panelId === prevPanel && styles['View__panel--prev'],\n panelId === nextPanel && styles['View__panel--next'],\n panelId === swipeBackPrevPanel && styles['View__panel--swipe-back-prev'],\n panelId === swipeBackNextPanel && styles['View__panel--swipe-back-next'],\n swipeBackResult === SwipeBackResults.success &&\n styles['View__panel--swipe-back-success'],\n swipeBackResult === SwipeBackResults.fail &&\n styles['View__panel--swipe-back-failed'],\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => panelId !== undefined && (this.panelNodes[panelId] = el)}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles['View__panel-in']}\n style={{ marginTop: compensateScroll ? -scroll : undefined }}\n >\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n );\n }\n}\n\nexport const ViewInfinite = withContext(\n withContext(\n withContext(\n withPlatform(withDOM<ViewInfiniteProps>(ViewInfiniteComponent)),\n SplitColContext,\n 'splitCol',\n ),\n ConfigProviderContext,\n 'configProvider',\n ),\n ScrollContext,\n 'scroll',\n);\n"],"names":["React","classNames","withContext","withPlatform","canUseDOM","withDOM","getNavId","Platform","animationEvent","transitionEvent","warnOnce","ScrollContext","ConfigProviderContext","NavTransitionProvider","NavTransitionDirectionProvider","SplitColContext","Touch","swipeBackExcluded","warn","SwipeBackResults","fail","success","scrollsCache","ViewInfiniteComponent","props","scrolls","transitionFinishTimeout","undefined","animationFinishTimeout","panelNodes","transitionEndHandler","e","includes","animationName","state","prevPanel","flushTransition","Boolean","isBack","swipingBackTransitionEndHandler","propertyName","target","pickPanel","swipeBackNextPanel","swipeBackResult","onSwipeBackCancel","onSwipeBackSuccess","onMoveX","event","window","platform","IOS","swipeBackPrevented","shouldDisableTransitionMotion","configProvider","isWebView","startX","SWIPE_BACK_AREA","innerWidth","browserSwipe","setState","onSwipeBack","animated","swipingBack","history","length","onSwipeBackStart","payload","activePanel","blurActiveElement","prevScrolls","scroll","getScroll","y","swipeBackStartX","swipeBackPrevPanel","slice","swipeBackShift","shiftX","onEnd","speed","duration","visiblePanels","nextPanel","document","panels","Children","toArray","children","componentWillUnmount","id","clearTimeout","componentDidUpdate","prevProps","prevState","isBackCheck","from","to","firstLayerId","map","panel","find","supported","setTimeout","ANDROID","VKCOM","scrollPosition","prevPanelScrolls","newPanelScrolls","pop","scrollTo","onTransition","waitTransitionFinish","transitionMotionEnabled","splitCol","animate","elem","eventHandler","name","removeEventListener","addEventListener","activeElement","blur","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","WebkitTransform","render","_1","nav","className","restProps","filter","sort","isPrevPanel","isNextPanel","disableAnimation","Component","div","compensateScroll","isTransitionTarget","scrollList","onAnimationEnd","ref","el","style","key","marginTop","entering","defaultProps","ViewInfinite"],"mappings":"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"}
|
|
@@ -9,5 +9,5 @@ interface VisuallyHiddenProps extends React.AllHTMLAttributes<HTMLElement>, HasR
|
|
|
9
9
|
* @since v5.4.0
|
|
10
10
|
* @see https://vkcom.github.io/VKUI/#/VisuallyHidden
|
|
11
11
|
*/
|
|
12
|
-
export declare const VisuallyHidden: ({ Component,
|
|
12
|
+
export declare const VisuallyHidden: ({ Component, ...restProps }: VisuallyHiddenProps) => React.JSX.Element;
|
|
13
13
|
export {};
|
|
@@ -2,22 +2,21 @@ import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
|
|
|
2
2
|
import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
|
|
3
3
|
import { _ as _object_without_properties } from "@swc/helpers/_/_object_without_properties";
|
|
4
4
|
import * as React from "react";
|
|
5
|
-
import {
|
|
5
|
+
import { RootComponent } from "../RootComponent/RootComponent";
|
|
6
6
|
/**
|
|
7
7
|
* Компонент-обертка. Позволяет скрыть контент визуально, но оставить его
|
|
8
8
|
* доступным для ассистивных технологий. По умолчанию — `span`.
|
|
9
9
|
*
|
|
10
10
|
* @since v5.4.0
|
|
11
11
|
* @see https://vkcom.github.io/VKUI/#/VisuallyHidden
|
|
12
|
-
*/ export var VisuallyHidden = function(_param) {
|
|
13
|
-
var _param_Component = _param.Component, Component = _param_Component === void 0 ? "span" : _param_Component,
|
|
14
|
-
"Component"
|
|
15
|
-
"getRootRef",
|
|
16
|
-
"className"
|
|
12
|
+
*/ export var VisuallyHidden = function(_param) /*#__PURE__*/ {
|
|
13
|
+
var _param_Component = _param.Component, Component = _param_Component === void 0 ? "span" : _param_Component, restProps = _object_without_properties(_param, [
|
|
14
|
+
"Component"
|
|
17
15
|
]);
|
|
18
|
-
return
|
|
19
|
-
|
|
20
|
-
|
|
16
|
+
return React.createElement(RootComponent, _object_spread_props(_object_spread({
|
|
17
|
+
Component: Component
|
|
18
|
+
}, restProps), {
|
|
19
|
+
baseClassName: "vkuiVisuallyHidden"
|
|
21
20
|
}));
|
|
22
21
|
};
|
|
23
22
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/VisuallyHidden/VisuallyHidden.tsx"],"sourcesContent":["import * as React from 'react';\nimport {
|
|
1
|
+
{"version":3,"sources":["../../../src/components/VisuallyHidden/VisuallyHidden.tsx"],"sourcesContent":["import * as React from 'react';\nimport { HasComponent, HasRootRef } from '../../types';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport styles from './VisuallyHidden.module.css';\n\ninterface VisuallyHiddenProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent {}\n\n/**\n * Компонент-обертка. Позволяет скрыть контент визуально, но оставить его\n * доступным для ассистивных технологий. По умолчанию — `span`.\n *\n * @since v5.4.0\n * @see https://vkcom.github.io/VKUI/#/VisuallyHidden\n */\nexport const VisuallyHidden = ({ Component = 'span', ...restProps }: VisuallyHiddenProps) => (\n <RootComponent Component={Component} {...restProps} baseClassName={styles['VisuallyHidden']} />\n);\n"],"names":["React","RootComponent","VisuallyHidden","Component","restProps","baseClassName"],"mappings":";;;AAAA,YAAYA,WAAW,QAAQ;AAE/B,SAASC,aAAa,QAAQ,iCAAiC;AAQ/D;;;;;;CAMC,GACD,OAAO,IAAMC,iBAAiB;kCAAGC,WAAAA,0CAAY,2BAAWC;QAAvBD;;WAC/B,oBAACF;QAAcE,WAAWA;OAAeC;QAAWC,aAAa;;AAA6B,EAC9F"}
|