@vkontakte/vkui 8.0.2 → 8.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Accordion/Accordion.d.ts +8 -6
- package/dist/components/Accordion/Accordion.d.ts.map +1 -1
- package/dist/components/Accordion/Accordion.js +3 -0
- package/dist/components/Accordion/Accordion.js.map +1 -1
- package/dist/components/Accordion/AccordionIcon.d.ts +14 -0
- package/dist/components/Accordion/AccordionIcon.d.ts.map +1 -0
- package/dist/components/Accordion/AccordionIcon.js +16 -0
- package/dist/components/Accordion/AccordionIcon.js.map +1 -0
- package/dist/components/Accordion/AccordionSummary.d.ts +3 -3
- package/dist/components/Accordion/AccordionSummary.d.ts.map +1 -1
- package/dist/components/Accordion/AccordionSummary.js +4 -6
- package/dist/components/Accordion/AccordionSummary.js.map +1 -1
- package/dist/components/ActionSheet/ActionSheet.d.ts +9 -9
- package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
- package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/components/ActionSheet/ActionSheetContext.d.ts +3 -3
- package/dist/components/ActionSheet/ActionSheetContext.d.ts.map +1 -1
- package/dist/components/ActionSheet/ActionSheetContext.js.map +1 -1
- package/dist/components/ActionSheet/types.d.ts +8 -8
- package/dist/components/ActionSheet/types.d.ts.map +1 -1
- package/dist/components/ActionSheet/types.js.map +1 -1
- package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +15 -15
- package/dist/components/ActionSheetItem/ActionSheetItem.d.ts.map +1 -1
- package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
- package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.d.ts +1 -1
- package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.d.ts.map +1 -1
- package/dist/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
- package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +7 -7
- package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts.map +1 -1
- package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
- package/dist/components/Alert/Alert.d.ts +18 -18
- package/dist/components/Alert/Alert.d.ts.map +1 -1
- package/dist/components/Alert/Alert.js.map +1 -1
- package/dist/components/Alert/AlertBase.d.ts +2 -2
- package/dist/components/Alert/AlertBase.d.ts.map +1 -1
- package/dist/components/Alert/AlertBase.js.map +1 -1
- package/dist/components/Alert/AlertTypography.d.ts +1 -1
- package/dist/components/Alert/AlertTypography.d.ts.map +1 -1
- package/dist/components/Alert/AlertTypography.js.map +1 -1
- package/dist/components/AppRoot/AppRoot.d.ts +9 -9
- package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
- package/dist/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/components/AppRoot/AppRootContext.d.ts +4 -4
- package/dist/components/AppRoot/AppRootContext.d.ts.map +1 -1
- package/dist/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/components/AppRoot/AppRootPortal.d.ts +2 -2
- package/dist/components/AppRoot/AppRootPortal.d.ts.map +1 -1
- package/dist/components/AppRoot/AppRootPortal.js.map +1 -1
- package/dist/components/AppRoot/ScrollContext.d.ts +4 -4
- package/dist/components/AppRoot/ScrollContext.d.ts.map +1 -1
- package/dist/components/AppRoot/ScrollContext.js.map +1 -1
- package/dist/components/AppRoot/types.d.ts +4 -4
- package/dist/components/AppRoot/types.d.ts.map +1 -1
- package/dist/components/AppRoot/types.js.map +1 -1
- package/dist/components/AspectRatio/AspectRatio.d.ts +2 -2
- package/dist/components/AspectRatio/AspectRatio.d.ts.map +1 -1
- package/dist/components/AspectRatio/AspectRatio.js.map +1 -1
- package/dist/components/Avatar/Avatar.d.ts +2 -2
- package/dist/components/Avatar/Avatar.d.ts.map +1 -1
- package/dist/components/Avatar/Avatar.js.map +1 -1
- package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.d.ts +1 -1
- package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.d.ts.map +1 -1
- package/dist/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
- package/dist/components/Badge/Badge.d.ts +1 -1
- package/dist/components/Badge/Badge.d.ts.map +1 -1
- package/dist/components/Badge/Badge.js.map +1 -1
- package/dist/components/Banner/Banner.d.ts +12 -12
- package/dist/components/Banner/Banner.d.ts.map +1 -1
- package/dist/components/Banner/Banner.js.map +1 -1
- package/dist/components/Box/Box.d.ts +1 -1
- package/dist/components/Box/Box.d.ts.map +1 -1
- package/dist/components/Box/Box.js.map +1 -1
- package/dist/components/Button/Button.d.ts +11 -11
- package/dist/components/Button/Button.d.ts.map +1 -1
- package/dist/components/Button/Button.js +1 -1
- package/dist/components/Button/Button.js.map +1 -1
- package/dist/components/ButtonGroup/ButtonGroup.d.ts +4 -4
- package/dist/components/ButtonGroup/ButtonGroup.d.ts.map +1 -1
- package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -1
- package/dist/components/Calendar/Calendar.d.ts +17 -17
- package/dist/components/Calendar/Calendar.d.ts.map +1 -1
- package/dist/components/Calendar/Calendar.js.map +1 -1
- package/dist/components/CalendarDay/CalendarDay.d.ts +18 -18
- package/dist/components/CalendarDay/CalendarDay.d.ts.map +1 -1
- package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
- package/dist/components/CalendarDays/CalendarDays.d.ts +14 -14
- package/dist/components/CalendarDays/CalendarDays.d.ts.map +1 -1
- package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/components/CalendarHeader/CalendarHeader.d.ts +19 -19
- package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
- package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/components/CalendarRange/CalendarRange.d.ts +12 -12
- package/dist/components/CalendarRange/CalendarRange.d.ts.map +1 -1
- package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/components/CalendarTime/CalendarTime.d.ts +14 -14
- package/dist/components/CalendarTime/CalendarTime.d.ts.map +1 -1
- package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
- package/dist/components/CalendarTime/CalendarTimePicker.d.ts +3 -3
- package/dist/components/CalendarTime/CalendarTimePicker.d.ts.map +1 -1
- package/dist/components/CalendarTime/CalendarTimePicker.js.map +1 -1
- package/dist/components/Card/Card.d.ts +1 -1
- package/dist/components/Card/Card.d.ts.map +1 -1
- package/dist/components/Card/Card.js.map +1 -1
- package/dist/components/CardGrid/CardGrid.d.ts +2 -2
- package/dist/components/CardGrid/CardGrid.d.ts.map +1 -1
- package/dist/components/CardGrid/CardGrid.js.map +1 -1
- package/dist/components/CardScroll/CardScroll.d.ts +3 -3
- package/dist/components/CardScroll/CardScroll.d.ts.map +1 -1
- package/dist/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/components/CarouselBase/Bullets.d.ts +1 -1
- package/dist/components/CarouselBase/Bullets.d.ts.map +1 -1
- package/dist/components/CarouselBase/Bullets.js.map +1 -1
- package/dist/components/CarouselBase/CarouselViewPort.d.ts +1 -1
- package/dist/components/CarouselBase/CarouselViewPort.d.ts.map +1 -1
- package/dist/components/CarouselBase/CarouselViewPort.js.map +1 -1
- package/dist/components/CarouselBase/ScrollArrows.d.ts +2 -2
- package/dist/components/CarouselBase/ScrollArrows.d.ts.map +1 -1
- package/dist/components/CarouselBase/ScrollArrows.js.map +1 -1
- package/dist/components/CarouselBase/helpers.d.ts +4 -4
- package/dist/components/CarouselBase/helpers.d.ts.map +1 -1
- package/dist/components/CarouselBase/helpers.js.map +1 -1
- package/dist/components/CarouselBase/types.d.ts +23 -23
- package/dist/components/CarouselBase/types.d.ts.map +1 -1
- package/dist/components/CarouselBase/types.js.map +1 -1
- package/dist/components/Cell/Cell.d.ts +8 -8
- package/dist/components/Cell/Cell.d.ts.map +1 -1
- package/dist/components/Cell/Cell.js.map +1 -1
- package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts +1 -1
- package/dist/components/Cell/CellCheckbox/CellCheckbox.d.ts.map +1 -1
- package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
- package/dist/components/Cell/CellDragger/CellDragger.d.ts +2 -2
- package/dist/components/Cell/CellDragger/CellDragger.d.ts.map +1 -1
- package/dist/components/Cell/CellDragger/CellDragger.js.map +1 -1
- package/dist/components/CellButton/CellButton.d.ts +69 -6
- package/dist/components/CellButton/CellButton.d.ts.map +1 -1
- package/dist/components/CellButton/CellButton.js +115 -6
- package/dist/components/CellButton/CellButton.js.map +1 -1
- package/dist/components/CellButtonGroup/CellButtonGroup.d.ts +2 -2
- package/dist/components/Checkbox/Checkbox.d.ts +6 -6
- package/dist/components/Checkbox/Checkbox.d.ts.map +1 -1
- package/dist/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/components/Checkbox/CheckboxInput/CheckboxInput.d.ts +11 -11
- package/dist/components/Checkbox/CheckboxInput/CheckboxInput.d.ts.map +1 -1
- package/dist/components/Checkbox/CheckboxInput/CheckboxInput.js.map +1 -1
- package/dist/components/ChipsInput/ChipsInput.d.ts +1 -1
- package/dist/components/ChipsInput/ChipsInput.d.ts.map +1 -1
- package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
- package/dist/components/ChipsInput/useChipsInput.d.ts +3 -3
- package/dist/components/ChipsInput/useChipsInput.d.ts.map +1 -1
- package/dist/components/ChipsInput/useChipsInput.js.map +1 -1
- package/dist/components/ChipsInputBase/Chip/Chip.d.ts +9 -9
- package/dist/components/ChipsInputBase/Chip/Chip.d.ts.map +1 -1
- package/dist/components/ChipsInputBase/Chip/Chip.js.map +1 -1
- package/dist/components/ChipsInputBase/types.d.ts +19 -19
- package/dist/components/ChipsInputBase/types.d.ts.map +1 -1
- package/dist/components/ChipsInputBase/types.js.map +1 -1
- package/dist/components/ChipsSelect/ChipsSelect.d.ts +13 -13
- package/dist/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
- package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
- package/dist/components/ChipsSelect/useChipsSelect.d.ts +8 -8
- package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
- package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
- package/dist/components/Clickable/Clickable.d.ts +1 -1
- package/dist/components/Clickable/Clickable.d.ts.map +1 -1
- package/dist/components/Clickable/Clickable.js.map +1 -1
- package/dist/components/Clickable/useState.d.ts +13 -13
- package/dist/components/Clickable/useState.d.ts.map +1 -1
- package/dist/components/Clickable/useState.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.d.ts +2 -1
- package/dist/components/ConfigProvider/ConfigProvider.d.ts.map +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/components/ContentBadge/ContentBadge.d.ts +4 -4
- package/dist/components/ContentBadge/ContentBadge.d.ts.map +1 -1
- package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
- package/dist/components/ContentCard/ContentCard.d.ts +8 -8
- package/dist/components/ContentCard/ContentCard.d.ts.map +1 -1
- package/dist/components/ContentCard/ContentCard.js.map +1 -1
- package/dist/components/Counter/Counter.d.ts +4 -4
- package/dist/components/Counter/Counter.d.ts.map +1 -1
- package/dist/components/Counter/Counter.js.map +1 -1
- package/dist/components/CustomScrollView/CustomScrollView.d.ts +6 -6
- package/dist/components/CustomScrollView/CustomScrollView.d.ts.map +1 -1
- package/dist/components/CustomScrollView/CustomScrollView.js.map +1 -1
- package/dist/components/CustomSelect/CustomSelect.d.ts +36 -27
- package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
- package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/components/CustomSelect/CustomSelectClearButton.d.ts +2 -2
- package/dist/components/CustomSelect/CustomSelectClearButton.d.ts.map +1 -1
- package/dist/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
- package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.d.ts +9 -9
- package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.d.ts.map +1 -1
- package/dist/components/CustomSelect/CustomSelectInput/CustomSelectInput.js.map +1 -1
- package/dist/components/CustomSelect/hooks/useDropdownOpenedController.d.ts +2 -2
- package/dist/components/CustomSelect/hooks/useDropdownOpenedController.d.ts.map +1 -1
- package/dist/components/CustomSelect/hooks/useDropdownOpenedController.js.map +1 -1
- package/dist/components/CustomSelect/hooks/useSelectedOptionController.d.ts +1 -1
- package/dist/components/CustomSelect/hooks/useSelectedOptionController.d.ts.map +1 -1
- package/dist/components/CustomSelect/hooks/useSelectedOptionController.js.map +1 -1
- package/dist/components/CustomSelect/types.d.ts +1 -1
- package/dist/components/CustomSelect/types.d.ts.map +1 -1
- package/dist/components/CustomSelect/types.js.map +1 -1
- package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +8 -8
- package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts.map +1 -1
- package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
- package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +9 -9
- package/dist/components/CustomSelectOption/CustomSelectOption.d.ts.map +1 -1
- package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/components/DateInput/DateInput.d.ts +23 -23
- package/dist/components/DateInput/DateInput.d.ts.map +1 -1
- package/dist/components/DateInput/DateInput.js +3 -12
- package/dist/components/DateInput/DateInput.js.map +1 -1
- package/dist/components/DateInput/hooks.d.ts +4 -4
- package/dist/components/DateInput/hooks.d.ts.map +1 -1
- package/dist/components/DateInput/hooks.js.map +1 -1
- package/dist/components/DateRangeInput/DateRangeInput.d.ts +25 -25
- package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
- package/dist/components/DateRangeInput/DateRangeInput.js +2 -11
- package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
- package/dist/components/DropZone/DropZone.d.ts +2 -2
- package/dist/components/DropZone/DropZone.d.ts.map +1 -1
- package/dist/components/DropZone/DropZone.js +1 -1
- package/dist/components/DropZone/DropZone.js.map +1 -1
- package/dist/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.d.ts +1 -1
- package/dist/components/DropZone/DropZoneGrid/DropZoneGrid.d.ts.map +1 -0
- package/dist/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.js +3 -3
- package/dist/components/DropZone/DropZoneGrid/DropZoneGrid.js.map +1 -0
- package/dist/components/DropdownIcon/DropdownIcon.d.ts +1 -1
- package/dist/components/DropdownIcon/DropdownIcon.d.ts.map +1 -1
- package/dist/components/DropdownIcon/DropdownIcon.js.map +1 -1
- package/dist/components/Epic/Epic.d.ts +1 -1
- package/dist/components/Epic/Epic.d.ts.map +1 -1
- package/dist/components/Epic/Epic.js.map +1 -1
- package/dist/components/Epic/ScrollSaver.d.ts +1 -1
- package/dist/components/Epic/ScrollSaver.d.ts.map +1 -1
- package/dist/components/Epic/ScrollSaver.js.map +1 -1
- package/dist/components/File/File.d.ts +4 -4
- package/dist/components/File/File.d.ts.map +1 -1
- package/dist/components/File/File.js.map +1 -1
- package/dist/components/FixedLayout/FixedLayout.d.ts +3 -3
- package/dist/components/FixedLayout/FixedLayout.d.ts.map +1 -1
- package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
- package/dist/components/Flex/Flex.d.ts +8 -12
- package/dist/components/Flex/Flex.d.ts.map +1 -1
- package/dist/components/Flex/Flex.js +2 -9
- package/dist/components/Flex/Flex.js.map +1 -1
- package/dist/components/Flex/FlexItem/FlexItem.d.ts +5 -12
- package/dist/components/Flex/FlexItem/FlexItem.d.ts.map +1 -1
- package/dist/components/Flex/FlexItem/FlexItem.js +5 -14
- package/dist/components/Flex/FlexItem/FlexItem.js.map +1 -1
- package/dist/components/FloatingArrow/FloatingArrow.d.ts +9 -9
- package/dist/components/FloatingArrow/FloatingArrow.d.ts.map +1 -1
- package/dist/components/FloatingArrow/FloatingArrow.js.map +1 -1
- package/dist/components/FocusTrap/FocusTrap.d.ts +1 -1
- package/dist/components/FocusTrap/FocusTrap.d.ts.map +1 -1
- package/dist/components/FocusTrap/FocusTrap.js +2 -4
- package/dist/components/FocusTrap/FocusTrap.js.map +1 -1
- package/dist/components/FormField/FormField.d.ts +8 -8
- package/dist/components/FormField/FormField.d.ts.map +1 -1
- package/dist/components/FormField/FormField.js.map +1 -1
- package/dist/components/FormFieldClearButton/FormFieldClearButton.d.ts +2 -2
- package/dist/components/FormFieldClearButton/FormFieldClearButton.d.ts.map +1 -1
- package/dist/components/FormFieldClearButton/FormFieldClearButton.js.map +1 -1
- package/dist/components/FormItem/FormItem.d.ts +10 -10
- package/dist/components/FormItem/FormItem.d.ts.map +1 -1
- package/dist/components/FormItem/FormItem.js.map +1 -1
- package/dist/components/FormItem/context.d.ts +2 -2
- package/dist/components/FormItem/context.d.ts.map +1 -1
- package/dist/components/FormItem/context.js.map +1 -1
- package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts +4 -4
- package/dist/components/FormLayoutGroup/FormLayoutGroup.d.ts.map +1 -1
- package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
- package/dist/components/FormStatus/FormStatus.d.ts +2 -2
- package/dist/components/FormStatus/FormStatus.d.ts.map +1 -1
- package/dist/components/FormStatus/FormStatus.js.map +1 -1
- package/dist/components/Gallery/Gallery.d.ts +2 -2
- package/dist/components/Gallery/Gallery.d.ts.map +1 -1
- package/dist/components/Gallery/Gallery.js.map +1 -1
- package/dist/components/Gradient/Gradient.d.ts +2 -2
- package/dist/components/Gradient/Gradient.d.ts.map +1 -1
- package/dist/components/Gradient/Gradient.js.map +1 -1
- package/dist/components/GridAvatar/GridAvatar.d.ts +1 -1
- package/dist/components/GridAvatar/GridAvatar.d.ts.map +1 -1
- package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
- package/dist/components/Group/Group.d.ts +2 -2
- package/dist/components/Group/Group.d.ts.map +1 -1
- package/dist/components/Group/Group.js.map +1 -1
- package/dist/components/Group/GroupContainer.d.ts +3 -3
- package/dist/components/Group/GroupContainer.d.ts.map +1 -1
- package/dist/components/Group/GroupContainer.js.map +1 -1
- package/dist/components/Group/GroupExpandedContent.d.ts +1 -1
- package/dist/components/Group/GroupExpandedContent.d.ts.map +1 -1
- package/dist/components/Group/GroupExpandedContent.js.map +1 -1
- package/dist/components/Header/Header.d.ts +11 -11
- package/dist/components/Header/Header.d.ts.map +1 -1
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/HorizontalCell/HorizontalCell.d.ts +7 -7
- package/dist/components/HorizontalCell/HorizontalCell.d.ts.map +1 -1
- package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
- package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.d.ts +4 -4
- package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.d.ts.map +1 -1
- package/dist/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
- package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +30 -15
- package/dist/components/HorizontalScroll/HorizontalScroll.d.ts.map +1 -1
- package/dist/components/HorizontalScroll/HorizontalScroll.js +20 -6
- package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
- package/dist/components/IconButton/IconButton.d.ts +1 -1
- package/dist/components/IconButton/IconButton.d.ts.map +1 -1
- package/dist/components/IconButton/IconButton.js.map +1 -1
- package/dist/components/Image/Image.d.ts +5 -5
- package/dist/components/Image/Image.d.ts.map +1 -1
- package/dist/components/Image/Image.js.map +1 -1
- package/dist/components/ImageBase/ImageBase.d.ts +14 -14
- package/dist/components/ImageBase/ImageBase.d.ts.map +1 -1
- package/dist/components/ImageBase/ImageBase.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +1 -1
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts.map +1 -1
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.d.ts +3 -3
- package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.d.ts.map +1 -1
- package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts +3 -3
- package/dist/components/ImageBase/ImageBaseOverlay/types.d.ts.map +1 -1
- package/dist/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
- package/dist/components/ImageBase/types.d.ts +3 -3
- package/dist/components/ImageBase/types.d.ts.map +1 -1
- package/dist/components/ImageBase/types.js.map +1 -1
- package/dist/components/Input/Input.d.ts +4 -4
- package/dist/components/Input/Input.d.ts.map +1 -1
- package/dist/components/Input/Input.js.map +1 -1
- package/dist/components/InputLike/InputLike.d.ts +3 -3
- package/dist/components/InputLike/InputLike.d.ts.map +1 -1
- package/dist/components/InputLike/InputLike.js.map +1 -1
- package/dist/components/Link/Link.d.ts +4 -4
- package/dist/components/Link/Link.d.ts.map +1 -1
- package/dist/components/Link/Link.js.map +1 -1
- package/dist/components/List/List.d.ts +1 -1
- package/dist/components/List/List.d.ts.map +1 -1
- package/dist/components/List/List.js.map +1 -1
- package/dist/components/MiniInfoCell/MiniInfoCell.d.ts +5 -5
- package/dist/components/MiniInfoCell/MiniInfoCell.d.ts.map +1 -1
- package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
- package/dist/components/ModalCard/ModalCardInternal.d.ts +1 -1
- package/dist/components/ModalCard/ModalCardInternal.d.ts.map +1 -1
- package/dist/components/ModalCard/ModalCardInternal.js.map +1 -1
- package/dist/components/ModalCard/types.d.ts +13 -13
- package/dist/components/ModalCard/types.d.ts.map +1 -1
- package/dist/components/ModalCard/types.js.map +1 -1
- package/dist/components/ModalCardBase/ModalCardBase.d.ts +14 -14
- package/dist/components/ModalCardBase/ModalCardBase.d.ts.map +1 -1
- package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
- package/dist/components/ModalDismissButton/ModalDismissButton.d.ts +1 -1
- package/dist/components/ModalDismissButton/ModalDismissButton.d.ts.map +1 -1
- package/dist/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
- package/dist/components/ModalOutlet/ModalOutlet.d.ts +3 -3
- package/dist/components/ModalOutlet/ModalOutlet.d.ts.map +1 -1
- package/dist/components/ModalOutlet/ModalOutlet.js.map +1 -1
- package/dist/components/ModalOutsideButton/ModalOutsideButton.d.ts +1 -1
- package/dist/components/ModalOutsideButton/ModalOutsideButton.d.ts.map +1 -1
- package/dist/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -1
- package/dist/components/ModalOverlay/ModalOverlay.d.ts +7 -7
- package/dist/components/ModalOverlay/ModalOverlay.d.ts.map +1 -1
- package/dist/components/ModalOverlay/ModalOverlay.js.map +1 -1
- package/dist/components/ModalPage/ModalPageBase.d.ts +2 -2
- package/dist/components/ModalPage/ModalPageBase.d.ts.map +1 -1
- package/dist/components/ModalPage/ModalPageBase.js.map +1 -1
- package/dist/components/ModalPage/ModalPageInternal.d.ts +2 -2
- package/dist/components/ModalPage/ModalPageInternal.d.ts.map +1 -1
- package/dist/components/ModalPage/ModalPageInternal.js.map +1 -1
- package/dist/components/ModalPage/types.d.ts +27 -27
- package/dist/components/ModalPage/types.d.ts.map +1 -1
- package/dist/components/ModalPage/types.js.map +1 -1
- package/dist/components/ModalPageFooter/ModalPageFooter.d.ts +2 -2
- package/dist/components/ModalPageFooter/ModalPageFooter.d.ts.map +1 -1
- package/dist/components/ModalPageFooter/ModalPageFooter.js.map +1 -1
- package/dist/components/ModalPageHeader/ModalPageHeader.d.ts +1 -1
- package/dist/components/ModalPageHeader/ModalPageHeader.d.ts.map +1 -1
- package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
- package/dist/components/ModalRoot/types.d.ts +15 -15
- package/dist/components/ModalRoot/types.d.ts.map +1 -1
- package/dist/components/ModalRoot/types.js.map +1 -1
- package/dist/components/ModalRoot/useModalRootManager.d.ts +19 -19
- package/dist/components/ModalRoot/useModalRootManager.d.ts.map +1 -1
- package/dist/components/ModalRoot/useModalRootManager.js.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.d.ts +11 -11
- package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/components/NumberInputLike/NumberInputLike.d.ts +3 -3
- package/dist/components/NumberInputLike/NumberInputLike.d.ts.map +1 -1
- package/dist/components/NumberInputLike/NumberInputLike.js.map +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts +6 -6
- package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts.map +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltip.js +12 -3
- package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.d.ts.map +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
- package/dist/components/Pagination/Pagination.d.ts +19 -19
- package/dist/components/Pagination/Pagination.d.ts.map +1 -1
- package/dist/components/Pagination/Pagination.js +14 -6
- package/dist/components/Pagination/Pagination.js.map +1 -1
- package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts +3 -3
- package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.d.ts.map +1 -1
- package/dist/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.d.ts +3 -3
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.d.ts.map +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.d.ts.map +1 -1
- package/dist/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts +3 -3
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.d.ts.map +1 -1
- package/dist/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
- package/dist/components/Panel/Panel.d.ts +3 -3
- package/dist/components/Panel/Panel.d.ts.map +1 -1
- package/dist/components/Panel/Panel.js.map +1 -1
- package/dist/components/PanelHeader/PanelHeader.d.ts +8 -8
- package/dist/components/PanelHeader/PanelHeader.d.ts.map +1 -1
- package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts +2 -2
- package/dist/components/PanelHeaderBack/PanelHeaderBack.d.ts.map +1 -1
- package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
- package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts +2 -2
- package/dist/components/PanelHeaderButton/PanelHeaderButton.d.ts.map +1 -1
- package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
- package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts +3 -3
- package/dist/components/PanelHeaderContent/PanelHeaderContent.d.ts.map +1 -1
- package/dist/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
- package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts +3 -3
- package/dist/components/PanelHeaderEdit/PanelHeaderEdit.d.ts.map +1 -1
- package/dist/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
- package/dist/components/PanelSpinner/PanelSpinner.d.ts +1 -1
- package/dist/components/PanelSpinner/PanelSpinner.d.ts.map +1 -1
- package/dist/components/PanelSpinner/PanelSpinner.js.map +1 -1
- package/dist/components/Placeholder/Placeholder.d.ts +5 -5
- package/dist/components/Placeholder/Placeholder.d.ts.map +1 -1
- package/dist/components/Placeholder/Placeholder.js.map +1 -1
- package/dist/components/PopoutWrapper/PopoutWrapper.d.ts +6 -6
- package/dist/components/PopoutWrapper/PopoutWrapper.d.ts.map +1 -1
- package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
- package/dist/components/Popover/Popover.d.ts +5 -5
- package/dist/components/Popover/Popover.d.ts.map +1 -1
- package/dist/components/Popover/Popover.js.map +1 -1
- package/dist/components/Popper/Popper.d.ts +4 -4
- package/dist/components/Popper/Popper.d.ts.map +1 -1
- package/dist/components/Popper/Popper.js +13 -7
- package/dist/components/Popper/Popper.js.map +1 -1
- package/dist/components/Progress/Progress.d.ts +4 -4
- package/dist/components/Progress/Progress.d.ts.map +1 -1
- package/dist/components/Progress/Progress.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.d.ts +2 -2
- package/dist/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts +4 -4
- package/dist/components/PullToRefresh/PullToRefreshSpinner.d.ts.map +1 -1
- package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
- package/dist/components/Radio/Radio.d.ts +7 -7
- package/dist/components/Radio/Radio.d.ts.map +1 -1
- package/dist/components/Radio/Radio.js +2 -2
- package/dist/components/Radio/Radio.js.map +1 -1
- package/dist/components/Radio/RadioInput/RadioInput.d.ts +4 -4
- package/dist/components/Radio/RadioInput/RadioInput.d.ts.map +1 -1
- package/dist/components/Radio/RadioInput/RadioInput.js.map +1 -1
- package/dist/components/RadioGroup/RadioGroup.d.ts +1 -1
- package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -1
- package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/components/Removable/Removable.d.ts +9 -9
- package/dist/components/Removable/Removable.d.ts.map +1 -1
- package/dist/components/Removable/Removable.js.map +1 -1
- package/dist/components/Removable/RemovableIos.d.ts +3 -3
- package/dist/components/Removable/RemovableIos.d.ts.map +1 -1
- package/dist/components/Removable/RemovableIos.js.map +1 -1
- package/dist/components/RichCell/RichCell.d.ts +15 -15
- package/dist/components/RichCell/RichCell.d.ts.map +1 -1
- package/dist/components/RichCell/RichCell.js.map +1 -1
- package/dist/components/Root/Root.d.ts +4 -4
- package/dist/components/Root/Root.d.ts.map +1 -1
- package/dist/components/Root/Root.js.map +1 -1
- package/dist/components/RootComponent/RootComponent.d.ts +2 -2
- package/dist/components/RootComponent/RootComponent.d.ts.map +1 -1
- package/dist/components/RootComponent/RootComponent.js.map +1 -1
- package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.d.ts +1 -1
- package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.d.ts.map +1 -1
- package/dist/components/ScreenSpinner/ScreenSpinnerSwapIcon.js.map +1 -1
- package/dist/components/ScreenSpinner/context.d.ts +2 -2
- package/dist/components/ScreenSpinner/context.d.ts.map +1 -1
- package/dist/components/ScreenSpinner/context.js.map +1 -1
- package/dist/components/ScreenSpinner/types.d.ts +5 -5
- package/dist/components/ScreenSpinner/types.d.ts.map +1 -1
- package/dist/components/ScreenSpinner/types.js.map +1 -1
- package/dist/components/ScrollArrow/ScrollArrow.d.ts +10 -4
- package/dist/components/ScrollArrow/ScrollArrow.d.ts.map +1 -1
- package/dist/components/ScrollArrow/ScrollArrow.js +14 -4
- package/dist/components/ScrollArrow/ScrollArrow.js.map +1 -1
- package/dist/components/Search/Search.d.ts +17 -17
- package/dist/components/Search/Search.d.ts.map +1 -1
- package/dist/components/Search/Search.js.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControl.d.ts +6 -6
- package/dist/components/SegmentedControl/SegmentedControl.d.ts.map +1 -1
- 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.d.ts.map +1 -1
- package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
- package/dist/components/SelectMimicry/SelectMimicry.d.ts +3 -3
- package/dist/components/SelectMimicry/SelectMimicry.d.ts.map +1 -1
- package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
- package/dist/components/SelectTypography/SelectTypography.d.ts +1 -1
- package/dist/components/SelectTypography/SelectTypography.d.ts.map +1 -1
- package/dist/components/SelectTypography/SelectTypography.js.map +1 -1
- package/dist/components/SelectionControl/SelectionControl.d.ts +1 -1
- package/dist/components/SelectionControl/SelectionControl.d.ts.map +1 -1
- package/dist/components/SelectionControl/SelectionControl.js.map +1 -1
- package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.d.ts +2 -2
- package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.d.ts.map +1 -1
- package/dist/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js.map +1 -1
- package/dist/components/Separator/Separator.d.ts +5 -5
- package/dist/components/Separator/Separator.d.ts.map +1 -1
- package/dist/components/Separator/Separator.js.map +1 -1
- package/dist/components/SimpleCell/Chevron/Chevron.d.ts +1 -1
- package/dist/components/SimpleCell/Chevron/Chevron.d.ts.map +1 -1
- package/dist/components/SimpleCell/Chevron/Chevron.js.map +1 -1
- package/dist/components/SimpleCell/SimpleCell.d.ts +14 -14
- package/dist/components/SimpleCell/SimpleCell.d.ts.map +1 -1
- package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
- package/dist/components/SimpleGrid/SimpleGrid.d.ts +6 -6
- package/dist/components/SimpleGrid/SimpleGrid.d.ts.map +1 -1
- package/dist/components/SimpleGrid/SimpleGrid.js.map +1 -1
- package/dist/components/Skeleton/Skeleton.d.ts +5 -5
- package/dist/components/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/components/Skeleton/Skeleton.js.map +1 -1
- package/dist/components/Slider/Slider.d.ts +17 -17
- package/dist/components/Slider/Slider.d.ts.map +1 -1
- package/dist/components/Slider/Slider.js.map +1 -1
- package/dist/components/Slider/SliderThumb/SliderThumb.d.ts +5 -5
- package/dist/components/Slider/SliderThumb/SliderThumb.d.ts.map +1 -1
- package/dist/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
- package/dist/components/Snackbar/Snackbar.d.ts +10 -10
- package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
- package/dist/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/components/Snackbar/subcomponents/Basic/Basic.d.ts +6 -6
- package/dist/components/Snackbar/subcomponents/Basic/Basic.d.ts.map +1 -1
- package/dist/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
- package/dist/components/Snackbar/utils.d.ts +1 -1
- package/dist/components/Snackbar/utils.d.ts.map +1 -1
- package/dist/components/Snackbar/utils.js.map +1 -1
- package/dist/components/Spacing/Spacing.d.ts +2 -2
- package/dist/components/Spacing/Spacing.d.ts.map +1 -1
- package/dist/components/Spacing/Spacing.js.map +1 -1
- package/dist/components/Spinner/Spinner.d.ts +4 -4
- package/dist/components/Spinner/Spinner.d.ts.map +1 -1
- package/dist/components/Spinner/Spinner.js.map +1 -1
- package/dist/components/SplitCol/SplitCol.d.ts +7 -7
- package/dist/components/SplitCol/SplitCol.d.ts.map +1 -1
- package/dist/components/SplitCol/SplitCol.js.map +1 -1
- package/dist/components/SplitLayout/SplitLayout.d.ts +8 -8
- package/dist/components/SplitLayout/SplitLayout.d.ts.map +1 -1
- package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/components/SubnavigationBar/SubnavigationBar.d.ts +2 -2
- package/dist/components/SubnavigationBar/SubnavigationBar.d.ts.map +1 -1
- package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
- package/dist/components/SubnavigationButton/SubnavigationButton.d.ts +8 -8
- package/dist/components/SubnavigationButton/SubnavigationButton.d.ts.map +1 -1
- package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
- package/dist/components/Switch/Switch.d.ts +4 -4
- package/dist/components/Switch/Switch.d.ts.map +1 -1
- package/dist/components/Switch/Switch.js.map +1 -1
- package/dist/components/Tabbar/Tabbar.d.ts +2 -2
- package/dist/components/Tabbar/Tabbar.d.ts.map +1 -1
- package/dist/components/Tabbar/Tabbar.js.map +1 -1
- package/dist/components/TabbarItem/TabbarItem.d.ts +3 -3
- package/dist/components/TabbarItem/TabbarItem.d.ts.map +1 -1
- package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
- package/dist/components/Tabs/Tabs.d.ts +7 -7
- package/dist/components/Tabs/Tabs.d.ts.map +1 -1
- package/dist/components/Tabs/Tabs.js.map +1 -1
- package/dist/components/Tabs/TabsModeContext.d.ts +1 -1
- package/dist/components/Tabs/TabsModeContext.d.ts.map +1 -1
- package/dist/components/Tabs/TabsModeContext.js.map +1 -1
- package/dist/components/TabsItem/TabsItem.d.ts +5 -5
- package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
- package/dist/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/components/Tappable/Tappable.d.ts +3 -3
- package/dist/components/Tappable/Tappable.d.ts.map +1 -1
- package/dist/components/Tappable/Tappable.js.map +1 -1
- package/dist/components/Tappable/state.d.ts +2 -2
- package/dist/components/Tappable/state.d.ts.map +1 -1
- package/dist/components/Tappable/state.js.map +1 -1
- package/dist/components/Textarea/Textarea.d.ts +6 -6
- package/dist/components/Textarea/Textarea.d.ts.map +1 -1
- package/dist/components/Textarea/Textarea.js.map +1 -1
- package/dist/components/ToolButton/ToolButton.d.ts +4 -4
- package/dist/components/ToolButton/ToolButton.d.ts.map +1 -1
- package/dist/components/ToolButton/ToolButton.js.map +1 -1
- package/dist/components/Tooltip/Tooltip.d.ts +6 -6
- package/dist/components/Tooltip/Tooltip.d.ts.map +1 -1
- package/dist/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/components/TooltipBase/TooltipBase.d.ts +10 -10
- package/dist/components/TooltipBase/TooltipBase.d.ts.map +1 -1
- package/dist/components/TooltipBase/TooltipBase.js.map +1 -1
- package/dist/components/Touch/Touch.d.ts +16 -16
- package/dist/components/Touch/Touch.d.ts.map +1 -1
- package/dist/components/Touch/Touch.js.map +1 -1
- package/dist/components/Typography/Caption/Caption.d.ts +1 -1
- package/dist/components/Typography/Caption/Caption.d.ts.map +1 -1
- package/dist/components/Typography/Caption/Caption.js.map +1 -1
- package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts +1 -1
- package/dist/components/Typography/DisplayTitle/DisplayTitle.d.ts.map +1 -1
- package/dist/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -1
- package/dist/components/Typography/EllipsisText/EllipsisText.d.ts +3 -3
- package/dist/components/Typography/EllipsisText/EllipsisText.d.ts.map +1 -1
- package/dist/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
- package/dist/components/Typography/Headline/Headline.d.ts +1 -1
- package/dist/components/Typography/Headline/Headline.d.ts.map +1 -1
- package/dist/components/Typography/Headline/Headline.js.map +1 -1
- package/dist/components/Typography/Title/Title.d.ts +1 -1
- package/dist/components/Typography/Title/Title.d.ts.map +1 -1
- package/dist/components/Typography/Title/Title.js.map +1 -1
- package/dist/components/Typography/Typography.d.ts +6 -6
- package/dist/components/Typography/Typography.d.ts.map +1 -1
- package/dist/components/Typography/Typography.js.map +1 -1
- package/dist/components/UnstyledTextField/UnstyledTextField.d.ts +1 -1
- package/dist/components/UnstyledTextField/UnstyledTextField.d.ts.map +1 -1
- package/dist/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
- package/dist/components/UsersStack/UsersStack.d.ts +6 -6
- package/dist/components/UsersStack/UsersStack.d.ts.map +1 -1
- package/dist/components/UsersStack/UsersStack.js.map +1 -1
- package/dist/components/View/View.d.ts +4 -4
- package/dist/components/View/View.d.ts.map +1 -1
- package/dist/components/View/View.js.map +1 -1
- package/dist/components/View/ViewInfinite.d.ts +12 -12
- package/dist/components/View/ViewInfinite.d.ts.map +1 -1
- package/dist/components/View/ViewInfinite.js.map +1 -1
- package/dist/components/WriteBar/WriteBar.d.ts +10 -10
- package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
- package/dist/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/components/WriteBarIcon/WriteBarIcon.d.ts +3 -3
- package/dist/components/WriteBarIcon/WriteBarIcon.d.ts.map +1 -1
- package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
- package/dist/components.css +1 -1
- package/dist/components.css.map +1 -1
- package/dist/cssm/components/Accordion/Accordion.js +3 -0
- package/dist/cssm/components/Accordion/Accordion.js.map +1 -1
- package/dist/cssm/components/Accordion/AccordionIcon.js +17 -0
- package/dist/cssm/components/Accordion/AccordionIcon.js.map +1 -0
- package/dist/cssm/components/Accordion/AccordionSummary.js +4 -7
- package/dist/cssm/components/Accordion/AccordionSummary.js.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheetContext.js.map +1 -1
- package/dist/cssm/components/ActionSheet/types.js.map +1 -1
- package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
- package/dist/cssm/components/ActionSheetItem/ActionSheetItem.module.css +0 -1
- package/dist/cssm/components/ActionSheetItem/subcomponents/Radio/Radio.js.map +1 -1
- package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
- package/dist/cssm/components/Alert/Alert.js.map +1 -1
- package/dist/cssm/components/Alert/AlertBase.js.map +1 -1
- package/dist/cssm/components/Alert/AlertTypography.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRootPortal.js.map +1 -1
- package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
- package/dist/cssm/components/AppRoot/types.js.map +1 -1
- package/dist/cssm/components/AspectRatio/AspectRatio.js.map +1 -1
- package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
- package/dist/cssm/components/Avatar/Avatar.module.css +0 -5
- package/dist/cssm/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.js.map +1 -1
- package/dist/cssm/components/Badge/Badge.js.map +1 -1
- package/dist/cssm/components/Banner/Banner.js.map +1 -1
- package/dist/cssm/components/Box/Box.js.map +1 -1
- package/dist/cssm/components/Button/Button.js +1 -1
- package/dist/cssm/components/Button/Button.js.map +1 -1
- package/dist/cssm/components/ButtonGroup/ButtonGroup.js.map +1 -1
- package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
- package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
- package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
- package/dist/cssm/components/CalendarTime/CalendarTimePicker.js.map +1 -1
- package/dist/cssm/components/Card/Card.js.map +1 -1
- package/dist/cssm/components/CardGrid/CardGrid.js.map +1 -1
- package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/cssm/components/CarouselBase/Bullets.js.map +1 -1
- package/dist/cssm/components/CarouselBase/CarouselViewPort.js.map +1 -1
- package/dist/cssm/components/CarouselBase/ScrollArrows.js.map +1 -1
- package/dist/cssm/components/CarouselBase/helpers.js.map +1 -1
- package/dist/cssm/components/CarouselBase/types.js.map +1 -1
- package/dist/cssm/components/Cell/Cell.js.map +1 -1
- package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
- package/dist/cssm/components/Cell/CellDragger/CellDragger.js.map +1 -1
- package/dist/cssm/components/CellButton/CellButton.js +115 -7
- package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
- package/dist/cssm/components/CellButton/CellButton.module.css +165 -7
- package/dist/cssm/components/Checkbox/Checkbox.js.map +1 -1
- package/dist/cssm/components/Checkbox/CheckboxInput/CheckboxInput.js.map +1 -1
- package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
- package/dist/cssm/components/ChipsInput/useChipsInput.js.map +1 -1
- package/dist/cssm/components/ChipsInputBase/Chip/Chip.js.map +1 -1
- package/dist/cssm/components/ChipsInputBase/types.js.map +1 -1
- package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
- package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
- package/dist/cssm/components/Clickable/Clickable.js.map +1 -1
- package/dist/cssm/components/Clickable/useState.js.map +1 -1
- package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
- package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
- package/dist/cssm/components/Counter/Counter.js.map +1 -1
- package/dist/cssm/components/CustomScrollView/CustomScrollView.js.map +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelect.module.css +0 -6
- package/dist/cssm/components/CustomSelect/CustomSelectClearButton.js.map +1 -1
- package/dist/cssm/components/CustomSelect/CustomSelectInput/CustomSelectInput.js.map +1 -1
- package/dist/cssm/components/CustomSelect/hooks/useDropdownOpenedController.js.map +1 -1
- package/dist/cssm/components/CustomSelect/hooks/useSelectedOptionController.js.map +1 -1
- package/dist/cssm/components/CustomSelect/types.js.map +1 -1
- package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
- package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/cssm/components/DateInput/DateInput.js +3 -12
- package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
- package/dist/cssm/components/DateInput/hooks.js.map +1 -1
- package/dist/cssm/components/DateRangeInput/DateRangeInput.js +2 -11
- package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
- package/dist/cssm/components/DropZone/DropZone.js +1 -1
- package/dist/cssm/components/DropZone/DropZone.js.map +1 -1
- package/dist/cssm/components/DropZone/DropZoneGrid/DropZoneGrid.js.map +1 -0
- package/dist/cssm/components/DropdownIcon/DropdownIcon.js.map +1 -1
- package/dist/cssm/components/Epic/Epic.js.map +1 -1
- package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
- package/dist/cssm/components/File/File.js.map +1 -1
- package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
- package/dist/cssm/components/Flex/Flex.js +2 -10
- package/dist/cssm/components/Flex/Flex.js.map +1 -1
- package/dist/cssm/components/Flex/FlexItem/FlexItem.js +5 -14
- package/dist/cssm/components/Flex/FlexItem/FlexItem.js.map +1 -1
- package/dist/cssm/components/Flex/FlexItem/FlexItem.module.css +0 -22
- package/dist/cssm/components/FloatingArrow/FloatingArrow.js.map +1 -1
- package/dist/cssm/components/FocusTrap/FocusTrap.js +2 -4
- package/dist/cssm/components/FocusTrap/FocusTrap.js.map +1 -1
- package/dist/cssm/components/FormField/FormField.js.map +1 -1
- package/dist/cssm/components/FormFieldClearButton/FormFieldClearButton.js.map +1 -1
- package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
- package/dist/cssm/components/FormItem/FormItem.module.css +1 -2
- package/dist/cssm/components/FormItem/context.js.map +1 -1
- package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
- package/dist/cssm/components/FormStatus/FormStatus.js.map +1 -1
- package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
- package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
- package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
- package/dist/cssm/components/Group/Group.js.map +1 -1
- package/dist/cssm/components/Group/GroupContainer.js.map +1 -1
- package/dist/cssm/components/Group/GroupExpandedContent.js.map +1 -1
- package/dist/cssm/components/Header/Header.js.map +1 -1
- package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
- package/dist/cssm/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.js.map +1 -1
- package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +20 -6
- package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
- package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
- package/dist/cssm/components/Image/Image.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBase.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseOverlay/types.js.map +1 -1
- package/dist/cssm/components/ImageBase/types.js.map +1 -1
- package/dist/cssm/components/Input/Input.js.map +1 -1
- package/dist/cssm/components/InputLike/InputLike.js.map +1 -1
- package/dist/cssm/components/Link/Link.js.map +1 -1
- package/dist/cssm/components/List/List.js.map +1 -1
- package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
- package/dist/cssm/components/ModalCard/ModalCardInternal.js.map +1 -1
- package/dist/cssm/components/ModalCard/types.js.map +1 -1
- package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
- package/dist/cssm/components/ModalCardBase/ModalCardBase.module.css +0 -4
- package/dist/cssm/components/ModalDismissButton/ModalDismissButton.js.map +1 -1
- package/dist/cssm/components/ModalOutlet/ModalOutlet.js.map +1 -1
- package/dist/cssm/components/ModalOutsideButton/ModalOutsideButton.js.map +1 -1
- package/dist/cssm/components/ModalOverlay/ModalOverlay.js.map +1 -1
- package/dist/cssm/components/ModalPage/ModalPageBase.js.map +1 -1
- package/dist/cssm/components/ModalPage/ModalPageInternal.js.map +1 -1
- package/dist/cssm/components/ModalPage/types.js.map +1 -1
- package/dist/cssm/components/ModalPageFooter/ModalPageFooter.js.map +1 -1
- package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
- package/dist/cssm/components/ModalRoot/types.js.map +1 -1
- package/dist/cssm/components/ModalRoot/useModalRootManager.js.map +1 -1
- package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/cssm/components/NumberInputLike/NumberInputLike.js.map +1 -1
- package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js +12 -3
- package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
- package/dist/cssm/components/OnboardingTooltip/OnboardingTooltipContainer.js.map +1 -1
- package/dist/cssm/components/Pagination/Pagination.js +14 -6
- package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
- package/dist/cssm/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.js.map +1 -1
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageButton.js.map +1 -1
- package/dist/cssm/components/Pagination/PaginationPage/PaginationPageEllipsis.js.map +1 -1
- package/dist/cssm/components/Pagination/PaginationPage/usePaginationPageClasses.js.map +1 -1
- package/dist/cssm/components/Panel/Panel.js.map +1 -1
- package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/cssm/components/PanelHeader/PanelHeader.module.css +0 -5
- package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
- package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
- package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.js.map +1 -1
- package/dist/cssm/components/PanelHeaderEdit/PanelHeaderEdit.js.map +1 -1
- package/dist/cssm/components/PanelSpinner/PanelSpinner.js.map +1 -1
- package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
- package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
- package/dist/cssm/components/Popover/Popover.js.map +1 -1
- package/dist/cssm/components/Popper/Popper.js +13 -7
- package/dist/cssm/components/Popper/Popper.js.map +1 -1
- package/dist/cssm/components/Progress/Progress.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
- package/dist/cssm/components/Radio/Radio.js +2 -2
- package/dist/cssm/components/Radio/Radio.js.map +1 -1
- package/dist/cssm/components/Radio/RadioInput/RadioInput.js.map +1 -1
- package/dist/cssm/components/RadioGroup/RadioGroup.js.map +1 -1
- package/dist/cssm/components/Removable/Removable.js.map +1 -1
- package/dist/cssm/components/Removable/Removable.module.css +0 -4
- package/dist/cssm/components/Removable/RemovableIos.js.map +1 -1
- package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
- package/dist/cssm/components/Root/Root.js.map +1 -1
- package/dist/cssm/components/RootComponent/RootComponent.js.map +1 -1
- package/dist/cssm/components/ScreenSpinner/ScreenSpinnerSwapIcon.js.map +1 -1
- package/dist/cssm/components/ScreenSpinner/context.js.map +1 -1
- package/dist/cssm/components/ScreenSpinner/types.js.map +1 -1
- package/dist/cssm/components/ScrollArrow/ScrollArrow.js +14 -4
- package/dist/cssm/components/ScrollArrow/ScrollArrow.js.map +1 -1
- package/dist/cssm/components/Search/Search.js.map +1 -1
- package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
- package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
- package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
- package/dist/cssm/components/SelectTypography/SelectTypography.js.map +1 -1
- package/dist/cssm/components/SelectionControl/SelectionControl.js.map +1 -1
- package/dist/cssm/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.js.map +1 -1
- package/dist/cssm/components/Separator/Separator.js.map +1 -1
- package/dist/cssm/components/SimpleCell/Chevron/Chevron.js.map +1 -1
- package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
- package/dist/cssm/components/SimpleCell/SimpleCell.module.css +3 -5
- package/dist/cssm/components/SimpleGrid/SimpleGrid.js.map +1 -1
- package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
- package/dist/cssm/components/Slider/Slider.js.map +1 -1
- package/dist/cssm/components/Slider/SliderThumb/SliderThumb.js.map +1 -1
- package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.js.map +1 -1
- package/dist/cssm/components/Snackbar/subcomponents/Basic/Basic.module.css +2 -4
- package/dist/cssm/components/Snackbar/utils.js.map +1 -1
- package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
- package/dist/cssm/components/Spinner/Spinner.js.map +1 -1
- package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
- package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
- package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
- package/dist/cssm/components/Switch/Switch.js.map +1 -1
- package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
- package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
- package/dist/cssm/components/Tabs/Tabs.js.map +1 -1
- package/dist/cssm/components/Tabs/TabsModeContext.js.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
- package/dist/cssm/components/Tappable/state.js.map +1 -1
- package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
- package/dist/cssm/components/ToolButton/ToolButton.js.map +1 -1
- package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
- package/dist/cssm/components/TooltipBase/TooltipBase.js.map +1 -1
- package/dist/cssm/components/Touch/Touch.js.map +1 -1
- package/dist/cssm/components/Typography/Caption/Caption.js.map +1 -1
- package/dist/cssm/components/Typography/DisplayTitle/DisplayTitle.js.map +1 -1
- package/dist/cssm/components/Typography/EllipsisText/EllipsisText.js.map +1 -1
- package/dist/cssm/components/Typography/Headline/Headline.js.map +1 -1
- package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
- package/dist/cssm/components/Typography/Typography.js.map +1 -1
- package/dist/cssm/components/UnstyledTextField/UnstyledTextField.js.map +1 -1
- package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
- package/dist/cssm/components/View/View.js.map +1 -1
- package/dist/cssm/components/View/View.module.css +1 -3
- package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
- package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
- package/dist/cssm/helpers/math.js.map +1 -1
- package/dist/cssm/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
- package/dist/cssm/hooks/useAutoDetectColorScheme.js +8 -27
- package/dist/cssm/hooks/useAutoDetectColorScheme.js.map +1 -1
- package/dist/cssm/hooks/useCalendar.js.map +1 -1
- package/dist/cssm/hooks/useDateInput.js.map +1 -1
- package/dist/cssm/hooks/useDraggableWithDomApi/types.js.map +1 -1
- package/dist/cssm/hooks/useEnsuredControl.js.map +1 -1
- package/dist/cssm/hooks/useFloatingElement.js.map +1 -1
- package/dist/cssm/hooks/useFocusTrap/FocusGuard.js.map +1 -1
- package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js +10 -2
- package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
- package/dist/cssm/hooks/useFocusVisibleClassName.js.map +1 -1
- package/dist/cssm/hooks/useGlobalEscKeyDown.js.map +1 -1
- package/dist/cssm/hooks/useMediaQueryMatch.js +25 -0
- package/dist/cssm/hooks/useMediaQueryMatch.js.map +1 -0
- package/dist/cssm/hooks/useMergeProps.js.map +1 -1
- package/dist/cssm/hooks/useModalManager/types.js.map +1 -1
- package/dist/cssm/hooks/usePagination.js.map +1 -1
- package/dist/cssm/hooks/usePatchChildren.js.map +1 -1
- package/dist/cssm/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.js → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.js} +2 -2
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.js.map +1 -0
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarHolder.js +5 -2
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarHolder.js.map +1 -1
- package/dist/cssm/hooks/useSnackbarManager/components/{SnackbarsContainer.js → SnackbarsContainer/SnackbarsContainer.js} +3 -3
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarsContainer/SnackbarsContainer.js.map +1 -0
- package/dist/cssm/hooks/useSnackbarManager/types.js.map +1 -1
- package/dist/cssm/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
- package/dist/cssm/index.js +1 -1
- package/dist/cssm/index.js.map +1 -1
- package/dist/cssm/lib/SSR.js.map +1 -1
- package/dist/cssm/lib/accessibility.js.map +1 -1
- package/dist/cssm/lib/adaptivity/functions.js +6 -0
- package/dist/cssm/lib/adaptivity/functions.js.map +1 -1
- package/dist/cssm/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
- package/dist/cssm/lib/animation/useCSSTransition.js +4 -2
- package/dist/cssm/lib/animation/useCSSTransition.js.map +1 -1
- package/dist/cssm/lib/animation/useReducedMotion.js +2 -20
- package/dist/cssm/lib/animation/useReducedMotion.js.map +1 -1
- package/dist/cssm/lib/calendar.js.map +1 -1
- package/dist/cssm/lib/date.js.map +1 -1
- package/dist/cssm/lib/dom.js.map +1 -1
- package/dist/cssm/lib/floating/functions.js.map +1 -1
- package/dist/cssm/lib/floating/types/component.js.map +1 -1
- package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js +6 -4
- package/dist/cssm/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
- package/dist/cssm/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
- package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +6 -2
- package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
- package/dist/cssm/lib/getNavId.js.map +1 -1
- package/dist/cssm/lib/layouts/layoutProps.js +17 -0
- package/dist/cssm/lib/layouts/layoutProps.js.map +1 -1
- package/dist/cssm/lib/layouts/resolveLayoutProps.js.map +1 -1
- package/dist/cssm/lib/layouts/types.js.map +1 -1
- package/dist/cssm/lib/select.js.map +1 -1
- package/dist/cssm/lib/sheet/useBottomSheet.js.map +1 -1
- package/dist/cssm/lib/tokens/TokensClassProvider.js.map +1 -1
- package/dist/cssm/lib/tokens/types.js.map +1 -1
- package/dist/cssm/lib/utils.js +3 -0
- package/dist/cssm/lib/utils.js.map +1 -1
- package/dist/cssm/styles/layout.css +36 -0
- package/dist/cssm/types.js +4 -1
- package/dist/cssm/types.js.map +1 -1
- package/dist/helpers/math.d.ts +1 -1
- package/dist/helpers/math.d.ts.map +1 -1
- package/dist/helpers/math.js.map +1 -1
- package/dist/hooks/useAdaptivityWithJSMediaQueries.d.ts +5 -1
- package/dist/hooks/useAdaptivityWithJSMediaQueries.d.ts.map +1 -1
- package/dist/hooks/useAdaptivityWithJSMediaQueries.js.map +1 -1
- package/dist/hooks/useAutoDetectColorScheme.d.ts.map +1 -1
- package/dist/hooks/useAutoDetectColorScheme.js +8 -27
- package/dist/hooks/useAutoDetectColorScheme.js.map +1 -1
- package/dist/hooks/useCalendar.d.ts +1 -1
- package/dist/hooks/useCalendar.d.ts.map +1 -1
- package/dist/hooks/useCalendar.js.map +1 -1
- package/dist/hooks/useDateInput.d.ts +5 -5
- package/dist/hooks/useDateInput.d.ts.map +1 -1
- package/dist/hooks/useDateInput.js.map +1 -1
- package/dist/hooks/useDraggableWithDomApi/types.d.ts +1 -1
- package/dist/hooks/useDraggableWithDomApi/types.d.ts.map +1 -1
- package/dist/hooks/useDraggableWithDomApi/types.js.map +1 -1
- package/dist/hooks/useEnsuredControl.d.ts +4 -4
- package/dist/hooks/useEnsuredControl.d.ts.map +1 -1
- package/dist/hooks/useEnsuredControl.js.map +1 -1
- package/dist/hooks/useFloatingElement.d.ts +4 -4
- package/dist/hooks/useFloatingElement.d.ts.map +1 -1
- package/dist/hooks/useFloatingElement.js.map +1 -1
- package/dist/hooks/useFocusTrap/FocusGuard.d.ts +1 -1
- package/dist/hooks/useFocusTrap/FocusGuard.d.ts.map +1 -1
- package/dist/hooks/useFocusTrap/FocusGuard.js.map +1 -1
- package/dist/hooks/useFocusTrap/useFocusTrap.d.ts +6 -10
- package/dist/hooks/useFocusTrap/useFocusTrap.d.ts.map +1 -1
- package/dist/hooks/useFocusTrap/useFocusTrap.js +10 -2
- package/dist/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
- package/dist/hooks/useFocusVisibleClassName.d.ts +3 -3
- package/dist/hooks/useFocusVisibleClassName.d.ts.map +1 -1
- package/dist/hooks/useFocusVisibleClassName.js.map +1 -1
- package/dist/hooks/useGlobalEscKeyDown.d.ts +1 -1
- package/dist/hooks/useGlobalEscKeyDown.d.ts.map +1 -1
- package/dist/hooks/useGlobalEscKeyDown.js.map +1 -1
- package/dist/hooks/useMediaQueryMatch.d.ts +6 -0
- package/dist/hooks/useMediaQueryMatch.d.ts.map +1 -0
- package/dist/hooks/useMediaQueryMatch.js +25 -0
- package/dist/hooks/useMediaQueryMatch.js.map +1 -0
- package/dist/hooks/useMergeProps.d.ts +1 -1
- package/dist/hooks/useMergeProps.d.ts.map +1 -1
- package/dist/hooks/useMergeProps.js.map +1 -1
- package/dist/hooks/useModalManager/types.d.ts +8 -8
- package/dist/hooks/useModalManager/types.d.ts.map +1 -1
- package/dist/hooks/useModalManager/types.js.map +1 -1
- package/dist/hooks/usePagination.d.ts +4 -4
- package/dist/hooks/usePagination.d.ts.map +1 -1
- package/dist/hooks/usePagination.js.map +1 -1
- package/dist/hooks/usePatchChildren.d.ts +1 -1
- package/dist/hooks/usePatchChildren.d.ts.map +1 -1
- package/dist/hooks/usePatchChildren.js.map +1 -1
- package/dist/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.d.ts → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.d.ts} +1 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.d.ts.map +1 -0
- package/dist/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.js → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.js} +10 -10
- package/dist/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.js.map +1 -0
- package/dist/hooks/useSnackbarManager/components/SnackbarHolder.d.ts.map +1 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarHolder.js +5 -2
- package/dist/hooks/useSnackbarManager/components/SnackbarHolder.js.map +1 -1
- package/dist/hooks/useSnackbarManager/components/{SnackbarsContainer.d.ts → SnackbarsContainer/SnackbarsContainer.d.ts} +2 -2
- package/dist/hooks/useSnackbarManager/components/SnackbarsContainer/SnackbarsContainer.d.ts.map +1 -0
- package/dist/hooks/useSnackbarManager/components/{SnackbarsContainer.js → SnackbarsContainer/SnackbarsContainer.js} +10 -10
- package/dist/hooks/useSnackbarManager/components/SnackbarsContainer/SnackbarsContainer.js.map +1 -0
- package/dist/hooks/useSnackbarManager/types.d.ts +11 -11
- package/dist/hooks/useSnackbarManager/types.d.ts.map +1 -1
- package/dist/hooks/useSnackbarManager/types.js.map +1 -1
- package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.d.ts +1 -1
- package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.d.ts.map +1 -1
- package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/lib/SSR.d.ts +4 -4
- package/dist/lib/SSR.d.ts.map +1 -1
- package/dist/lib/SSR.js.map +1 -1
- package/dist/lib/accessibility.d.ts +1 -1
- package/dist/lib/accessibility.d.ts.map +1 -1
- package/dist/lib/accessibility.js.map +1 -1
- package/dist/lib/adaptivity/functions.d.ts.map +1 -1
- package/dist/lib/adaptivity/functions.js +6 -0
- package/dist/lib/adaptivity/functions.js.map +1 -1
- package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts +6 -6
- package/dist/lib/animation/useCSSKeyframesAnimationController.d.ts.map +1 -1
- package/dist/lib/animation/useCSSKeyframesAnimationController.js.map +1 -1
- package/dist/lib/animation/useCSSTransition.d.ts +11 -11
- package/dist/lib/animation/useCSSTransition.d.ts.map +1 -1
- package/dist/lib/animation/useCSSTransition.js +4 -2
- package/dist/lib/animation/useCSSTransition.js.map +1 -1
- package/dist/lib/animation/useReducedMotion.d.ts.map +1 -1
- package/dist/lib/animation/useReducedMotion.js +2 -20
- package/dist/lib/animation/useReducedMotion.js.map +1 -1
- package/dist/lib/calendar.d.ts +5 -5
- package/dist/lib/calendar.d.ts.map +1 -1
- package/dist/lib/calendar.js.map +1 -1
- package/dist/lib/date.d.ts +10 -10
- package/dist/lib/date.d.ts.map +1 -1
- package/dist/lib/date.js.map +1 -1
- package/dist/lib/dom.d.ts +2 -2
- package/dist/lib/dom.d.ts.map +1 -1
- package/dist/lib/dom.js.map +1 -1
- package/dist/lib/floating/functions.d.ts +2 -2
- package/dist/lib/floating/functions.d.ts.map +1 -1
- package/dist/lib/floating/functions.js.map +1 -1
- package/dist/lib/floating/types/component.d.ts +9 -9
- package/dist/lib/floating/types/component.d.ts.map +1 -1
- package/dist/lib/floating/types/component.js.map +1 -1
- package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts +14 -14
- package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.d.ts.map +1 -1
- package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js +6 -4
- package/dist/lib/floating/useFloatingMiddlewaresBootstrap/index.js.map +1 -1
- package/dist/lib/floating/useFloatingWithInteractions/types.d.ts +15 -15
- package/dist/lib/floating/useFloatingWithInteractions/types.d.ts.map +1 -1
- package/dist/lib/floating/useFloatingWithInteractions/types.js.map +1 -1
- package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +6 -2
- package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
- package/dist/lib/getNavId.d.ts +2 -2
- package/dist/lib/getNavId.d.ts.map +1 -1
- package/dist/lib/getNavId.js.map +1 -1
- package/dist/lib/layouts/layoutProps.d.ts +2 -0
- package/dist/lib/layouts/layoutProps.d.ts.map +1 -1
- package/dist/lib/layouts/layoutProps.js +17 -0
- package/dist/lib/layouts/layoutProps.js.map +1 -1
- package/dist/lib/layouts/resolveLayoutProps.d.ts +6 -6
- package/dist/lib/layouts/resolveLayoutProps.d.ts.map +1 -1
- package/dist/lib/layouts/resolveLayoutProps.js.map +1 -1
- package/dist/lib/layouts/types.d.ts +39 -27
- package/dist/lib/layouts/types.d.ts.map +1 -1
- package/dist/lib/layouts/types.js.map +1 -1
- package/dist/lib/select.d.ts +2 -2
- package/dist/lib/select.d.ts.map +1 -1
- package/dist/lib/select.js.map +1 -1
- package/dist/lib/sheet/useBottomSheet.d.ts +4 -4
- package/dist/lib/sheet/useBottomSheet.d.ts.map +1 -1
- package/dist/lib/sheet/useBottomSheet.js.map +1 -1
- package/dist/lib/tokens/TokensClassProvider.js.map +1 -1
- package/dist/lib/tokens/types.d.ts +2 -2
- package/dist/lib/tokens/types.d.ts.map +1 -1
- package/dist/lib/tokens/types.js.map +1 -1
- package/dist/lib/utils.d.ts +3 -3
- package/dist/lib/utils.d.ts.map +1 -1
- package/dist/lib/utils.js +3 -0
- package/dist/lib/utils.js.map +1 -1
- package/dist/types.d.ts +17 -10
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +4 -1
- package/dist/types.js.map +1 -1
- package/dist/vkui.css +1 -1
- package/dist/vkui.css.map +1 -1
- package/package.json +3 -3
- package/src/components/Accordion/Accordion.tsx +10 -6
- package/src/components/Accordion/AccordionIcon.tsx +31 -0
- package/src/components/Accordion/AccordionSummary.tsx +5 -9
- package/src/components/ActionSheet/ActionSheet.tsx +14 -10
- package/src/components/ActionSheet/ActionSheetContext.ts +3 -3
- package/src/components/ActionSheet/types.ts +8 -8
- package/src/components/ActionSheetItem/ActionSheetItem.module.css +0 -1
- package/src/components/ActionSheetItem/ActionSheetItem.module.css.d.ts.map +1 -1
- package/src/components/ActionSheetItem/ActionSheetItem.tsx +15 -15
- package/src/components/ActionSheetItem/subcomponents/Radio/Radio.tsx +1 -1
- package/src/components/AdaptivityProvider/AdaptivityContext.tsx +7 -7
- package/src/components/Alert/Alert.tsx +17 -17
- package/src/components/Alert/AlertBase.tsx +2 -2
- package/src/components/Alert/AlertTypography.tsx +1 -1
- package/src/components/AppRoot/AppRoot.tsx +9 -9
- package/src/components/AppRoot/AppRootContext.ts +4 -4
- package/src/components/AppRoot/AppRootPortal.tsx +2 -2
- package/src/components/AppRoot/ScrollContext.tsx +5 -5
- package/src/components/AppRoot/types.ts +4 -4
- package/src/components/AspectRatio/AspectRatio.tsx +2 -2
- package/src/components/Avatar/Avatar.module.css +0 -5
- package/src/components/Avatar/Avatar.module.css.d.ts.map +1 -1
- package/src/components/Avatar/Avatar.tsx +6 -2
- package/src/components/Avatar/AvatarBadge/AvatarBadgeWithPreset.tsx +1 -1
- package/src/components/Badge/Badge.tsx +1 -1
- package/src/components/Banner/Banner.tsx +12 -12
- package/src/components/Box/Box.tsx +1 -1
- package/src/components/Button/Button.tsx +19 -12
- package/src/components/ButtonGroup/ButtonGroup.tsx +4 -4
- package/src/components/Calendar/Calendar.tsx +17 -17
- package/src/components/CalendarDay/CalendarDay.tsx +18 -18
- package/src/components/CalendarDays/CalendarDays.tsx +14 -14
- package/src/components/CalendarHeader/CalendarHeader.tsx +19 -19
- package/src/components/CalendarRange/CalendarRange.tsx +12 -12
- package/src/components/CalendarTime/CalendarTime.tsx +14 -14
- package/src/components/CalendarTime/CalendarTimePicker.tsx +3 -3
- package/src/components/Card/Card.tsx +1 -1
- package/src/components/CardGrid/CardGrid.tsx +2 -2
- package/src/components/CardScroll/CardScroll.tsx +3 -3
- package/src/components/CarouselBase/Bullets.tsx +1 -1
- package/src/components/CarouselBase/CarouselViewPort.tsx +1 -1
- package/src/components/CarouselBase/ScrollArrows.tsx +2 -2
- package/src/components/CarouselBase/helpers.ts +4 -4
- package/src/components/CarouselBase/types.ts +23 -23
- package/src/components/Cell/Cell.tsx +8 -8
- package/src/components/Cell/CellCheckbox/CellCheckbox.tsx +1 -1
- package/src/components/Cell/CellDragger/CellDragger.tsx +2 -2
- package/src/components/CellButton/CellButton.module.css +159 -7
- package/src/components/CellButton/CellButton.module.css.d.ts.map +1 -1
- package/src/components/CellButton/CellButton.tsx +154 -11
- package/src/components/Checkbox/Checkbox.tsx +16 -9
- package/src/components/Checkbox/CheckboxInput/CheckboxInput.tsx +20 -14
- package/src/components/ChipsInput/ChipsInput.tsx +1 -1
- package/src/components/ChipsInput/useChipsInput.ts +3 -3
- package/src/components/ChipsInputBase/Chip/Chip.tsx +9 -9
- package/src/components/ChipsInputBase/types.ts +28 -22
- package/src/components/ChipsSelect/ChipsSelect.tsx +13 -13
- package/src/components/ChipsSelect/useChipsSelect.ts +22 -21
- package/src/components/Clickable/Clickable.tsx +1 -1
- package/src/components/Clickable/useState.tsx +13 -13
- package/src/components/ConfigProvider/ConfigProvider.tsx +2 -1
- package/src/components/ContentBadge/ContentBadge.tsx +4 -4
- package/src/components/ContentCard/ContentCard.tsx +8 -8
- package/src/components/Counter/Counter.tsx +4 -4
- package/src/components/CustomScrollView/CustomScrollView.tsx +6 -6
- package/src/components/CustomSelect/CustomSelect.module.css +0 -6
- package/src/components/CustomSelect/CustomSelect.module.css.d.ts.map +1 -1
- package/src/components/CustomSelect/CustomSelect.tsx +42 -29
- package/src/components/CustomSelect/CustomSelectClearButton.tsx +2 -2
- package/src/components/CustomSelect/CustomSelectInput/CustomSelectInput.tsx +20 -14
- package/src/components/CustomSelect/hooks/useDropdownOpenedController.ts +2 -2
- package/src/components/CustomSelect/hooks/useSelectedOptionController.ts +1 -1
- package/src/components/CustomSelect/types.ts +1 -1
- package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +8 -8
- package/src/components/CustomSelectOption/CustomSelectOption.tsx +9 -9
- package/src/components/DateInput/DateInput.tsx +27 -35
- package/src/components/DateInput/hooks.ts +7 -7
- package/src/components/DateRangeInput/DateRangeInput.tsx +28 -36
- package/src/components/DropZone/DropZone.tsx +5 -2
- package/src/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.tsx +1 -1
- package/src/components/DropdownIcon/DropdownIcon.tsx +1 -1
- package/src/components/Epic/Epic.tsx +1 -1
- package/src/components/Epic/ScrollSaver.tsx +1 -1
- package/src/components/File/File.tsx +15 -9
- package/src/components/FixedLayout/FixedLayout.tsx +3 -3
- package/src/components/Flex/Flex.tsx +8 -23
- package/src/components/Flex/FlexItem/FlexItem.module.css +0 -22
- package/src/components/Flex/FlexItem/FlexItem.module.css.d.ts.map +1 -1
- package/src/components/Flex/FlexItem/FlexItem.tsx +17 -44
- package/src/components/FloatingArrow/FloatingArrow.tsx +9 -9
- package/src/components/FocusTrap/FocusTrap.tsx +0 -3
- package/src/components/FormField/FormField.tsx +8 -8
- package/src/components/FormFieldClearButton/FormFieldClearButton.tsx +2 -2
- package/src/components/FormItem/FormItem.module.css +1 -2
- package/src/components/FormItem/FormItem.module.css.d.ts.map +1 -1
- package/src/components/FormItem/FormItem.tsx +10 -10
- package/src/components/FormItem/context.ts +2 -2
- package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +4 -4
- package/src/components/FormStatus/FormStatus.tsx +2 -2
- package/src/components/Gallery/Gallery.tsx +2 -2
- package/src/components/Gradient/Gradient.tsx +2 -2
- package/src/components/GridAvatar/GridAvatar.tsx +1 -1
- package/src/components/Group/Group.tsx +2 -2
- package/src/components/Group/GroupContainer.tsx +3 -3
- package/src/components/Group/GroupExpandedContent.tsx +1 -1
- package/src/components/Header/Header.tsx +11 -11
- package/src/components/HorizontalCell/HorizontalCell.tsx +7 -7
- package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.tsx +4 -4
- package/src/components/HorizontalScroll/HorizontalScroll.tsx +63 -18
- package/src/components/IconButton/IconButton.tsx +1 -1
- package/src/components/Image/Image.tsx +5 -5
- package/src/components/ImageBase/ImageBase.tsx +19 -15
- package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.tsx +1 -1
- package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.tsx +3 -3
- package/src/components/ImageBase/ImageBaseOverlay/types.ts +3 -3
- package/src/components/ImageBase/types.ts +3 -3
- package/src/components/Input/Input.tsx +13 -7
- package/src/components/InputLike/InputLike.tsx +3 -3
- package/src/components/Link/Link.tsx +4 -4
- package/src/components/List/List.tsx +1 -1
- package/src/components/MiniInfoCell/MiniInfoCell.tsx +5 -5
- package/src/components/ModalCard/ModalCardInternal.tsx +1 -1
- package/src/components/ModalCard/types.ts +13 -13
- package/src/components/ModalCardBase/ModalCardBase.module.css +0 -4
- package/src/components/ModalCardBase/ModalCardBase.module.css.d.ts.map +1 -1
- package/src/components/ModalCardBase/ModalCardBase.tsx +14 -14
- package/src/components/ModalDismissButton/ModalDismissButton.tsx +1 -1
- package/src/components/ModalOutlet/ModalOutlet.tsx +3 -3
- package/src/components/ModalOutsideButton/ModalOutsideButton.tsx +1 -1
- package/src/components/ModalOverlay/ModalOverlay.tsx +7 -7
- package/src/components/ModalPage/ModalPageBase.tsx +2 -2
- package/src/components/ModalPage/ModalPageInternal.tsx +2 -2
- package/src/components/ModalPage/types.ts +27 -27
- package/src/components/ModalPageFooter/ModalPageFooter.tsx +2 -2
- package/src/components/ModalPageHeader/ModalPageHeader.tsx +1 -1
- package/src/components/ModalRoot/types.ts +15 -15
- package/src/components/ModalRoot/useModalRootManager.tsx +19 -19
- package/src/components/NativeSelect/NativeSelect.tsx +20 -14
- package/src/components/NumberInputLike/NumberInputLike.tsx +3 -3
- package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +16 -8
- package/src/components/OnboardingTooltip/OnboardingTooltipContainer.tsx +1 -1
- package/src/components/Pagination/Pagination.tsx +27 -25
- package/src/components/Pagination/PaginationNavigationButton/PaginationNavigationButton.tsx +5 -3
- package/src/components/Pagination/PaginationPage/PaginationPageButton.tsx +3 -3
- package/src/components/Pagination/PaginationPage/PaginationPageEllipsis.tsx +1 -1
- package/src/components/Pagination/PaginationPage/usePaginationPageClasses.ts +3 -3
- package/src/components/Panel/Panel.tsx +3 -3
- package/src/components/PanelHeader/PanelHeader.module.css +0 -5
- package/src/components/PanelHeader/PanelHeader.module.css.d.ts.map +1 -1
- package/src/components/PanelHeader/PanelHeader.tsx +14 -12
- package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +2 -2
- package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +3 -3
- package/src/components/PanelHeaderContent/PanelHeaderContent.tsx +3 -3
- package/src/components/PanelHeaderEdit/PanelHeaderEdit.tsx +3 -3
- package/src/components/PanelSpinner/PanelSpinner.tsx +1 -1
- package/src/components/Placeholder/Placeholder.tsx +5 -5
- package/src/components/PopoutWrapper/PopoutWrapper.tsx +6 -6
- package/src/components/Popover/Popover.tsx +5 -5
- package/src/components/Popper/Popper.tsx +17 -15
- package/src/components/Progress/Progress.tsx +4 -4
- package/src/components/PullToRefresh/PullToRefresh.tsx +2 -2
- package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +4 -4
- package/src/components/Radio/Radio.tsx +18 -12
- package/src/components/Radio/RadioInput/RadioInput.tsx +15 -9
- package/src/components/RadioGroup/RadioGroup.tsx +1 -1
- package/src/components/Removable/Removable.module.css +0 -4
- package/src/components/Removable/Removable.module.css.d.ts.map +1 -1
- package/src/components/Removable/Removable.tsx +13 -10
- package/src/components/Removable/RemovableIos.tsx +6 -3
- package/src/components/RichCell/RichCell.tsx +15 -15
- package/src/components/Root/Root.tsx +3 -3
- package/src/components/RootComponent/RootComponent.tsx +2 -2
- package/src/components/ScreenSpinner/ScreenSpinnerSwapIcon.tsx +1 -1
- package/src/components/ScreenSpinner/context.ts +2 -2
- package/src/components/ScreenSpinner/types.tsx +5 -5
- package/src/components/ScrollArrow/ScrollArrow.tsx +27 -4
- package/src/components/Search/Search.tsx +28 -22
- package/src/components/SegmentedControl/SegmentedControl.tsx +6 -6
- package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +3 -3
- package/src/components/SelectMimicry/SelectMimicry.tsx +3 -3
- package/src/components/SelectTypography/SelectTypography.tsx +1 -1
- package/src/components/SelectionControl/SelectionControl.tsx +1 -1
- package/src/components/SelectionControl/SelectionControlLabel/SelectionControlLabel.tsx +2 -2
- package/src/components/Separator/Separator.tsx +5 -5
- package/src/components/SimpleCell/Chevron/Chevron.tsx +1 -1
- package/src/components/SimpleCell/SimpleCell.module.css +3 -5
- package/src/components/SimpleCell/SimpleCell.module.css.d.ts.map +1 -1
- package/src/components/SimpleCell/SimpleCell.tsx +14 -14
- package/src/components/SimpleGrid/SimpleGrid.tsx +6 -6
- package/src/components/Skeleton/Skeleton.tsx +5 -5
- package/src/components/Slider/Slider.tsx +19 -17
- package/src/components/Slider/SliderThumb/SliderThumb.tsx +9 -7
- package/src/components/Snackbar/Snackbar.tsx +19 -13
- package/src/components/Snackbar/subcomponents/Basic/Basic.module.css +2 -4
- package/src/components/Snackbar/subcomponents/Basic/Basic.module.css.d.ts.map +1 -1
- package/src/components/Snackbar/subcomponents/Basic/Basic.tsx +6 -6
- package/src/components/Snackbar/utils.ts +1 -1
- package/src/components/Spacing/Spacing.tsx +2 -2
- package/src/components/Spinner/Spinner.tsx +4 -4
- package/src/components/SplitCol/SplitCol.tsx +7 -7
- package/src/components/SplitLayout/SplitLayout.tsx +15 -9
- package/src/components/SubnavigationBar/SubnavigationBar.tsx +2 -2
- package/src/components/SubnavigationButton/SubnavigationButton.tsx +8 -8
- package/src/components/Switch/Switch.tsx +15 -9
- package/src/components/Tabbar/Tabbar.tsx +2 -2
- package/src/components/TabbarItem/TabbarItem.tsx +3 -3
- package/src/components/Tabs/Tabs.tsx +7 -7
- package/src/components/Tabs/TabsModeContext.ts +1 -1
- package/src/components/TabsItem/TabsItem.tsx +5 -5
- package/src/components/Tappable/Tappable.tsx +3 -3
- package/src/components/Tappable/state.tsx +2 -2
- package/src/components/Textarea/Textarea.tsx +14 -10
- package/src/components/ToolButton/ToolButton.tsx +4 -4
- package/src/components/Tooltip/Tooltip.tsx +6 -6
- package/src/components/TooltipBase/TooltipBase.tsx +10 -10
- package/src/components/Touch/Touch.tsx +16 -16
- package/src/components/Typography/Caption/Caption.tsx +1 -1
- package/src/components/Typography/DisplayTitle/DisplayTitle.tsx +1 -1
- package/src/components/Typography/EllipsisText/EllipsisText.tsx +3 -3
- package/src/components/Typography/Headline/Headline.tsx +1 -1
- package/src/components/Typography/Title/Title.tsx +1 -1
- package/src/components/Typography/Typography.tsx +6 -6
- package/src/components/UnstyledTextField/UnstyledTextField.tsx +1 -1
- package/src/components/UsersStack/UsersStack.tsx +6 -6
- package/src/components/View/View.module.css +1 -3
- package/src/components/View/View.module.css.d.ts.map +1 -1
- package/src/components/View/View.tsx +4 -4
- package/src/components/View/ViewInfinite.tsx +11 -11
- package/src/components/WriteBar/WriteBar.tsx +21 -15
- package/src/components/WriteBarIcon/WriteBarIcon.tsx +3 -3
- package/src/helpers/math.ts +1 -1
- package/src/hooks/useAdaptivityWithJSMediaQueries.ts +3 -1
- package/src/hooks/useAutoDetectColorScheme.ts +8 -30
- package/src/hooks/useCalendar.ts +2 -2
- package/src/hooks/useDateInput.ts +5 -5
- package/src/hooks/useDraggableWithDomApi/types.ts +1 -1
- package/src/hooks/useEnsuredControl.ts +4 -4
- package/src/hooks/useFloatingElement.tsx +4 -4
- package/src/hooks/useFocusTrap/FocusGuard.tsx +1 -1
- package/src/hooks/useFocusTrap/useFocusTrap.tsx +17 -15
- package/src/hooks/useFocusVisibleClassName.ts +3 -3
- package/src/hooks/useGlobalEscKeyDown.ts +2 -2
- package/src/hooks/useMediaQueryMatch.ts +34 -0
- package/src/hooks/useMergeProps.ts +2 -2
- package/src/hooks/useModalManager/types.ts +8 -8
- package/src/hooks/usePagination.ts +4 -4
- package/src/hooks/usePatchChildren.ts +1 -1
- package/src/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.tsx → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.tsx} +3 -3
- package/src/hooks/useSnackbarManager/components/SnackbarHolder.tsx +6 -2
- package/src/hooks/useSnackbarManager/components/{SnackbarsContainer.tsx → SnackbarsContainer/SnackbarsContainer.tsx} +6 -6
- package/src/hooks/useSnackbarManager/types.ts +11 -11
- package/src/hooks/useSyncHTMLWithBaseVKUIClasses.ts +1 -1
- package/src/index.ts +6 -2
- package/src/lib/SSR.tsx +4 -4
- package/src/lib/accessibility.ts +1 -1
- package/src/lib/adaptivity/functions.ts +10 -1
- package/src/lib/animation/useCSSKeyframesAnimationController.ts +6 -6
- package/src/lib/animation/useCSSTransition.ts +15 -13
- package/src/lib/animation/useReducedMotion.ts +2 -25
- package/src/lib/calendar.ts +5 -2
- package/src/lib/date.ts +11 -11
- package/src/lib/dom.tsx +2 -2
- package/src/lib/floating/functions.ts +2 -2
- package/src/lib/floating/types/component.ts +9 -9
- package/src/lib/floating/useFloatingMiddlewaresBootstrap/index.ts +26 -19
- package/src/lib/floating/useFloatingWithInteractions/types.ts +15 -15
- package/src/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.ts +2 -2
- package/src/lib/getNavId.ts +2 -2
- package/src/lib/layouts/layoutProps.ts +5 -0
- package/src/lib/layouts/resolveLayoutProps.ts +3 -3
- package/src/lib/layouts/types.ts +40 -27
- package/src/lib/select.ts +2 -2
- package/src/lib/sheet/useBottomSheet.ts +4 -4
- package/src/lib/tokens/TokensClassProvider.tsx +1 -1
- package/src/lib/tokens/types.ts +2 -2
- package/src/lib/utils.ts +8 -3
- package/src/types.ts +18 -10
- package/dist/components/DropZone/components/DropZoneGrid.d.ts.map +0 -1
- package/dist/components/DropZone/components/DropZoneGrid.js.map +0 -1
- package/dist/cssm/components/DropZone/components/DropZoneGrid.js.map +0 -1
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper.js.map +0 -1
- package/dist/cssm/hooks/useSnackbarManager/components/SnackbarsContainer.js.map +0 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper.d.ts.map +0 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarAnimatedWrapper.js.map +0 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarsContainer.d.ts.map +0 -1
- package/dist/hooks/useSnackbarManager/components/SnackbarsContainer.js.map +0 -1
- /package/dist/cssm/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.js +0 -0
- /package/dist/cssm/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.module.css +0 -0
- /package/dist/cssm/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.module.css → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.module.css} +0 -0
- /package/dist/cssm/hooks/useSnackbarManager/components/{SnackbarsContainer.module.css → SnackbarsContainer/SnackbarsContainer.module.css} +0 -0
- /package/src/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.module.css +0 -0
- /package/src/components/DropZone/{components → DropZoneGrid}/DropZoneGrid.module.css.d.ts.map +0 -0
- /package/src/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.module.css → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.module.css} +0 -0
- /package/src/hooks/useSnackbarManager/components/{SnackbarAnimatedWrapper.module.css.d.ts.map → SnackbarAnimatedWrapper/SnackbarAnimatedWrapper.module.css.d.ts.map} +0 -0
- /package/src/hooks/useSnackbarManager/components/{SnackbarsContainer.module.css → SnackbarsContainer/SnackbarsContainer.module.css} +0 -0
- /package/src/hooks/useSnackbarManager/components/{SnackbarsContainer.module.css.d.ts.map → SnackbarsContainer/SnackbarsContainer.module.css.d.ts.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/View/View.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { blurActiveElement, useDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HTMLAttributesWithRootRef } from '../../types';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport { useLayoutEffectCall } from './useLayoutEffectCall';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nexport const scrollsCache = new Map<string, Map<string, number | undefined>>();\n\nexport interface ViewProps extends HTMLAttributesWithRootRef<HTMLElement>, NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: (params: { isBack: boolean; from: string; to: string }) => void;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: () => void;\n /**\n * Обработчик начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?: (activePanel: string | null) => void | 'prevent';\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: () => void;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[];\n /**\n * Коллекция Panel. У каждой Panel должен быть уникальный `id`.\n */\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkui.io/components/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): React.ReactNode => {\n const id = getNavId({ nav, id: restProps.id });\n const [scrolls] = React.useState(\n () => scrollsCache.get(id as string) || new Map<string, number | undefined>(),\n );\n const layoutEffectCall = useLayoutEffectCall();\n\n React.useEffect(() => () => {\n if (id) {\n scrollsCache.set(id, scrolls);\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 swipeBackPrevented = React.useRef<boolean>(false);\n const [swipingBack, setSwipingBack] = React.useState<boolean | undefined>(undefined);\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<'success' | 'fail' | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = React.useRef<string>(undefined);\n const prevSwipingBack = React.useRef<boolean>(undefined);\n const prevBrowserSwipe = React.useRef<boolean>(undefined);\n const prevSwipeBackResult = React.useRef<'success' | 'fail' | null>(undefined);\n const prevSwipeBackShift = React.useRef<number>(undefined);\n const prevSwipeBackPrevPanel = React.useRef<string | null>(undefined);\n const prevOnTransition = React.useRef<typeof onTransition>(undefined);\n\n const panels = (React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>).filter(\n (panel) => {\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 || !splitCol.animate || platform === 'vkcom';\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider.isWebView && Boolean(onSwipeBack);\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.set(prevPanel, 0);\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(isBackTransition);\n\n layoutEffectCall(() => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.get(activePanelProp) : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n });\n },\n [activePanelProp, layoutEffectCall, onTransition, scroll, scrolls],\n );\n\n const handleAnimatedTargetAnimationEnd: React.AnimationEventHandler<HTMLDivElement> = (e) => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (prevPanel !== null) {\n flushTransition(prevPanel, Boolean(isBack));\n }\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 switch (swipeBackResult) {\n case 'fail':\n onSwipeBackCancel();\n break;\n case 'success':\n onSwipeBackSuccess();\n }\n }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackResult]);\n\n const handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n setBrowserSwipe(true);\n }\n };\n\n const handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (swipeBackPrevented.current || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if (animated && swipeBackTriggered) {\n return;\n }\n\n if (!swipingBack && history && history.length > 1) {\n if (swipedToOpposite) {\n swipeBackPrevented.current = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n swipeBackPrevented.current = true;\n return;\n }\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n swipeBackPrevented.current = true;\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.set(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 if (event.shiftX < 0) {\n setSwipeBackShift(0);\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n setSwipeBackShift(window!.innerWidth);\n } else {\n setSwipeBackShift(event.shiftX);\n }\n }\n };\n\n const handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n swipeBackPrevented.current = false;\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * millisecondsInSecond;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackShift >= window!.innerWidth / 2) {\n setSwipeBackResult('success');\n } else {\n setSwipeBackResult('fail');\n }\n }\n };\n\n const calcPanelSwipeStyles = (isPrev: boolean, isNext: boolean): React.CSSProperties => {\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n if (isNext) {\n return window\n ? {\n transform: `translate3d(${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%, 0, 0)`,\n }\n : {};\n }\n\n if (isPrev) {\n return { transform: `translate3d(${swipeBackShift}px, 0, 0)` };\n }\n\n return {};\n };\n\n const calcPanelSwipeBackOverlayStyles = (isNext: boolean): React.CSSProperties => {\n if (!window || !isNext) {\n return {};\n }\n const opacityOnSwipeEnd =\n swipeBackResult === 'success' ? 0 : swipeBackResult === 'fail' ? 1 : null;\n\n return {\n display: 'block',\n opacity:\n opacityOnSwipeEnd === null ? 1 - swipeBackShift / window.innerWidth : opacityOnSwipeEnd,\n };\n };\n\n const handleSwipeBackTargetTransitionEnd = (event: React.TransitionEvent<HTMLDivElement>) => {\n if (event.propertyName.includes('transform')) {\n swipingBackTransitionEndHandler();\n }\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n !prevSwipingBack.current &&\n !prevBrowserSwipe.current\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel.current || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.set(\n prevActivePanel.current,\n scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n );\n\n if (disableAnimation) {\n flushTransition(prevActivePanel.current, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel.current, activePanelProp]);\n setPrevPanel(prevActivePanel.current);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n prevSwipingBack.current\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel.current;\n if (prevSwipeBackPrevPanel.current) {\n scrolls.set(prevSwipeBackPrevPanel.current, 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 layoutEffectCall(() => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.get(nextPanel));\n }\n prevOnTransition.current &&\n prevOnTransition.current({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n });\n }\n\n // Началась анимация завершения свайпа назад.\n // см. `onTransitionEnd()`\n\n // Закончился Safari свайп\n if (prevActivePanel.current !== 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 browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n layoutEffectCall,\n scrolls,\n ]);\n\n React.useEffect(\n function restoreScrollPositionWhenSwipeBackIsCancelled() {\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n const swipeBackCancelledInTheMiddleOfAction =\n prevSwipeBackResult.current === 'fail' && !swipeBackResult;\n const swipeBackCancelledByMovingPanelBackToInitialPoint =\n prevSwipingBack.current && !swipingBack && prevSwipeBackShift.current === 0;\n\n if (\n (swipeBackCancelledInTheMiddleOfAction ||\n swipeBackCancelledByMovingPanelBackToInitialPoint) &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.get(activePanel));\n }\n },\n [swipeBackResult, swipingBack, activePanel, scroll, scrolls],\n );\n\n /**\n * @see https://github.com/VKCOM/VKUI/pull/9274\n */\n React.useEffect(function updateAfterAll() {\n prevActivePanel.current = activePanelProp;\n prevSwipingBack.current = swipingBack;\n prevBrowserSwipe.current = browserSwipe;\n prevSwipeBackResult.current = swipeBackResult;\n prevSwipeBackShift.current = swipeBackShift;\n prevSwipeBackPrevPanel.current = swipeBackPrevPanel;\n prevOnTransition.current = onTransition;\n });\n\n return (\n <NavViewIdContext.Provider value={id}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles.animated,\n !disableAnimation && swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled ? handleTouchEndForIOSSwipeBackSimulation : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n const isPanelActive = panelId === activePanel;\n const isPanelPrev = panelId === prevPanel;\n const isPanelNext = panelId === nextPanel;\n const isAnimatedTarget = animated && (isBack ? isPanelPrev : isPanelNext);\n\n const isSwipeBackPrev = panelId === swipeBackPrevPanel;\n const isSwipeBackNext = panelId === swipeBackNextPanel;\n const isSwipeBackTarget = swipeBackResult && isSwipeBackPrev;\n\n let scrollCompensateStyle: React.CSSProperties | undefined = undefined;\n\n if (isPanelPrev || (isPanelNext && isBack) || isSwipeBackPrev || isSwipeBackNext) {\n const marginTop = scrolls.get(panelId);\n if (marginTop !== undefined) {\n scrollCompensateStyle = { marginTop: -1 * marginTop };\n }\n }\n\n return (\n <div\n className={classNames(\n styles.panel,\n\n isPanelActive && styles.panelActive,\n isPanelPrev && styles.panelPrev,\n isPanelNext && styles.panelNext,\n\n isSwipeBackPrev && styles.panelSwipeBackPrev,\n isSwipeBackNext && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onTransitionEnd={\n isSwipeBackTarget ? handleSwipeBackTargetTransitionEnd : undefined\n }\n onAnimationEnd={isAnimatedTarget ? handleAnimatedTargetAnimationEnd : undefined}\n ref={(el) => {\n panelId !== undefined && (panelNodes.current[panelId] = el);\n }}\n style={calcPanelSwipeStyles(isSwipeBackPrev, isSwipeBackNext)}\n key={panelId}\n >\n {platform === 'ios' && (\n <div\n className={styles.panelOverlay}\n style={calcPanelSwipeBackOverlayStyles(isSwipeBackNext)}\n />\n )}\n <div className={styles.panelIn} style={scrollCompensateStyle}>\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 </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n};\n"],"names":["React","classNames","usePlatform","millisecondsInSecond","blurActiveElement","useDOM","LockFloatingPositionContext","getNavId","warnOnce","useScroll","useConfigProvider","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","useSplitCol","Touch","useLayoutEffectCall","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","scrollsCache","Map","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","id","scrolls","useState","get","layoutEffectCall","useEffect","set","panelNodes","useRef","window","document","scroll","configProvider","splitCol","platform","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","isBack","setIsBack","undefined","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipeBackPrevented","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackShift","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","iOSSwipeBackSimulationEnabled","isWebView","Boolean","flushTransition","useCallback","isBackTransition","scrollTo","from","to","handleAnimatedTargetAnimationEnd","e","target","currentTarget","onSwipeBackSuccess","swipingBackTransitionEndHandler","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","current","swipedToOpposite","length","originalEvent","payload","getScroll","y","slice","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","isPrev","isNext","transform","calcPanelSwipeBackOverlayStyles","opacityOnSwipeEnd","display","opacity","handleSwipeBackTargetTransitionEnd","propertyName","firstLayerId","map","find","compensateKeyboardHeight","restoreScrollPositionWhenSwipeBackIsCancelled","swipeBackCancelledInTheMiddleOfAction","swipeBackCancelledByMovingPanelBackToInitialPoint","updateAfterAll","Provider","value","Component","onMoveX","onEnd","div","isPanelActive","isPanelPrev","isPanelNext","isAnimatedTarget","isSwipeBackPrev","isSwipeBackNext","isSwipeBackTarget","scrollCompensateStyle","marginTop","onTransitionEnd","onAnimationEnd","ref","el","style","entering"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,WAAW,QAAQ,6BAA0B;AACtD,SAASC,oBAAoB,QAAQ,oBAAiB;AACtD,SAASC,iBAAiB,EAAEC,MAAM,QAAQ,mBAAgB;AAC1D,SAASC,2BAA2B,QAAQ,kEAA+D;AAC3G,SAASC,QAAQ,QAAyB,wBAAqB;AAC/D,SAASC,QAAQ,QAAQ,wBAAqB;AAE9C,SAASC,SAAS,QAAQ,8BAA2B;AACrD,SAASC,iBAAiB,QAAQ,6CAA0C;AAC5E,SAASC,gBAAgB,QAAQ,kCAA+B;AAChE,SAASC,qBAAqB,QAAQ,kDAA+C;AACrF,SAASC,8BAA8B,QAAQ,oEAAiE;AAChH,SAASC,WAAW,QAAQ,iCAA8B;AAC1D,SAAgCC,KAAK,QAAQ,oBAAiB;AAC9D,SAASC,mBAAmB,QAAQ,2BAAwB;AAC5D,SACEC,sBAAsB,EACtBC,gDAAgD,EAChDC,iBAAiB,QACZ,aAAU;AAGjB,OAAO,MAAMC,eAAe,IAAIC,MAA+C;AAmC/E,MAAMC,OAAOd,SAAS;AAEtB;;CAEC,GACD,OAAO,MAAMe,OAAO,CAAC,EACnBC,aAAaC,eAAe,EAC5BC,OAAO,EACPC,GAAG,EACHC,YAAY,EACZC,WAAW,EACXC,gBAAgB,EAChBC,mBAAmBC,qBAAqB,EACxCC,QAAQ,EACRC,SAAS,EACT,GAAGC,WACO;IACV,MAAMC,KAAK7B,SAAS;QAAEoB;QAAKS,IAAID,UAAUC,EAAE;IAAC;IAC5C,MAAM,CAACC,QAAQ,GAAGrC,MAAMsC,QAAQ,CAC9B,IAAMlB,aAAamB,GAAG,CAACH,OAAiB,IAAIf;IAE9C,MAAMmB,mBAAmBxB;IAEzBhB,MAAMyC,SAAS,CAAC,IAAM;YACpB,IAAIL,IAAI;gBACNhB,aAAasB,GAAG,CAACN,IAAIC;YACvB;QACF;IAEA,MAAMM,aAAa3C,MAAM4C,MAAM,CAA0C,CAAC;IAE1E,MAAM,EAAEC,MAAM,EAAEC,QAAQ,EAAE,GAAGzC;IAC7B,MAAM0C,SAAStC;IACf,MAAMuC,iBAAiBtC;IACvB,MAAMuC,WAAWnC;IACjB,MAAMoC,WAAWhD;IAEjB,MAAM,CAACiD,UAAUC,YAAY,GAAGpD,MAAMsC,QAAQ,CAAC;IAE/C,MAAM,CAACe,eAAeC,iBAAiB,GAAGtD,MAAMsC,QAAQ,CAAC;QAACb;KAAgB;IAC1E,MAAM,CAACD,aAAa+B,eAAe,GAAGvD,MAAMsC,QAAQ,CAAgBb;IACpE,MAAM,CAAC+B,QAAQC,UAAU,GAAGzD,MAAMsC,QAAQ,CAAsBoB;IAChE,MAAM,CAACC,WAAWC,aAAa,GAAG5D,MAAMsC,QAAQ,CAAgB;IAChE,MAAM,CAACuB,WAAWC,aAAa,GAAG9D,MAAMsC,QAAQ,CAAgB;IAEhE,MAAMyB,qBAAqB/D,MAAM4C,MAAM,CAAU;IACjD,MAAM,CAACoB,aAAaC,eAAe,GAAGjE,MAAMsC,QAAQ,CAAsBoB;IAC1E,MAAM,CAACQ,iBAAiBC,mBAAmB,GAAGnE,MAAMsC,QAAQ,CAAS;IACrE,MAAM,CAAC8B,gBAAgBC,kBAAkB,GAAGrE,MAAMsC,QAAQ,CAAS;IACnE,MAAM,CAACgC,oBAAoBC,sBAAsB,GAAGvE,MAAMsC,QAAQ,CAAgB;IAClF,MAAM,CAACkC,oBAAoBC,sBAAsB,GAAGzE,MAAMsC,QAAQ,CAAgB;IAClF,MAAM,CAACoC,iBAAiBC,mBAAmB,GAAG3E,MAAMsC,QAAQ,CAA4B;IAExF,MAAM,CAACsC,cAAcC,gBAAgB,GAAG7E,MAAMsC,QAAQ,CAAC;IAEvD,MAAMwC,kBAAkB9E,MAAM4C,MAAM,CAASc;IAC7C,MAAMqB,kBAAkB/E,MAAM4C,MAAM,CAAUc;IAC9C,MAAMsB,mBAAmBhF,MAAM4C,MAAM,CAAUc;IAC/C,MAAMuB,sBAAsBjF,MAAM4C,MAAM,CAA4Bc;IACpE,MAAMwB,qBAAqBlF,MAAM4C,MAAM,CAASc;IAChD,MAAMyB,yBAAyBnF,MAAM4C,MAAM,CAAgBc;IAC3D,MAAM0B,mBAAmBpF,MAAM4C,MAAM,CAAsBc;IAE3D,MAAM2B,SAAS,AAACrF,MAAMsF,QAAQ,CAACC,OAAO,CAACtD,UAAoDuD,MAAM,CAC/F,CAACC;QACC,MAAMC,UAAUnF,SAASkF,MAAME,KAAK,EAAErE;QAEtC,OACE,AAACoE,YAAYhC,aAAaL,cAAcuC,QAAQ,CAACF,YACjDA,YAAYlB,sBACZkB,YAAYpB;IAEhB;IAGF,MAAMuB,mBACJ,CAAC7C,eAAe8C,uBAAuB,IAAI,CAAC7C,SAAS8C,OAAO,IAAI7C,aAAa;IAC/E,MAAM8C,gCACJ,CAACH,oBAAoB3C,aAAa,SAASF,eAAeiD,SAAS,IAAIC,QAAQrE;IAEjF,MAAMsE,kBAAkBnG,MAAMoG,WAAW,CACvC,CAACzC,WAAmB0C;QAClB,IAAIA,kBAAkB;YACpBhE,QAAQK,GAAG,CAACiB,WAAW;QACzB;QACAC,aAAa;QACbE,aAAa;QACbR,iBAAiB;YAAC7B;SAAgB;QAClC8B,eAAe9B;QACf2B,YAAY;QACZK,UAAU4C;QAEV7D,iBAAiB;YACfO,QAAQuD,SAAS,GAAGD,mBAAmBhE,QAAQE,GAAG,CAACd,mBAAmB;YACtEG,gBACEA,aAAa;gBACX4B,QAAQ6C;gBACRE,MAAM5C;gBACN6C,IAAI/E;YACN;QACJ;IACF,GACA;QAACA;QAAiBe;QAAkBZ;QAAcmB;QAAQV;KAAQ;IAGpE,MAAMoE,mCAAgF,CAACC;QACrF,IAAIA,EAAEC,MAAM,KAAKD,EAAEE,aAAa,EAAE;YAChC;QACF;QAEA,IAAIjD,cAAc,MAAM;YACtBwC,gBAAgBxC,WAAWuC,QAAQ1C;QACrC;IACF;IAEA,MAAMqD,qBAAqB7G,MAAMoG,WAAW,CAAC;QAC3CvE,eAAeA;IACjB,GAAG;QAACA;KAAY;IAEhB,MAAME,oBAAoB/B,MAAMoG,WAAW,CAAC;QAC1CpE,yBAAyBA;QACzByC,sBAAsB;QACtBF,sBAAsB;QACtBN,eAAe;QACfU,mBAAmB;QACnBR,mBAAmB;QACnBE,kBAAkB;IACpB,GAAG;QAACrC;KAAsB;IAE1B,MAAM8E,kCAAkC9G,MAAMoG,WAAW,CAAC;QACxD,OAAQ1B;YACN,KAAK;gBACH3C;gBACA;YACF,KAAK;gBACH8E;QACJ;IACF,GAAG;QAAC9E;QAAmB8E;QAAoBnC;KAAgB;IAE3D,MAAMqC,mDAAmD,CAACC;QACxD,IAAIpC,cAAc;YAChB;QACF;QACA,MAAM,EAAEqC,kBAAkB,EAAEC,wBAAwB,EAAEC,sBAAsB,EAAE,GAC5ElG,uBAAuB+F,MAAMI,MAAM,EAAEJ,MAAMK,MAAM,EAAExE,OAAQyE,UAAU;QAEvE,IAAI,AAACJ,CAAAA,4BAA4BC,sBAAqB,KAAMF,oBAAoB;YAC9EpC,gBAAgB;QAClB;IACF;IAEA,MAAM0C,4CAA4C,CAACP;QACjD,IAAIjD,mBAAmByD,OAAO,IAAIrG,kBAAkB6F,QAAQ;YAC1D;QACF;QAEA,MAAM,EAAES,gBAAgB,EAAER,kBAAkB,EAAEC,wBAAwB,EAAE,GACtEjG,uBAAuB+F,MAAMI,MAAM,EAAEJ,MAAMK,MAAM,EAAExE,OAAQyE,UAAU;QAEvE,IAAInE,YAAY8D,oBAAoB;YAClC;QACF;QAEA,IAAI,CAACjD,eAAetC,WAAWA,QAAQgG,MAAM,GAAG,GAAG;YACjD,IAAID,kBAAkB;gBACpB1D,mBAAmByD,OAAO,GAAG;gBAC7B;YACF;YAEA,IAAI,CAACP,oBAAoB;gBACvB;YACF;YAEA,IACE,CAACC,4BACDhG,iDAAiD8F,MAAMW,aAAa,CAAChB,MAAM,GAC3E;gBACA5C,mBAAmByD,OAAO,GAAG;gBAC7B;YACF;YACA,sBAAsB;YACtB,IAAI1F,kBAAkB;gBACpB,MAAM8F,UAAU9F,iBAAiBN;gBACjC,IAAIoG,YAAY,WAAW;oBACzB7D,mBAAmByD,OAAO,GAAG;oBAC7B;gBACF;YACF;YAEA,IAAIhG,gBAAgB,MAAM;gBACxB,+EAA+E;gBAC/EpB,kBAAkB0C;gBAClBT,QAAQK,GAAG,CAAClB,aAAauB,QAAQ8E,YAAYC;YAC/C;YAEA7D,eAAe;YACfE,mBAAmB6C,MAAMI,MAAM;YAC/B3C,sBAAsBjD;YACtB+C,sBAAsB7C,QAAQqG,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE;QAC5C;QAEA,IAAI/D,aAAa;YACf,IAAIgD,MAAMK,MAAM,GAAG,GAAG;gBACpBhD,kBAAkB;YACpB,OAAO,IAAI2C,MAAMK,MAAM,GAAGxE,OAAQyE,UAAU,GAAGpD,iBAAiB;gBAC9DG,kBAAkBxB,OAAQyE,UAAU;YACtC,OAAO;gBACLjD,kBAAkB2C,MAAMK,MAAM;YAChC;QACF;IACF;IAEA,MAAMW,0CAA0C,CAAChB;QAC/CjD,mBAAmByD,OAAO,GAAG;QAC7B,IAAIxD,aAAa;YACf,MAAMiE,QAAQ,AAAC7D,iBAAiB4C,MAAMkB,QAAQ,GAAI/H;YAClD,IAAIiE,mBAAmB,GAAG;gBACxBrC;YACF,OAAO,IAAIqC,kBAAmBvB,CAAAA,OAAQyE,UAAU,IAAI,CAAA,GAAI;gBACtDT;YACF,OAAO,IAAIoB,QAAQ,OAAO7D,kBAAkBvB,OAAQyE,UAAU,GAAG,GAAG;gBAClE3C,mBAAmB;YACrB,OAAO;gBACLA,mBAAmB;YACrB;QACF;IACF;IAEA,MAAMwD,uBAAuB,CAACC,QAAiBC;QAC7C,IAAI,AAAC,CAACD,UAAU,CAACC,UAAW3D,iBAAiB;YAC3C,OAAO,CAAC;QACV;QAEA,IAAI2D,QAAQ;YACV,OAAOxF,SACH;gBACEyF,WAAW,CAAC,YAAY,EAAE,CAAC,KAAK,AAAClE,iBAAiB,MAAOvB,OAAOyE,UAAU,GAAG,EAAE,QAAQ,CAAC;YAC1F,IACA,CAAC;QACP;QAEA,IAAIc,QAAQ;YACV,OAAO;gBAAEE,WAAW,CAAC,YAAY,EAAElE,eAAe,SAAS,CAAC;YAAC;QAC/D;QAEA,OAAO,CAAC;IACV;IAEA,MAAMmE,kCAAkC,CAACF;QACvC,IAAI,CAACxF,UAAU,CAACwF,QAAQ;YACtB,OAAO,CAAC;QACV;QACA,MAAMG,oBACJ9D,oBAAoB,YAAY,IAAIA,oBAAoB,SAAS,IAAI;QAEvE,OAAO;YACL+D,SAAS;YACTC,SACEF,sBAAsB,OAAO,IAAIpE,iBAAiBvB,OAAOyE,UAAU,GAAGkB;QAC1E;IACF;IAEA,MAAMG,qCAAqC,CAAC3B;QAC1C,IAAIA,MAAM4B,YAAY,CAAChD,QAAQ,CAAC,cAAc;YAC5CkB;QACF;IACF;IAEA9G,MAAMyC,SAAS,CAAC;QACd,gBAAgB;QAChB,IACEqC,gBAAgB0C,OAAO,IACvB1C,gBAAgB0C,OAAO,KAAK/F,mBAC5B,CAACsD,gBAAgByC,OAAO,IACxB,CAACxC,iBAAiBwC,OAAO,EACzB;YACA,MAAMqB,eAAe,AACnB7I,MAAMsF,QAAQ,CAACC,OAAO,CAACtD,UAEtB6G,GAAG,CAAC,CAACrD,QAAUlF,SAASkF,MAAME,KAAK,EAAErE,OACrCyH,IAAI,CAAC,CAAC3G,KAAOA,OAAO0C,gBAAgB0C,OAAO,IAAIpF,OAAOX;YAEzD,MAAM4E,mBAAmBwC,iBAAiBpH;YAC1CY,QAAQK,GAAG,CACToC,gBAAgB0C,OAAO,EACvBzE,QAAQ8E,UAAU;gBAAEmB,0BAA0B;YAAM,GAAGlB;YAGzD,IAAIjC,kBAAkB;gBACpBM,gBAAgBrB,gBAAgB0C,OAAO,EAAEnB;YAC3C,OAAO;gBACLjG,kBAAkB0C;gBAElBQ,iBAAiB;oBAACwB,gBAAgB0C,OAAO;oBAAE/F;iBAAgB;gBAC3DmC,aAAakB,gBAAgB0C,OAAO;gBACpC1D,aAAarC;gBACb8B,eAAe;gBACfH,YAAY;gBACZK,UAAU4C;YACZ;QACF;QAEA,oCAAoC;QACpC,IACEvB,gBAAgB0C,OAAO,IACvB1C,gBAAgB0C,OAAO,KAAK/F,mBAC5BsD,gBAAgByC,OAAO,EACvB;YACA,MAAM3D,YAAYpC;YAClB,MAAMkC,YAAYmB,gBAAgB0C,OAAO;YACzC,IAAIrC,uBAAuBqC,OAAO,EAAE;gBAClCnF,QAAQK,GAAG,CAACyC,uBAAuBqC,OAAO,EAAE;YAC9C;YAEA/C,sBAAsB;YACtBF,sBAAsB;YACtBN,eAAe;YACfU,mBAAmB;YACnBR,mBAAmB;YACnBE,kBAAkB;YAClBd,eAAeM;YACfP,iBAAiB;gBAACO;aAAU;YAC5BJ,UAAU;YAEVjB,iBAAiB;gBACf,IAAIqB,cAAc,MAAM;oBACtBd,QAAQuD,SAAS,GAAGjE,QAAQE,GAAG,CAACsB;gBAClC;gBACAuB,iBAAiBoC,OAAO,IACtBpC,iBAAiBoC,OAAO,CAAC;oBACvBhE,QAAQ;oBACR+C,MAAM5C;oBACN6C,IAAI3C;gBACN;YACJ;QACF;QAEA,6CAA6C;QAC7C,0BAA0B;QAE1B,0BAA0B;QAC1B,IAAIiB,gBAAgB0C,OAAO,KAAK/F,mBAAmBmD,cAAc;YAC/DC,gBAAgB;YAChBf,aAAa;YACbF,aAAa;YACbR,YAAY;YACZE,iBAAiB;gBAAC7B;aAAgB;YAClC8B,eAAe9B;QACjB;IACF,GAAG;QACDA;QACAD;QACAoD;QACA3C;QACA4D;QACA/C;QACAqD;QACApD;QACAuB;QACAI;QACAlC;QACAH;KACD;IAEDrC,MAAMyC,SAAS,CACb,SAASwG;QACP,+EAA+E;QAC/E,MAAMC,wCACJjE,oBAAoBuC,OAAO,KAAK,UAAU,CAAC9C;QAC7C,MAAMyE,oDACJpE,gBAAgByC,OAAO,IAAI,CAACxD,eAAekB,mBAAmBsC,OAAO,KAAK;QAE5E,IACE,AAAC0B,CAAAA,yCACCC,iDAAgD,KAClD3H,gBAAgB,MAChB;YACAuB,QAAQuD,SAAS,GAAGjE,QAAQE,GAAG,CAACf;QAClC;IACF,GACA;QAACkD;QAAiBV;QAAaxC;QAAauB;QAAQV;KAAQ;IAG9D;;GAEC,GACDrC,MAAMyC,SAAS,CAAC,SAAS2G;QACvBtE,gBAAgB0C,OAAO,GAAG/F;QAC1BsD,gBAAgByC,OAAO,GAAGxD;QAC1BgB,iBAAiBwC,OAAO,GAAG5C;QAC3BK,oBAAoBuC,OAAO,GAAG9C;QAC9BQ,mBAAmBsC,OAAO,GAAGpD;QAC7Be,uBAAuBqC,OAAO,GAAGhD;QACjCY,iBAAiBoC,OAAO,GAAG5F;IAC7B;IAEA,qBACE,KAACjB,iBAAiB0I,QAAQ;QAACC,OAAOlH;kBAChC,cAAA,KAAC9B,4BAA4B+I,QAAQ;YAACC,OAAOtF,eAAeb;sBAC1D,cAAA,KAACpC;gBACCwI,WAAU;gBACT,GAAGpH,SAAS;gBACbD,WAAWjC,6BAETiD,aAAa,SAASjD,4BAAuB,0BAC7C,CAAC4F,oBAAoB1C,kCACrB,CAAC0C,oBAAoB7B,wCACrB6B,0CACA3D;gBAEFsH,SACExD,gCACIuB,4CACArE,aAAa,QACX6D,mDACArD;gBAER+F,OACEzD,gCAAgCgC,0CAA0CtE;0BAG5E,cAAA,KAACgG;oBAAIxH,SAAS;8BACXmD,OAAOyD,GAAG,CAAC,CAACrD;wBACX,MAAMC,UAAUnF,SAASkF,MAAME,KAAK,EAAErE;wBAEtC,MAAMqI,gBAAgBjE,YAAYlE;wBAClC,MAAMoI,cAAclE,YAAY/B;wBAChC,MAAMkG,cAAcnE,YAAY7B;wBAChC,MAAMiG,mBAAmB3G,YAAaK,CAAAA,SAASoG,cAAcC,WAAU;wBAEvE,MAAME,kBAAkBrE,YAAYlB;wBACpC,MAAMwF,kBAAkBtE,YAAYpB;wBACpC,MAAM2F,oBAAoBvF,mBAAmBqF;wBAE7C,IAAIG,wBAAyDxG;wBAE7D,IAAIkG,eAAgBC,eAAerG,UAAWuG,mBAAmBC,iBAAiB;4BAChF,MAAMG,YAAY9H,QAAQE,GAAG,CAACmD;4BAC9B,IAAIyE,cAAczG,WAAW;gCAC3BwG,wBAAwB;oCAAEC,WAAW,CAAC,IAAIA;gCAAU;4BACtD;wBACF;wBAEA,qBACE,MAACT;4BACCxH,WAAWjC,8BAGT0J,0CACAC,sCACAC,sCAEAE,mDACAC,mDACAtF,oBAAoB,gDACpBA,oBAAoB;4BAEtB0F,iBACEH,oBAAoBtB,qCAAqCjF;4BAE3D2G,gBAAgBP,mBAAmBrD,mCAAmC/C;4BACtE4G,KAAK,CAACC;gCACJ7E,YAAYhC,aAAcf,CAAAA,WAAW6E,OAAO,CAAC9B,QAAQ,GAAG6E,EAAC;4BAC3D;4BACAC,OAAOrC,qBAAqB4B,iBAAiBC;;gCAG5C9G,aAAa,uBACZ,KAACwG;oCACCxH,SAAS;oCACTsI,OAAOjC,gCAAgCyB;;8CAG3C,KAACN;oCAAIxH,SAAS;oCAAkBsI,OAAON;8CACrC,cAAA,KAACrJ;wCAA+B2C,QAAQQ,eAAeR;kDACrD,cAAA,KAAC5C;4CACC6J,UAAU/E,YAAY7B,aAAa6B,YAAYpB;sDAE9CmB;;;;;2BAbFC;oBAmBX;;;;;AAMZ,EAAE"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/View/View.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { blurActiveElement, useDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HTMLAttributesWithRootRef } from '../../types';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport { useLayoutEffectCall } from './useLayoutEffectCall';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nexport const scrollsCache = new Map<string, Map<string, number | undefined>>();\n\nexport interface ViewProps extends HTMLAttributesWithRootRef<HTMLElement>, NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: (params: { isBack: boolean; from: string; to: string }) => void;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Коллекция Panel. У каждой Panel должен быть уникальный `id`.\n */\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkui.io/components/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): React.ReactNode => {\n const id = getNavId({ nav, id: restProps.id });\n const [scrolls] = React.useState(\n () => scrollsCache.get(id as string) || new Map<string, number | undefined>(),\n );\n const layoutEffectCall = useLayoutEffectCall();\n\n React.useEffect(() => () => {\n if (id) {\n scrollsCache.set(id, scrolls);\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 swipeBackPrevented = React.useRef<boolean>(false);\n const [swipingBack, setSwipingBack] = React.useState<boolean | undefined>(undefined);\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<'success' | 'fail' | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = React.useRef<string>(undefined);\n const prevSwipingBack = React.useRef<boolean>(undefined);\n const prevBrowserSwipe = React.useRef<boolean>(undefined);\n const prevSwipeBackResult = React.useRef<'success' | 'fail' | null>(undefined);\n const prevSwipeBackShift = React.useRef<number>(undefined);\n const prevSwipeBackPrevPanel = React.useRef<string | null>(undefined);\n const prevOnTransition = React.useRef<typeof onTransition>(undefined);\n\n const panels = (React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>).filter(\n (panel) => {\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 || !splitCol.animate || platform === 'vkcom';\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider.isWebView && Boolean(onSwipeBack);\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.set(prevPanel, 0);\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(isBackTransition);\n\n layoutEffectCall(() => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.get(activePanelProp) : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n });\n },\n [activePanelProp, layoutEffectCall, onTransition, scroll, scrolls],\n );\n\n const handleAnimatedTargetAnimationEnd: React.AnimationEventHandler<HTMLDivElement> = (e) => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (prevPanel !== null) {\n flushTransition(prevPanel, Boolean(isBack));\n }\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 switch (swipeBackResult) {\n case 'fail':\n onSwipeBackCancel();\n break;\n case 'success':\n onSwipeBackSuccess();\n }\n }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackResult]);\n\n const handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n setBrowserSwipe(true);\n }\n };\n\n const handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (swipeBackPrevented.current || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if (animated && swipeBackTriggered) {\n return;\n }\n\n if (!swipingBack && history && history.length > 1) {\n if (swipedToOpposite) {\n swipeBackPrevented.current = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n swipeBackPrevented.current = true;\n return;\n }\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n swipeBackPrevented.current = true;\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.set(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 if (event.shiftX < 0) {\n setSwipeBackShift(0);\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n setSwipeBackShift(window!.innerWidth);\n } else {\n setSwipeBackShift(event.shiftX);\n }\n }\n };\n\n const handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n swipeBackPrevented.current = false;\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * millisecondsInSecond;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackShift >= window!.innerWidth / 2) {\n setSwipeBackResult('success');\n } else {\n setSwipeBackResult('fail');\n }\n }\n };\n\n const calcPanelSwipeStyles = (isPrev: boolean, isNext: boolean): React.CSSProperties => {\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n if (isNext) {\n return window\n ? {\n transform: `translate3d(${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%, 0, 0)`,\n }\n : {};\n }\n\n if (isPrev) {\n return { transform: `translate3d(${swipeBackShift}px, 0, 0)` };\n }\n\n return {};\n };\n\n const calcPanelSwipeBackOverlayStyles = (isNext: boolean): React.CSSProperties => {\n if (!window || !isNext) {\n return {};\n }\n const opacityOnSwipeEnd =\n swipeBackResult === 'success' ? 0 : swipeBackResult === 'fail' ? 1 : null;\n\n return {\n display: 'block',\n opacity:\n opacityOnSwipeEnd === null ? 1 - swipeBackShift / window.innerWidth : opacityOnSwipeEnd,\n };\n };\n\n const handleSwipeBackTargetTransitionEnd = (event: React.TransitionEvent<HTMLDivElement>) => {\n if (event.propertyName.includes('transform')) {\n swipingBackTransitionEndHandler();\n }\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n !prevSwipingBack.current &&\n !prevBrowserSwipe.current\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel.current || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.set(\n prevActivePanel.current,\n scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n );\n\n if (disableAnimation) {\n flushTransition(prevActivePanel.current, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel.current, activePanelProp]);\n setPrevPanel(prevActivePanel.current);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n prevSwipingBack.current\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel.current;\n if (prevSwipeBackPrevPanel.current) {\n scrolls.set(prevSwipeBackPrevPanel.current, 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 layoutEffectCall(() => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.get(nextPanel));\n }\n prevOnTransition.current &&\n prevOnTransition.current({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n });\n }\n\n // Началась анимация завершения свайпа назад.\n // см. `onTransitionEnd()`\n\n // Закончился Safari свайп\n if (prevActivePanel.current !== 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 browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n layoutEffectCall,\n scrolls,\n ]);\n\n React.useEffect(\n function restoreScrollPositionWhenSwipeBackIsCancelled() {\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n const swipeBackCancelledInTheMiddleOfAction =\n prevSwipeBackResult.current === 'fail' && !swipeBackResult;\n const swipeBackCancelledByMovingPanelBackToInitialPoint =\n prevSwipingBack.current && !swipingBack && prevSwipeBackShift.current === 0;\n\n if (\n (swipeBackCancelledInTheMiddleOfAction ||\n swipeBackCancelledByMovingPanelBackToInitialPoint) &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.get(activePanel));\n }\n },\n [swipeBackResult, swipingBack, activePanel, scroll, scrolls],\n );\n\n /**\n * @see https://github.com/VKCOM/VKUI/pull/9274\n */\n React.useEffect(function updateAfterAll() {\n prevActivePanel.current = activePanelProp;\n prevSwipingBack.current = swipingBack;\n prevBrowserSwipe.current = browserSwipe;\n prevSwipeBackResult.current = swipeBackResult;\n prevSwipeBackShift.current = swipeBackShift;\n prevSwipeBackPrevPanel.current = swipeBackPrevPanel;\n prevOnTransition.current = onTransition;\n });\n\n return (\n <NavViewIdContext.Provider value={id}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles.animated,\n !disableAnimation && swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled ? handleTouchEndForIOSSwipeBackSimulation : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n const isPanelActive = panelId === activePanel;\n const isPanelPrev = panelId === prevPanel;\n const isPanelNext = panelId === nextPanel;\n const isAnimatedTarget = animated && (isBack ? isPanelPrev : isPanelNext);\n\n const isSwipeBackPrev = panelId === swipeBackPrevPanel;\n const isSwipeBackNext = panelId === swipeBackNextPanel;\n const isSwipeBackTarget = swipeBackResult && isSwipeBackPrev;\n\n let scrollCompensateStyle: React.CSSProperties | undefined = undefined;\n\n if (isPanelPrev || (isPanelNext && isBack) || isSwipeBackPrev || isSwipeBackNext) {\n const marginTop = scrolls.get(panelId);\n if (marginTop !== undefined) {\n scrollCompensateStyle = { marginTop: -1 * marginTop };\n }\n }\n\n return (\n <div\n className={classNames(\n styles.panel,\n\n isPanelActive && styles.panelActive,\n isPanelPrev && styles.panelPrev,\n isPanelNext && styles.panelNext,\n\n isSwipeBackPrev && styles.panelSwipeBackPrev,\n isSwipeBackNext && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onTransitionEnd={\n isSwipeBackTarget ? handleSwipeBackTargetTransitionEnd : undefined\n }\n onAnimationEnd={isAnimatedTarget ? handleAnimatedTargetAnimationEnd : undefined}\n ref={(el) => {\n panelId !== undefined && (panelNodes.current[panelId] = el);\n }}\n style={calcPanelSwipeStyles(isSwipeBackPrev, isSwipeBackNext)}\n key={panelId}\n >\n {platform === 'ios' && (\n <div\n className={styles.panelOverlay}\n style={calcPanelSwipeBackOverlayStyles(isSwipeBackNext)}\n />\n )}\n <div className={styles.panelIn} style={scrollCompensateStyle}>\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 </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n};\n"],"names":["React","classNames","usePlatform","millisecondsInSecond","blurActiveElement","useDOM","LockFloatingPositionContext","getNavId","warnOnce","useScroll","useConfigProvider","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","useSplitCol","Touch","useLayoutEffectCall","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","scrollsCache","Map","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","id","scrolls","useState","get","layoutEffectCall","useEffect","set","panelNodes","useRef","window","document","scroll","configProvider","splitCol","platform","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","isBack","setIsBack","undefined","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipeBackPrevented","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackShift","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","iOSSwipeBackSimulationEnabled","isWebView","Boolean","flushTransition","useCallback","isBackTransition","scrollTo","from","to","handleAnimatedTargetAnimationEnd","e","target","currentTarget","onSwipeBackSuccess","swipingBackTransitionEndHandler","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","current","swipedToOpposite","length","originalEvent","payload","getScroll","y","slice","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","isPrev","isNext","transform","calcPanelSwipeBackOverlayStyles","opacityOnSwipeEnd","display","opacity","handleSwipeBackTargetTransitionEnd","propertyName","firstLayerId","map","find","compensateKeyboardHeight","restoreScrollPositionWhenSwipeBackIsCancelled","swipeBackCancelledInTheMiddleOfAction","swipeBackCancelledByMovingPanelBackToInitialPoint","updateAfterAll","Provider","value","Component","onMoveX","onEnd","div","isPanelActive","isPanelPrev","isPanelNext","isAnimatedTarget","isSwipeBackPrev","isSwipeBackNext","isSwipeBackTarget","scrollCompensateStyle","marginTop","onTransitionEnd","onAnimationEnd","ref","el","style","entering"],"mappings":"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"}
|
|
@@ -17,50 +17,50 @@ export interface ViewInfiniteProps extends HTMLAttributesWithRootRef<HTMLElement
|
|
|
17
17
|
/**
|
|
18
18
|
* Обработчик, который вызывается при завершении анимации смены активной панели.
|
|
19
19
|
*/
|
|
20
|
-
onTransition?: (params: TransitionParams & {
|
|
20
|
+
onTransition?: ((params: TransitionParams & {
|
|
21
21
|
isBack: boolean;
|
|
22
|
-
}) => void;
|
|
22
|
+
}) => void) | undefined;
|
|
23
23
|
/**
|
|
24
24
|
* Обработчик свайпа назад.
|
|
25
25
|
*/
|
|
26
|
-
onSwipeBack?: () => void;
|
|
26
|
+
onSwipeBack?: (() => void) | undefined;
|
|
27
27
|
/**
|
|
28
28
|
* Обработчик начала анимации свайпа назад.
|
|
29
29
|
*/
|
|
30
|
-
onSwipeBackStart?: (activePanel: string | null) => void | 'prevent';
|
|
30
|
+
onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;
|
|
31
31
|
/**
|
|
32
32
|
* Обработчик завершения анимации отмененного пользователем свайпа.
|
|
33
33
|
*/
|
|
34
|
-
onSwipeBackCancel?: () => void;
|
|
34
|
+
onSwipeBackCancel?: (() => void) | undefined;
|
|
35
35
|
/**
|
|
36
36
|
* Массив из id панелей в порядке открытия.
|
|
37
37
|
*/
|
|
38
|
-
history?: string[];
|
|
38
|
+
history?: string[] | undefined;
|
|
39
39
|
/**
|
|
40
40
|
* Функция проверки перехода назад.
|
|
41
41
|
*/
|
|
42
|
-
isBackCheck?: (params: TransitionParams) => boolean;
|
|
42
|
+
isBackCheck?: ((params: TransitionParams) => boolean) | undefined;
|
|
43
43
|
/**
|
|
44
44
|
* @ignore
|
|
45
45
|
*/
|
|
46
|
-
splitCol?: SplitColContextProps;
|
|
46
|
+
splitCol?: SplitColContextProps | undefined;
|
|
47
47
|
/**
|
|
48
48
|
* @ignore
|
|
49
49
|
*/
|
|
50
|
-
configProvider?: ConfigProviderContextInterface;
|
|
50
|
+
configProvider?: ConfigProviderContextInterface | undefined;
|
|
51
51
|
/**
|
|
52
52
|
* @ignore
|
|
53
53
|
*/
|
|
54
|
-
scroll?: ScrollContextInterface;
|
|
54
|
+
scroll?: ScrollContextInterface | undefined;
|
|
55
55
|
}
|
|
56
56
|
export interface ViewInfiniteState {
|
|
57
57
|
animated: boolean;
|
|
58
58
|
visiblePanels: Array<string | null>;
|
|
59
59
|
activePanel: string | null;
|
|
60
|
-
isBack?: boolean;
|
|
60
|
+
isBack?: boolean | undefined;
|
|
61
61
|
prevPanel: string | null;
|
|
62
62
|
nextPanel: string | null;
|
|
63
|
-
swipingBack?: boolean;
|
|
63
|
+
swipingBack?: boolean | undefined;
|
|
64
64
|
swipeBackStartX: number;
|
|
65
65
|
swipeBackShift: number;
|
|
66
66
|
swipeBackNextPanel: string | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewInfinite.d.ts","sourceRoot":"","sources":["../../../src/components/View/ViewInfinite.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAO/B,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAE/D,OAAO,KAAK,EAAE,WAAW,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAC1E,OAAO,EAAiB,KAAK,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AACtF,OAAO,EAEL,KAAK,8BAA8B,EACpC,MAAM,yCAAyC,CAAC;AAIjD,OAAO,EAAmB,KAAK,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAazF,eAAO,IAAI,YAAY,kDAA4D,CAAC;AAGpF,MAAM,MAAM,gBAAgB,GAAG;IAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAAC;AAE1E,MAAM,WAAW,iBACf,SAAQ,yBAAyB,CAAC,WAAW,CAAC,EAC5C,WAAW,EACX,UAAU;IACZ;;OAEG;IACH,WAAW,EAAE,MAAM,CAAC;IACpB;;OAEG;IACH,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,gBAAgB,GAAG;QAAE,MAAM,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"ViewInfinite.d.ts","sourceRoot":"","sources":["../../../src/components/View/ViewInfinite.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAO/B,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAE/D,OAAO,KAAK,EAAE,WAAW,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAC1E,OAAO,EAAiB,KAAK,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AACtF,OAAO,EAEL,KAAK,8BAA8B,EACpC,MAAM,yCAAyC,CAAC;AAIjD,OAAO,EAAmB,KAAK,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAazF,eAAO,IAAI,YAAY,kDAA4D,CAAC;AAGpF,MAAM,MAAM,gBAAgB,GAAG;IAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAAC;AAE1E,MAAM,WAAW,iBACf,SAAQ,yBAAyB,CAAC,WAAW,CAAC,EAC5C,WAAW,EACX,UAAU;IACZ;;OAEG;IACH,WAAW,EAAE,MAAM,CAAC;IACpB;;OAEG;IACH,YAAY,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,gBAAgB,GAAG;QAAE,MAAM,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,CAAC,GAAG,SAAS,CAAC;IACtF;;OAEG;IACH,WAAW,CAAC,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,SAAS,CAAC;IACvC;;OAEG;IACH,gBAAgB,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,GAAG,SAAS,CAAC,GAAG,SAAS,CAAC;IAClF;;OAEG;IACH,iBAAiB,CAAC,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,SAAS,CAAC;IAC7C;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC/B;;OAEG;IACH,WAAW,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,gBAAgB,KAAK,OAAO,CAAC,GAAG,SAAS,CAAC;IAClE;;OAEG;IACH,QAAQ,CAAC,EAAE,oBAAoB,GAAG,SAAS,CAAC;IAC5C;;OAEG;IACH,cAAc,CAAC,EAAE,8BAA8B,GAAG,SAAS,CAAC;IAC5D;;OAEG;IACH,MAAM,CAAC,EAAE,sBAAsB,GAAG,SAAS,CAAC;CAC7C;AAGD,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,OAAO,CAAC;IAElB,aAAa,EAAE,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACpC,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,MAAM,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAC7B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IAEzB,WAAW,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAClC,eAAe,EAAE,MAAM,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,eAAe,EAAE,SAAS,GAAG,MAAM,GAAG,IAAI,CAAC;IAE3C,YAAY,EAAE,OAAO,CAAC;CACvB;AAkkBD,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAYpD,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { canUseDOM, type DOMProps, withDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasPlatform, HTMLAttributesWithRootRef } from '../../types';\nimport { ScrollContext, type ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n type ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { SplitColContext, type SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nexport let scrollsCache = new Map<string, Map<string, Array<number | undefined>>>();\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends HTMLAttributesWithRootRef<HTMLElement>,\n HasPlatform,\n NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: (params: TransitionParams & { isBack: boolean }) => void;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: () => void;\n /**\n * Обработчик начала анимации свайпа назад.\n */\n onSwipeBackStart?: (activePanel: string | null) => void | 'prevent';\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: () => void;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[];\n /**\n * Функция проверки перехода назад.\n */\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\n/* eslint-disable jsdoc/require-jsdoc */\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 swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: 'success' | 'fail' | null;\n\n browserSwipe: boolean;\n}\n/* eslint-enable jsdoc/require-jsdoc */\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\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 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 swipeBackPrevented = false;\n private readonly scrolls: Map<string, Array<number | undefined>> =\n scrollsCache.get(getNavId(this.props, warn) as string) || new Map();\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private readonly 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 Array<React.ReactElement<NavIdProps>>;\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache.set(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.get(prevProps.activePanel) || [];\n this.scrolls.set(prevProps.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n ]);\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\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 if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n this.scrolls.set(prevPanel, prevPanelScrolls);\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls.get(nextPanel) || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(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 === 'fail' &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls.get(this.state.activePanel) || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(this.state.activePanel, newPanelScrolls);\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 === 'vkcom'\n );\n }\n\n private transitionDisposer = noop;\n\n private disposeTransition() {\n this.transitionDisposer();\n this.transitionDisposer = noop;\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (this.shouldDisableTransitionMotion()) {\n this.disposeTransition();\n this.transitionFinishTimeout = setTimeout(eventHandler);\n } else if (elem) {\n this.disposeTransition();\n elem.addEventListener('transitionend', eventHandler);\n this.transitionDisposer = () => {\n elem.removeEventListener('transitionend', eventHandler);\n };\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === 'android' || this.props.platform === 'vkcom' ? 300 : 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.get(prevPanel) || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls.get(activePanel) || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls.set(prevPanel, prevPanelScrolls);\n this.scrolls.set(activePanel, newPanelScrolls);\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: React.AnimationEventHandler<HTMLDivElement> = (e): void => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (this.state.prevPanel !== null) {\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 'fail':\n this.onSwipeBackCancel();\n break;\n case '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 handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (this.state.browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n this.setState({ browserSwipe: true });\n }\n };\n\n handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (this.swipeBackPrevented || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if (this.state.animated && swipeBackTriggered) {\n return;\n }\n\n if (!this.state.swipingBack && this.props.history && this.props.history.length > 1) {\n if (swipedToOpposite) {\n this.swipeBackPrevented = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n this.swipeBackPrevented = true;\n return;\n }\n // Начался свайп назад\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.swipeBackPrevented = true;\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls.get(this.state.activePanel) || [];\n this.scrolls.set(this.state.activePanel, [\n ...prevScrolls,\n 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 if (event.shiftX < 0) {\n this.setState({ swipeBackShift: 0 });\n } else if (event.shiftX > this.window!.innerWidth - this.state.swipeBackStartX) {\n this.setState({ swipeBackShift: this.window!.innerWidth });\n } else {\n this.setState({ swipeBackShift: event.shiftX });\n }\n }\n };\n\n handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n this.swipeBackPrevented = false;\n\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * millisecondsInSecond;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (speed > 250 || this.state.swipeBackShift >= this.window.innerWidth / 2) {\n this.setState({ swipeBackResult: 'success' });\n } else {\n this.setState({ swipeBackResult: 'fail' });\n }\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 };\n }\n if (isPrev) {\n return {\n transform: `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 const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider?.isWebView && Boolean(onSwipeBack);\n\n return (\n <NavViewIdContext.Provider value={id || nav}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles.animated,\n !disableAnimation && this.state.swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchEndForIOSSwipeBackSimulation\n : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\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.get(panelId)) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles.panel,\n panelId === activePanel && styles.panelActive,\n panelId === prevPanel && styles.panelPrev,\n panelId === nextPanel && styles.panelNext,\n panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev,\n panelId === swipeBackNextPanel && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => {\n panelId !== undefined && (this.panelNodes[panelId] = el);\n }}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles.panelIn}\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 </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n }\n}\n\nexport const ViewInfinite: React.FC<ViewInfiniteProps> = 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","noop","withContext","withPlatform","millisecondsInSecond","canUseDOM","withDOM","LockFloatingPositionContext","getNavId","warnOnce","ScrollContext","ConfigProviderContext","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","SplitColContext","Touch","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","warn","scrollsCache","Map","ViewInfiniteComponent","Component","document","props","window","panels","Children","toArray","children","componentWillUnmount","id","set","scrolls","animationFinishTimeout","clearTimeout","componentDidUpdate","prevProps","prevState","activePanel","swipingBack","browserSwipe","isBack","isBackCheck","from","to","firstLayerId","map","panel","find","blurActiveElement","prevScrolls","get","scroll","getScroll","compensateKeyboardHeight","y","shouldDisableTransitionMotion","flushTransition","setState","visiblePanels","prevPanel","nextPanel","animated","state","swipeBackNextPanel","swipeBackPrevPanel","scrollPosition","undefined","prevPanelScrolls","slice","newPanelScrolls","pop","swipeBackResult","swipeBackStartX","swipeBackShift","scrollTo","onTransition","waitTransitionFinish","pickPanel","swipingBackTransitionEndHandler","configProvider","transitionMotionEnabled","splitCol","animate","platform","disposeTransition","transitionDisposer","elem","eventHandler","transitionFinishTimeout","setTimeout","addEventListener","removeEventListener","activeElement","blur","panelNodes","onSwipeBackSuccess","onSwipeBack","onSwipeBackCancel","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","innerWidth","prevPanelShadow","boxShadow","transform","render","_1","history","nav","onSwipeBackStart","className","restProps","filter","includes","sort","isPrevPanel","isNextPanel","disableAnimation","iOSSwipeBackSimulationEnabled","isWebView","Boolean","Provider","value","onMoveX","handleTouchMoveXForIOSSwipeBackSimulation","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","onEnd","handleTouchEndForIOSSwipeBackSimulation","div","compensateScroll","isTransitionTarget","scrollList","length","onAnimationEnd","transitionEndHandler","ref","el","style","marginTop","entering","swipeBackPrevented","e","target","currentTarget","propertyName","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","swipedToOpposite","originalEvent","payload","speed","duration","defaultProps","ViewInfinite"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { canUseDOM, type DOMProps, withDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasPlatform, HTMLAttributesWithRootRef } from '../../types';\nimport { ScrollContext, type ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n type ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { SplitColContext, type SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nexport let scrollsCache = new Map<string, Map<string, Array<number | undefined>>>();\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends HTMLAttributesWithRootRef<HTMLElement>,\n HasPlatform,\n NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: ((params: TransitionParams & { isBack: boolean }) => void) | undefined;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Функция проверки перехода назад.\n */\n isBackCheck?: ((params: TransitionParams) => boolean) | undefined;\n /**\n * @ignore\n */\n splitCol?: SplitColContextProps | undefined;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface | undefined;\n /**\n * @ignore\n */\n scroll?: ScrollContextInterface | undefined;\n}\n\n/* eslint-disable jsdoc/require-jsdoc */\nexport interface ViewInfiniteState {\n animated: boolean;\n\n visiblePanels: Array<string | null>;\n activePanel: string | null;\n isBack?: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack?: boolean | undefined;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: 'success' | 'fail' | null;\n\n browserSwipe: boolean;\n}\n/* eslint-enable jsdoc/require-jsdoc */\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\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 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 swipeBackPrevented = false;\n private readonly scrolls: Map<string, Array<number | undefined>> =\n scrollsCache.get(getNavId(this.props, warn) as string) || new Map();\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private readonly 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 Array<React.ReactElement<NavIdProps>>;\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache.set(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.get(prevProps.activePanel) || [];\n this.scrolls.set(prevProps.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n ]);\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\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 if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n this.scrolls.set(prevPanel, prevPanelScrolls);\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls.get(nextPanel) || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(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 === 'fail' &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls.get(this.state.activePanel) || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(this.state.activePanel, newPanelScrolls);\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 === 'vkcom'\n );\n }\n\n private transitionDisposer = noop;\n\n private disposeTransition() {\n this.transitionDisposer();\n this.transitionDisposer = noop;\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (this.shouldDisableTransitionMotion()) {\n this.disposeTransition();\n this.transitionFinishTimeout = setTimeout(eventHandler);\n } else if (elem) {\n this.disposeTransition();\n elem.addEventListener('transitionend', eventHandler);\n this.transitionDisposer = () => {\n elem.removeEventListener('transitionend', eventHandler);\n };\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === 'android' || this.props.platform === 'vkcom' ? 300 : 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.get(prevPanel) || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls.get(activePanel) || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls.set(prevPanel, prevPanelScrolls);\n this.scrolls.set(activePanel, newPanelScrolls);\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: React.AnimationEventHandler<HTMLDivElement> = (e): void => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (this.state.prevPanel !== null) {\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 'fail':\n this.onSwipeBackCancel();\n break;\n case '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 handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (this.state.browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n this.setState({ browserSwipe: true });\n }\n };\n\n handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (this.swipeBackPrevented || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if (this.state.animated && swipeBackTriggered) {\n return;\n }\n\n if (!this.state.swipingBack && this.props.history && this.props.history.length > 1) {\n if (swipedToOpposite) {\n this.swipeBackPrevented = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n this.swipeBackPrevented = true;\n return;\n }\n // Начался свайп назад\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.swipeBackPrevented = true;\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls.get(this.state.activePanel) || [];\n this.scrolls.set(this.state.activePanel, [\n ...prevScrolls,\n 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 if (event.shiftX < 0) {\n this.setState({ swipeBackShift: 0 });\n } else if (event.shiftX > this.window!.innerWidth - this.state.swipeBackStartX) {\n this.setState({ swipeBackShift: this.window!.innerWidth });\n } else {\n this.setState({ swipeBackShift: event.shiftX });\n }\n }\n };\n\n handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n this.swipeBackPrevented = false;\n\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * millisecondsInSecond;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (speed > 250 || this.state.swipeBackShift >= this.window.innerWidth / 2) {\n this.setState({ swipeBackResult: 'success' });\n } else {\n this.setState({ swipeBackResult: 'fail' });\n }\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 };\n }\n if (isPrev) {\n return {\n transform: `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 const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider?.isWebView && Boolean(onSwipeBack);\n\n return (\n <NavViewIdContext.Provider value={id || nav}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles.animated,\n !disableAnimation && this.state.swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchEndForIOSSwipeBackSimulation\n : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\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.get(panelId)) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles.panel,\n panelId === activePanel && styles.panelActive,\n panelId === prevPanel && styles.panelPrev,\n panelId === nextPanel && styles.panelNext,\n panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev,\n panelId === swipeBackNextPanel && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => {\n panelId !== undefined && (this.panelNodes[panelId] = el);\n }}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles.panelIn}\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 </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n }\n}\n\nexport const ViewInfinite: React.FC<ViewInfiniteProps> = 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","noop","withContext","withPlatform","millisecondsInSecond","canUseDOM","withDOM","LockFloatingPositionContext","getNavId","warnOnce","ScrollContext","ConfigProviderContext","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","SplitColContext","Touch","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","warn","scrollsCache","Map","ViewInfiniteComponent","Component","document","props","window","panels","Children","toArray","children","componentWillUnmount","id","set","scrolls","animationFinishTimeout","clearTimeout","componentDidUpdate","prevProps","prevState","activePanel","swipingBack","browserSwipe","isBack","isBackCheck","from","to","firstLayerId","map","panel","find","blurActiveElement","prevScrolls","get","scroll","getScroll","compensateKeyboardHeight","y","shouldDisableTransitionMotion","flushTransition","setState","visiblePanels","prevPanel","nextPanel","animated","state","swipeBackNextPanel","swipeBackPrevPanel","scrollPosition","undefined","prevPanelScrolls","slice","newPanelScrolls","pop","swipeBackResult","swipeBackStartX","swipeBackShift","scrollTo","onTransition","waitTransitionFinish","pickPanel","swipingBackTransitionEndHandler","configProvider","transitionMotionEnabled","splitCol","animate","platform","disposeTransition","transitionDisposer","elem","eventHandler","transitionFinishTimeout","setTimeout","addEventListener","removeEventListener","activeElement","blur","panelNodes","onSwipeBackSuccess","onSwipeBack","onSwipeBackCancel","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","innerWidth","prevPanelShadow","boxShadow","transform","render","_1","history","nav","onSwipeBackStart","className","restProps","filter","includes","sort","isPrevPanel","isNextPanel","disableAnimation","iOSSwipeBackSimulationEnabled","isWebView","Boolean","Provider","value","onMoveX","handleTouchMoveXForIOSSwipeBackSimulation","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","onEnd","handleTouchEndForIOSSwipeBackSimulation","div","compensateScroll","isTransitionTarget","scrollList","length","onAnimationEnd","transitionEndHandler","ref","el","style","marginTop","entering","swipeBackPrevented","e","target","currentTarget","propertyName","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","swipedToOpposite","originalEvent","payload","speed","duration","defaultProps","ViewInfinite"],"mappings":"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"}
|
|
@@ -4,40 +4,40 @@ export interface WriteBarProps extends Pick<React.TextareaHTMLAttributes<HTMLTex
|
|
|
4
4
|
/**
|
|
5
5
|
* @deprecated Since 7.9.0. Вместо этого используйте `slotProps={ textArea: { getRootRef: ... } }`.
|
|
6
6
|
*/
|
|
7
|
-
getRef?: React.Ref<HTMLTextAreaElement
|
|
7
|
+
getRef?: React.Ref<HTMLTextAreaElement> | undefined;
|
|
8
8
|
/**
|
|
9
9
|
* Свойства, которые можно прокинуть внутрь компонента:
|
|
10
10
|
* - `root`: свойства для прокидывания в корень компонента;
|
|
11
11
|
* - `textArea`: свойства для прокидывания в поле ввода.
|
|
12
12
|
*/
|
|
13
13
|
slotProps?: {
|
|
14
|
-
root?: Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & HasRootRef<HTMLDivElement> & HasDataAttribute;
|
|
15
|
-
textArea?: React.TextareaHTMLAttributes<HTMLTextAreaElement> & HasRootRef<HTMLTextAreaElement> & HasDataAttribute;
|
|
16
|
-
};
|
|
14
|
+
root?: (Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & HasRootRef<HTMLDivElement> & HasDataAttribute) | undefined;
|
|
15
|
+
textArea?: (React.TextareaHTMLAttributes<HTMLTextAreaElement> & HasRootRef<HTMLTextAreaElement> & HasDataAttribute) | undefined;
|
|
16
|
+
} | undefined;
|
|
17
17
|
/**
|
|
18
18
|
* Содержимое, отображаемое слева от поля ввода.
|
|
19
19
|
*/
|
|
20
|
-
before?: React.ReactNode;
|
|
20
|
+
before?: React.ReactNode | undefined;
|
|
21
21
|
/**
|
|
22
22
|
* Содержимое, отображаемое поверх поля ввода (актуально для iOS).
|
|
23
23
|
*/
|
|
24
|
-
inlineAfter?: React.ReactNode;
|
|
24
|
+
inlineAfter?: React.ReactNode | undefined;
|
|
25
25
|
/**
|
|
26
26
|
* Содержимое, отображаемое справа от поля ввода.
|
|
27
27
|
*/
|
|
28
|
-
after?: React.ReactNode;
|
|
28
|
+
after?: React.ReactNode | undefined;
|
|
29
29
|
/**
|
|
30
30
|
* Вызывается при смене высоты поля ввода.
|
|
31
31
|
*/
|
|
32
|
-
onHeightChange?: VoidFunction;
|
|
32
|
+
onHeightChange?: VoidFunction | undefined;
|
|
33
33
|
/**
|
|
34
34
|
* Добавляет тень вокруг поля ввода.
|
|
35
35
|
*/
|
|
36
|
-
shadow?: boolean;
|
|
36
|
+
shadow?: boolean | undefined;
|
|
37
37
|
/**
|
|
38
38
|
* @deprecated Неиспользуемое свойство.
|
|
39
39
|
*/
|
|
40
|
-
children?: never;
|
|
40
|
+
children?: never | undefined;
|
|
41
41
|
}
|
|
42
42
|
/**
|
|
43
43
|
* @see https://vkui.io/components/write-bar
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WriteBar.d.ts","sourceRoot":"","sources":["../../../src/components/WriteBar/WriteBar.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAO/B,OAAO,KAAK,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAUhE,MAAM,WAAW,aACf,SAAQ,IAAI,CACR,KAAK,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,EAC/C,cAAc,GACd,gBAAgB,GAChB,aAAa,GACb,MAAM,GACN,SAAS,GACT,UAAU,GACV,WAAW,GACX,WAAW,GACX,MAAM,GACN,aAAa,GACb,UAAU,GACV,UAAU,GACV,MAAM,GACN,OAAO,GACP,MAAM,GACN,MAAM,GACN,UAAU,GACV,SAAS,GACT,QAAQ,CACX,EACD,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,GAAG,SAAS,GAAG,QAAQ,CAAC,EAC7E,UAAU,CAAC,cAAc,CAAC;IAC5B;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"WriteBar.d.ts","sourceRoot":"","sources":["../../../src/components/WriteBar/WriteBar.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAO/B,OAAO,KAAK,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAUhE,MAAM,WAAW,aACf,SAAQ,IAAI,CACR,KAAK,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,EAC/C,cAAc,GACd,gBAAgB,GAChB,aAAa,GACb,MAAM,GACN,SAAS,GACT,UAAU,GACV,WAAW,GACX,WAAW,GACX,MAAM,GACN,aAAa,GACb,UAAU,GACV,UAAU,GACV,MAAM,GACN,OAAO,GACP,MAAM,GACN,MAAM,GACN,UAAU,GACV,SAAS,GACT,QAAQ,CACX,EACD,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,GAAG,SAAS,GAAG,QAAQ,CAAC,EAC7E,UAAU,CAAC,cAAc,CAAC;IAC5B;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,GAAG,SAAS,CAAC;IACpD;;;;OAIG;IACH,SAAS,CAAC,EACN;QACE,IAAI,CAAC,EACD,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,CAAC,GACrD,UAAU,CAAC,cAAc,CAAC,GAC1B,gBAAgB,CAAC,GACnB,SAAS,CAAC;QACd,QAAQ,CAAC,EACL,CAAC,KAAK,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,GAChD,UAAU,CAAC,mBAAmB,CAAC,GAC/B,gBAAgB,CAAC,GACnB,SAAS,CAAC;KACf,GACD,SAAS,CAAC;IACd;;OAEG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;IACrC;;OAEG;IACH,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;IAC1C;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;IACpC;;OAEG;IACH,cAAc,CAAC,EAAE,YAAY,GAAG,SAAS,CAAC;IAC1C;;OAEG;IACH,MAAM,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAC7B;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,GAAG,SAAS,CAAC;CAC9B;AAYD;;GAEG;AACH,eAAO,MAAM,QAAQ,GAAI,qWAsCtB,aAAa,KAAG,KAAK,CAAC,SA8ExB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/WriteBar/WriteBar.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useMergeProps } from '../../hooks/useMergeProps';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasDataAttribute, HasRootRef } from '../../types';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { useResizeTextarea } from '../Textarea/useResizeTextarea';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Title } from '../Typography/Title/Title';\nimport type { TypographyProps } from '../Typography/Typography';\nimport styles from './WriteBar.module.css';\n\nconst warn = warnOnce('WriteBar');\n\nexport interface WriteBarProps\n extends Pick<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n | 'autoComplete'\n | 'autoCapitalize'\n | 'autoCorrect'\n | 'cols'\n | 'dirName'\n | 'disabled'\n | 'maxLength'\n | 'minLength'\n | 'name'\n | 'placeholder'\n | 'readOnly'\n | 'required'\n | 'rows'\n | 'value'\n | 'wrap'\n | 'form'\n | 'onChange'\n | 'onFocus'\n | 'onBlur'\n >,\n Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'onFocus' | 'onBlur'>,\n HasRootRef<HTMLDivElement> {\n /**\n * @deprecated Since 7.9.0. Вместо этого используйте `slotProps={ textArea: { getRootRef: ... } }`.\n */\n getRef?: React.Ref<HTMLTextAreaElement
|
|
1
|
+
{"version":3,"sources":["../../../src/components/WriteBar/WriteBar.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useMergeProps } from '../../hooks/useMergeProps';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasDataAttribute, HasRootRef } from '../../types';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { useResizeTextarea } from '../Textarea/useResizeTextarea';\nimport { Headline } from '../Typography/Headline/Headline';\nimport { Title } from '../Typography/Title/Title';\nimport type { TypographyProps } from '../Typography/Typography';\nimport styles from './WriteBar.module.css';\n\nconst warn = warnOnce('WriteBar');\n\nexport interface WriteBarProps\n extends Pick<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n | 'autoComplete'\n | 'autoCapitalize'\n | 'autoCorrect'\n | 'cols'\n | 'dirName'\n | 'disabled'\n | 'maxLength'\n | 'minLength'\n | 'name'\n | 'placeholder'\n | 'readOnly'\n | 'required'\n | 'rows'\n | 'value'\n | 'wrap'\n | 'form'\n | 'onChange'\n | 'onFocus'\n | 'onBlur'\n >,\n Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'onFocus' | 'onBlur'>,\n HasRootRef<HTMLDivElement> {\n /**\n * @deprecated Since 7.9.0. Вместо этого используйте `slotProps={ textArea: { getRootRef: ... } }`.\n */\n getRef?: React.Ref<HTMLTextAreaElement> | undefined;\n /**\n * Свойства, которые можно прокинуть внутрь компонента:\n * - `root`: свойства для прокидывания в корень компонента;\n * - `textArea`: свойства для прокидывания в поле ввода.\n */\n slotProps?:\n | {\n root?:\n | (Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> &\n HasRootRef<HTMLDivElement> &\n HasDataAttribute)\n | undefined;\n textArea?:\n | (React.TextareaHTMLAttributes<HTMLTextAreaElement> &\n HasRootRef<HTMLTextAreaElement> &\n HasDataAttribute)\n | undefined;\n }\n | undefined;\n /**\n * Содержимое, отображаемое слева от поля ввода.\n */\n before?: React.ReactNode | undefined;\n /**\n * Содержимое, отображаемое поверх поля ввода (актуально для iOS).\n */\n inlineAfter?: React.ReactNode | undefined;\n /**\n * Содержимое, отображаемое справа от поля ввода.\n */\n after?: React.ReactNode | undefined;\n /**\n * Вызывается при смене высоты поля ввода.\n */\n onHeightChange?: VoidFunction | undefined;\n /**\n * Добавляет тень вокруг поля ввода.\n */\n shadow?: boolean | undefined;\n /**\n * @deprecated Неиспользуемое свойство.\n */\n children?: never | undefined;\n}\n\nconst WriteBarTypography = (props: TypographyProps) => {\n const platform = usePlatform();\n\n if (platform === 'ios') {\n return <Title {...props} level=\"3\" weight=\"3\" />;\n }\n\n return <Headline weight=\"3\" {...props} />;\n};\n\n/**\n * @see https://vkui.io/components/write-bar\n */\nexport const WriteBar = ({\n // WriteBarProps\n before,\n inlineAfter,\n after,\n onHeightChange,\n shadow = false,\n getRef,\n\n // textarea props\n autoComplete,\n autoCapitalize,\n autoCorrect,\n cols,\n dirName,\n disabled,\n maxLength,\n minLength,\n name,\n placeholder,\n readOnly,\n required,\n value: valueProp,\n wrap,\n rows,\n form,\n onChange: onChangeProp,\n onFocus,\n onBlur,\n id,\n inputMode,\n defaultValue,\n autoFocus,\n tabIndex,\n spellCheck,\n\n slotProps,\n ...restProps\n}: WriteBarProps): React.ReactNode => {\n /* istanbul ignore if: не проверяем в тестах */\n if (process.env.NODE_ENV === 'development' && getRef) {\n warn('Свойство `getRef` устаревшее, используйте `slotProps={ textArea: { getRootRef: ... } }`');\n }\n\n const platform = usePlatform();\n\n const rootProps = useMergeProps(restProps, slotProps?.root);\n\n const {\n onChange,\n getRootRef: getTextAreaRef,\n ...textAreaRest\n } = useMergeProps(\n {\n className: styles.textarea,\n getRootRef: getRef,\n autoComplete,\n autoCapitalize,\n autoCorrect,\n cols,\n dirName,\n disabled,\n maxLength,\n minLength,\n name,\n placeholder,\n readOnly,\n required,\n value: valueProp,\n wrap,\n rows,\n form,\n onChange: onChangeProp,\n onFocus,\n onBlur,\n id,\n inputMode,\n defaultValue,\n autoFocus,\n tabIndex,\n spellCheck,\n },\n slotProps?.textArea,\n );\n\n const [refResizeTextarea, resize] = useResizeTextarea(onHeightChange, true);\n const textareaRef = useExternRef(getTextAreaRef, refResizeTextarea);\n\n React.useEffect(resize, [resize, platform]);\n\n return (\n <RootComponent\n baseClassName={classNames(\n styles.host,\n platform === 'ios' && styles.ios,\n shadow && styles.shadow,\n )}\n {...rootProps}\n >\n <div className={styles.form}>\n {hasReactNode(before) && <div className={styles.before}>{before}</div>}\n\n <div className={styles.formIn}>\n <WriteBarTypography\n Component=\"textarea\"\n onChange={callMultiple(onChange, resize)}\n getRootRef={textareaRef}\n {...textAreaRest}\n />\n {hasReactNode(inlineAfter) && <div className={styles.inlineAfter}>{inlineAfter}</div>}\n </div>\n\n {hasReactNode(after) && <div className={styles.after}>{after}</div>}\n </div>\n </RootComponent>\n );\n};\n"],"names":["React","classNames","hasReactNode","useExternRef","useMergeProps","usePlatform","callMultiple","warnOnce","RootComponent","useResizeTextarea","Headline","Title","warn","WriteBarTypography","props","platform","level","weight","WriteBar","before","inlineAfter","after","onHeightChange","shadow","getRef","autoComplete","autoCapitalize","autoCorrect","cols","dirName","disabled","maxLength","minLength","name","placeholder","readOnly","required","value","valueProp","wrap","rows","form","onChange","onChangeProp","onFocus","onBlur","id","inputMode","defaultValue","autoFocus","tabIndex","spellCheck","slotProps","restProps","process","env","NODE_ENV","rootProps","root","getRootRef","getTextAreaRef","textAreaRest","className","textArea","refResizeTextarea","resize","textareaRef","useEffect","baseClassName","div","Component"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,YAAY,QAAQ,kBAAkB;AAC3D,SAASC,YAAY,QAAQ,8BAA2B;AACxD,SAASC,aAAa,QAAQ,+BAA4B;AAC1D,SAASC,WAAW,QAAQ,6BAA0B;AACtD,SAASC,YAAY,QAAQ,4BAAyB;AACtD,SAASC,QAAQ,QAAQ,wBAAqB;AAE9C,SAASC,aAAa,QAAQ,oCAAiC;AAC/D,SAASC,iBAAiB,QAAQ,mCAAgC;AAClE,SAASC,QAAQ,QAAQ,qCAAkC;AAC3D,SAASC,KAAK,QAAQ,+BAA4B;AAIlD,MAAMC,OAAOL,SAAS;AA4EtB,MAAMM,qBAAqB,CAACC;IAC1B,MAAMC,WAAWV;IAEjB,IAAIU,aAAa,OAAO;QACtB,qBAAO,KAACJ;YAAO,GAAGG,KAAK;YAAEE,OAAM;YAAIC,QAAO;;IAC5C;IAEA,qBAAO,KAACP;QAASO,QAAO;QAAK,GAAGH,KAAK;;AACvC;AAEA;;CAEC,GACD,OAAO,MAAMI,WAAW,CAAC,EACvB,gBAAgB;AAChBC,MAAM,EACNC,WAAW,EACXC,KAAK,EACLC,cAAc,EACdC,SAAS,KAAK,EACdC,MAAM,EAEN,iBAAiB;AACjBC,YAAY,EACZC,cAAc,EACdC,WAAW,EACXC,IAAI,EACJC,OAAO,EACPC,QAAQ,EACRC,SAAS,EACTC,SAAS,EACTC,IAAI,EACJC,WAAW,EACXC,QAAQ,EACRC,QAAQ,EACRC,OAAOC,SAAS,EAChBC,IAAI,EACJC,IAAI,EACJC,IAAI,EACJC,UAAUC,YAAY,EACtBC,OAAO,EACPC,MAAM,EACNC,EAAE,EACFC,SAAS,EACTC,YAAY,EACZC,SAAS,EACTC,QAAQ,EACRC,UAAU,EAEVC,SAAS,EACT,GAAGC,WACW;IACd,6CAA6C,GAC7C,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,iBAAiBhC,QAAQ;QACpDZ,KAAK;IACP;IAEA,MAAMG,WAAWV;IAEjB,MAAMoD,YAAYrD,cAAciD,WAAWD,WAAWM;IAEtD,MAAM,EACJhB,QAAQ,EACRiB,YAAYC,cAAc,EAC1B,GAAGC,cACJ,GAAGzD,cACF;QACE0D,SAAS;QACTH,YAAYnC;QACZC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC,OAAOC;QACPC;QACAC;QACAC;QACAC,UAAUC;QACVC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;IACF,GACAC,WAAWW;IAGb,MAAM,CAACC,mBAAmBC,OAAO,GAAGxD,kBAAkBa,gBAAgB;IACtE,MAAM4C,cAAc/D,aAAayD,gBAAgBI;IAEjDhE,MAAMmE,SAAS,CAACF,QAAQ;QAACA;QAAQlD;KAAS;IAE1C,qBACE,KAACP;QACC4D,eAAenE,iCAEbc,aAAa,8BACbQ;QAED,GAAGkC,SAAS;kBAEb,cAAA,MAACY;YAAIP,SAAS;;gBACX5D,aAAaiB,yBAAW,KAACkD;oBAAIP,SAAS;8BAAkB3C;;8BAEzD,MAACkD;oBAAIP,SAAS;;sCACZ,KAACjD;4BACCyD,WAAU;4BACV5B,UAAUpC,aAAaoC,UAAUuB;4BACjCN,YAAYO;4BACX,GAAGL,YAAY;;wBAEjB3D,aAAakB,8BAAgB,KAACiD;4BAAIP,SAAS;sCAAuB1C;;;;gBAGpElB,aAAamB,wBAAU,KAACgD;oBAAIP,SAAS;8BAAiBzC;;;;;AAI/D,EAAE"}
|
|
@@ -9,15 +9,15 @@ export interface WriteBarIconProps extends React.ButtonHTMLAttributes<HTMLButton
|
|
|
9
9
|
* - `send` – иконка отправки, текст по умолчанию — "Отправить";
|
|
10
10
|
* - `done` – иконка отправки в режиме редактирования, текст по умолчанию — "Готово".
|
|
11
11
|
*/
|
|
12
|
-
mode?: 'attach' | 'send' | 'done';
|
|
12
|
+
mode?: 'attach' | 'send' | 'done' | undefined;
|
|
13
13
|
/**
|
|
14
14
|
* Значение счётчика для кнопки. Например, для количества прикреплённых файлов.
|
|
15
15
|
*/
|
|
16
|
-
count?: number;
|
|
16
|
+
count?: number | undefined;
|
|
17
17
|
/**
|
|
18
18
|
* Текст кнопки. Необходим для ассистивных технологий.
|
|
19
19
|
*/
|
|
20
|
-
label?: string;
|
|
20
|
+
label?: string | undefined;
|
|
21
21
|
}
|
|
22
22
|
/**
|
|
23
23
|
* @see https://vkui.io/components/write-bar#write-bar-icon
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WriteBarIcon.d.ts","sourceRoot":"","sources":["../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAC;AA4BpC,MAAM,WAAW,iBAAkB,SAAQ,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;IACtF;;;;;;;;OAQG;IACH,IAAI,CAAC,EAAE,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"WriteBarIcon.d.ts","sourceRoot":"","sources":["../../../src/components/WriteBarIcon/WriteBarIcon.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAC;AA4BpC,MAAM,WAAW,iBAAkB,SAAQ,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;IACtF;;;;;;;;OAQG;IACH,IAAI,CAAC,EAAE,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;IAC9C;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC5B;AAID;;GAEG;AACH,eAAO,MAAM,YAAY,GAAI,2DAM1B,iBAAiB,KAAG,KAAK,CAAC,SAqE5B,CAAC"}
|