@vkontakte/vkui 8.1.3 → 8.2.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/ActionSheet/ActionSheet.d.ts +5 -4
- package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
- package/dist/components/ActionSheet/ActionSheet.js +2 -1
- package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +3 -3
- package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
- package/dist/components/AdaptivityProvider/AdaptivityProvider.js +2 -2
- package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
- package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
- package/dist/components/AppRoot/AppRoot.js +0 -6
- package/dist/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/components/AppRoot/AppRootContext.d.ts +0 -1
- package/dist/components/AppRoot/AppRootContext.d.ts.map +1 -1
- package/dist/components/AppRoot/AppRootContext.js +0 -1
- package/dist/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/components/Calendar/Calendar.d.ts +1 -1
- package/dist/components/Calendar/Calendar.js +2 -1
- package/dist/components/Calendar/Calendar.js.map +1 -1
- package/dist/components/CalendarDay/CalendarDay.d.ts.map +1 -1
- package/dist/components/CalendarDay/CalendarDay.js +4 -2
- package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
- package/dist/components/CalendarDays/CalendarDays.d.ts.map +1 -1
- package/dist/components/CalendarDays/CalendarDays.js +2 -2
- package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
- package/dist/components/CalendarHeader/CalendarHeader.js +4 -2
- package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
- package/dist/components/CalendarRange/CalendarRange.d.ts +2 -2
- package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
- package/dist/components/CalendarTime/CalendarTime.d.ts +1 -1
- package/dist/components/CalendarTime/CalendarTime.d.ts.map +1 -1
- package/dist/components/CalendarTime/CalendarTime.js +61 -50
- package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
- package/dist/components/CalendarTime/CalendarTimePicker.d.ts +11 -7
- package/dist/components/CalendarTime/CalendarTimePicker.d.ts.map +1 -1
- package/dist/components/CalendarTime/CalendarTimePicker.js +108 -48
- package/dist/components/CalendarTime/CalendarTimePicker.js.map +1 -1
- package/dist/components/CalendarTime/ComboBox.d.ts +25 -0
- package/dist/components/CalendarTime/ComboBox.d.ts.map +1 -0
- package/dist/components/CalendarTime/ComboBox.js +112 -0
- package/dist/components/CalendarTime/ComboBox.js.map +1 -0
- package/dist/components/CardScroll/CardScroll.d.ts.map +1 -1
- package/dist/components/CardScroll/CardScroll.js +2 -2
- package/dist/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/components/CarouselBase/CarouselBase.d.ts.map +1 -1
- package/dist/components/CarouselBase/CarouselBase.js +3 -1
- package/dist/components/CarouselBase/CarouselBase.js.map +1 -1
- package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
- package/dist/components/ChipsSelect/useChipsSelect.js +2 -1
- package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.d.ts.map +1 -1
- package/dist/components/ConfigProvider/ConfigProvider.js +8 -4
- package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProviderOverride.d.ts.map +1 -1
- package/dist/components/ConfigProvider/ConfigProviderOverride.js +5 -1
- package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
- package/dist/components/ConfigProvider/ConfigProviderSubContexts.d.ts +15 -0
- package/dist/components/ConfigProvider/ConfigProviderSubContexts.d.ts.map +1 -0
- package/dist/components/ConfigProvider/ConfigProviderSubContexts.js +25 -0
- package/dist/components/ConfigProvider/ConfigProviderSubContexts.js.map +1 -0
- package/dist/components/ContentBadge/ContentBadge.d.ts +14 -1
- package/dist/components/ContentBadge/ContentBadge.d.ts.map +1 -1
- package/dist/components/ContentBadge/ContentBadge.js +39 -1
- package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
- package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
- package/dist/components/CustomSelect/CustomSelect.js +16 -10
- package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/components/DateInput/DateInput.d.ts.map +1 -1
- package/dist/components/DateInput/DateInput.js +4 -3
- package/dist/components/DateInput/DateInput.js.map +1 -1
- package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
- package/dist/components/DateRangeInput/DateRangeInput.js +2 -2
- package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
- package/dist/components/Epic/ScrollSaver.d.ts.map +1 -1
- package/dist/components/Epic/ScrollSaver.js +1 -0
- package/dist/components/Epic/ScrollSaver.js.map +1 -1
- package/dist/components/FixedLayout/ParentWidthWrapper.d.ts +6 -0
- package/dist/components/FixedLayout/ParentWidthWrapper.d.ts.map +1 -0
- package/dist/components/FixedLayout/ParentWidthWrapper.js +43 -0
- package/dist/components/FixedLayout/ParentWidthWrapper.js.map +1 -0
- package/dist/components/Flex/Flex.d.ts +7 -4
- package/dist/components/Flex/Flex.d.ts.map +1 -1
- package/dist/components/Flex/Flex.js +5 -2
- package/dist/components/Flex/Flex.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +3 -1
- package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.js +6 -2
- package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltip.js +2 -1
- package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
- package/dist/components/PanelHeader/PanelHeader.d.ts +1 -1
- package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/components/Popper/Popper.js +1 -1
- package/dist/components/Popper/Popper.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.js +8 -4
- package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/components/Root/Root.d.ts +1 -1
- package/dist/components/Root/Root.d.ts.map +1 -1
- package/dist/components/Root/Root.js +14 -5
- package/dist/components/Root/Root.js.map +1 -1
- package/dist/components/SimpleGrid/SimpleGrid.d.ts +9 -8
- package/dist/components/SimpleGrid/SimpleGrid.d.ts.map +1 -1
- package/dist/components/SimpleGrid/SimpleGrid.js +9 -2
- package/dist/components/SimpleGrid/SimpleGrid.js.map +1 -1
- package/dist/components/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/components/Skeleton/Skeleton.js +3 -4
- package/dist/components/Skeleton/Skeleton.js.map +1 -1
- package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
- package/dist/components/Snackbar/Snackbar.js +6 -3
- package/dist/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/components/Spacing/Spacing.d.ts +1 -1
- package/dist/components/Spacing/Spacing.js.map +1 -1
- package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.d.ts +10 -0
- package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.d.ts.map +1 -0
- package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js +54 -0
- package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js.map +1 -0
- package/dist/components/Spinner/ExpressiveSpinner/icons.d.ts +18 -0
- package/dist/components/Spinner/ExpressiveSpinner/icons.d.ts.map +1 -0
- package/dist/components/Spinner/ExpressiveSpinner/icons.js +79 -0
- package/dist/components/Spinner/ExpressiveSpinner/icons.js.map +1 -0
- package/dist/components/Spinner/SvgIcon.d.ts +14 -0
- package/dist/components/Spinner/SvgIcon.d.ts.map +1 -0
- package/dist/components/Spinner/SvgIcon.js +20 -0
- package/dist/components/Spinner/SvgIcon.js.map +1 -0
- package/dist/components/Spinner/icons.d.ts +1 -1
- package/dist/components/Spinner/icons.d.ts.map +1 -1
- package/dist/components/Spinner/icons.js +10 -23
- package/dist/components/Spinner/icons.js.map +1 -1
- package/dist/components/SplitLayout/SplitLayout.d.ts +3 -3
- package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
- package/dist/components/TabsItem/TabsItem.js +2 -5
- package/dist/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/components/Tappable/Tappable.d.ts +2 -2
- package/dist/components/Tappable/Tappable.js.map +1 -1
- package/dist/components/WriteBar/WriteBar.d.ts +15 -1
- package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
- package/dist/components/WriteBar/WriteBar.js +35 -63
- package/dist/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.d.ts +5 -0
- package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.d.ts.map +1 -0
- package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js +15 -0
- package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js.map +1 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.d.ts +8 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.d.ts.map +1 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.js +16 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.js.map +1 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.d.ts +5 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.d.ts.map +1 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js +15 -0
- package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js.map +1 -0
- package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.d.ts +10 -0
- package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.d.ts.map +1 -0
- package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.js +16 -0
- package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.js.map +1 -0
- package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.d.ts +10 -0
- package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.d.ts.map +1 -0
- package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js +39 -0
- package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js.map +1 -0
- package/dist/components.css +1 -1
- package/dist/components.css.map +1 -1
- package/dist/cssm/components/ActionSheet/ActionSheet.js +2 -1
- package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
- package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
- package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +2 -2
- package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRoot.js +0 -6
- package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
- package/dist/cssm/components/AppRoot/AppRootContext.js +0 -1
- package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
- package/dist/cssm/components/Calendar/Calendar.js +2 -1
- package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
- package/dist/cssm/components/CalendarDay/CalendarDay.js +4 -2
- package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
- package/dist/cssm/components/CalendarDays/CalendarDays.js +2 -2
- package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
- package/dist/cssm/components/CalendarHeader/CalendarHeader.js +4 -2
- 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 +61 -50
- package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
- package/dist/cssm/components/CalendarTime/CalendarTime.module.css +38 -0
- package/dist/cssm/components/CalendarTime/CalendarTimePicker.js +108 -48
- package/dist/cssm/components/CalendarTime/CalendarTimePicker.js.map +1 -1
- package/dist/cssm/components/CalendarTime/ComboBox.js +113 -0
- package/dist/cssm/components/CalendarTime/ComboBox.js.map +1 -0
- package/dist/cssm/components/CardScroll/CardScroll.js +2 -2
- package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
- package/dist/cssm/components/CarouselBase/CarouselBase.js +3 -1
- package/dist/cssm/components/CarouselBase/CarouselBase.js.map +1 -1
- package/dist/cssm/components/ChipsSelect/useChipsSelect.js +2 -1
- package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
- package/dist/cssm/components/ConfigProvider/ConfigProvider.js +8 -4
- package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
- package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js +5 -1
- package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
- package/dist/cssm/components/ConfigProvider/ConfigProviderSubContexts.js +25 -0
- package/dist/cssm/components/ConfigProvider/ConfigProviderSubContexts.js.map +1 -0
- package/dist/cssm/components/ContentBadge/ContentBadge.js +39 -1
- package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
- package/dist/cssm/components/ContentBadge/ContentBadge.module.css +88 -90
- package/dist/cssm/components/CustomSelect/CustomSelect.js +16 -10
- package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
- package/dist/cssm/components/DateInput/DateInput.js +4 -3
- package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
- package/dist/cssm/components/DateRangeInput/DateRangeInput.js +2 -2
- package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
- package/dist/cssm/components/Epic/ScrollSaver.js +1 -0
- package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
- package/dist/cssm/components/FixedLayout/ParentWidthWrapper.js +43 -0
- package/dist/cssm/components/FixedLayout/ParentWidthWrapper.js.map +1 -0
- package/dist/cssm/components/Flex/Flex.js +5 -2
- package/dist/cssm/components/Flex/Flex.js.map +1 -1
- package/dist/cssm/components/GridAvatar/GridAvatar.module.css +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +3 -1
- package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
- package/dist/cssm/components/NativeSelect/NativeSelect.js +6 -2
- package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js +2 -1
- package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
- package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
- package/dist/cssm/components/Popper/Popper.js +1 -1
- package/dist/cssm/components/Popper/Popper.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js +8 -4
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +1 -1
- package/dist/cssm/components/Root/Root.js +14 -5
- package/dist/cssm/components/Root/Root.js.map +1 -1
- package/dist/cssm/components/SimpleGrid/SimpleGrid.js +9 -2
- package/dist/cssm/components/SimpleGrid/SimpleGrid.js.map +1 -1
- package/dist/cssm/components/Skeleton/Skeleton.js +3 -4
- package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
- package/dist/cssm/components/Snackbar/Snackbar.js +6 -3
- package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
- package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
- package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js +56 -0
- package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js.map +1 -0
- package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css +13 -0
- package/dist/cssm/components/Spinner/ExpressiveSpinner/icons.js +79 -0
- package/dist/cssm/components/Spinner/ExpressiveSpinner/icons.js.map +1 -0
- package/dist/cssm/components/Spinner/SvgIcon.js +20 -0
- package/dist/cssm/components/Spinner/SvgIcon.js.map +1 -0
- package/dist/cssm/components/Spinner/icons.js +10 -23
- package/dist/cssm/components/Spinner/icons.js.map +1 -1
- package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.js +2 -5
- package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
- package/dist/cssm/components/WriteBar/WriteBar.js +35 -64
- package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js +16 -0
- package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js.map +1 -0
- package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css +12 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.js +17 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.js.map +1 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css +18 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js +16 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js.map +1 -0
- package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css +3 -0
- package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.js +17 -0
- package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.js.map +1 -0
- package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css +15 -0
- package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js +40 -0
- package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js.map +1 -0
- package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css +43 -0
- package/dist/cssm/helpers/math.js +6 -0
- package/dist/cssm/helpers/math.js.map +1 -1
- package/dist/cssm/hoc/withPlatform.js +3 -2
- package/dist/cssm/hoc/withPlatform.js.map +1 -1
- package/dist/cssm/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
- package/dist/cssm/hooks/useAnimationFrame.js +40 -0
- package/dist/cssm/hooks/useAnimationFrame.js.map +1 -0
- package/dist/cssm/hooks/useAutoFocus.js +4 -1
- package/dist/cssm/hooks/useAutoFocus.js.map +1 -1
- package/dist/cssm/hooks/useColorScheme.js +3 -3
- package/dist/cssm/hooks/useColorScheme.js.map +1 -1
- package/dist/cssm/hooks/useConfigDirection.js +3 -3
- package/dist/cssm/hooks/useConfigDirection.js.map +1 -1
- package/dist/cssm/hooks/useDateInput.js +1 -2
- package/dist/cssm/hooks/useDateInput.js.map +1 -1
- package/dist/cssm/hooks/useFocusTrap/useAutoFocus.js +1 -0
- package/dist/cssm/hooks/useFocusTrap/useAutoFocus.js.map +1 -1
- package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js +2 -0
- package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
- package/dist/cssm/hooks/useFocusVisible.js +8 -13
- package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
- package/dist/cssm/hooks/useFocusWithin.js +5 -4
- package/dist/cssm/hooks/useFocusWithin.js.map +1 -1
- package/dist/cssm/hooks/useGlobalEscKeyDown.js +17 -15
- package/dist/cssm/hooks/useGlobalEscKeyDown.js.map +1 -1
- package/dist/cssm/hooks/useGlobalOnClickOutside.js +6 -2
- package/dist/cssm/hooks/useGlobalOnClickOutside.js.map +1 -1
- package/dist/cssm/hooks/useKeyboardInputTracker.js +48 -41
- package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
- package/dist/cssm/hooks/useLatestRef.js +13 -0
- package/dist/cssm/hooks/useLatestRef.js.map +1 -0
- package/dist/cssm/hooks/useLocale.js +3 -3
- package/dist/cssm/hooks/useLocale.js.map +1 -1
- package/dist/cssm/hooks/useMediaQueryMatch.js +1 -0
- package/dist/cssm/hooks/useMediaQueryMatch.js.map +1 -1
- package/dist/cssm/hooks/useMutationObserver.js +3 -3
- package/dist/cssm/hooks/useMutationObserver.js.map +1 -1
- package/dist/cssm/hooks/usePlatform.js +3 -3
- package/dist/cssm/hooks/usePlatform.js.map +1 -1
- package/dist/cssm/hooks/useResizeObserver.js +4 -6
- package/dist/cssm/hooks/useResizeObserver.js.map +1 -1
- package/dist/cssm/hooks/useSyncHTMLWithBaseVKUIClasses.js +2 -1
- package/dist/cssm/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
- package/dist/cssm/hooks/useSyncHTMLWithTokens.js +3 -1
- package/dist/cssm/hooks/useSyncHTMLWithTokens.js.map +1 -1
- package/dist/cssm/hooks/useWaitTransitionFinish.js +13 -15
- package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
- package/dist/cssm/index.js +1 -0
- package/dist/cssm/index.js.map +1 -1
- package/dist/cssm/lib/array.js +18 -0
- package/dist/cssm/lib/array.js.map +1 -0
- package/dist/cssm/lib/curve.js +21 -0
- package/dist/cssm/lib/curve.js.map +1 -0
- package/dist/cssm/lib/dom.js +5 -2
- package/dist/cssm/lib/dom.js.map +1 -1
- package/dist/cssm/lib/fx.js +4 -55
- package/dist/cssm/lib/fx.js.map +1 -1
- package/dist/cssm/lib/layouts/index.js.map +1 -1
- package/dist/cssm/lib/layouts/layoutProps.js +11 -0
- package/dist/cssm/lib/layouts/layoutProps.js.map +1 -1
- package/dist/cssm/lib/layouts/resolveLayoutProps.js +13 -11
- package/dist/cssm/lib/layouts/resolveLayoutProps.js.map +1 -1
- package/dist/cssm/lib/layouts/types.js.map +1 -1
- package/dist/cssm/lib/material/shapes/Shape.js +18 -0
- package/dist/cssm/lib/material/shapes/Shape.js.map +1 -0
- package/dist/cssm/lib/material/shapes/shapes.js +2250 -0
- package/dist/cssm/lib/material/shapes/shapes.js.map +1 -0
- package/dist/cssm/lib/math.js +31 -0
- package/dist/cssm/lib/math.js.map +1 -0
- package/dist/cssm/lib/svg/path/approximate.js +57 -0
- package/dist/cssm/lib/svg/path/approximate.js.map +1 -0
- package/dist/cssm/lib/svg/path/interpolate.js +121 -0
- package/dist/cssm/lib/svg/path/interpolate.js.map +1 -0
- package/dist/cssm/lib/svg/path/path.js +50 -0
- package/dist/cssm/lib/svg/path/path.js.map +1 -0
- package/dist/cssm/lib/svg/path/point.js +3 -0
- package/dist/cssm/lib/svg/path/point.js.map +1 -0
- package/dist/cssm/lib/svg/path/transform.js +110 -0
- package/dist/cssm/lib/svg/path/transform.js.map +1 -0
- package/dist/cssm/lib/tokens/useTokenClassName.js +4 -1
- package/dist/cssm/lib/tokens/useTokenClassName.js.map +1 -1
- package/dist/cssm/lib/touch/UIPanGestureRecognizer.js +2 -2
- package/dist/cssm/lib/touch/UIPanGestureRecognizer.js.map +1 -1
- package/dist/cssm/styles/layout.css +273 -0
- package/dist/cssm/types.js +1 -4
- package/dist/cssm/types.js.map +1 -1
- package/dist/helpers/math.d.ts +4 -0
- package/dist/helpers/math.d.ts.map +1 -1
- package/dist/helpers/math.js +6 -0
- package/dist/helpers/math.js.map +1 -1
- package/dist/hoc/withPlatform.d.ts +1 -1
- package/dist/hoc/withPlatform.d.ts.map +1 -1
- package/dist/hoc/withPlatform.js +3 -2
- package/dist/hoc/withPlatform.js.map +1 -1
- package/dist/hooks/useAdaptivityConditionalRender/types.d.ts +2 -2
- package/dist/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
- package/dist/hooks/useAnimationFrame.d.ts +16 -0
- package/dist/hooks/useAnimationFrame.d.ts.map +1 -0
- package/dist/hooks/useAnimationFrame.js +40 -0
- package/dist/hooks/useAnimationFrame.js.map +1 -0
- package/dist/hooks/useAutoFocus.js +4 -1
- package/dist/hooks/useAutoFocus.js.map +1 -1
- package/dist/hooks/useColorScheme.d.ts.map +1 -1
- package/dist/hooks/useColorScheme.js +3 -3
- package/dist/hooks/useColorScheme.js.map +1 -1
- package/dist/hooks/useConfigDirection.d.ts.map +1 -1
- package/dist/hooks/useConfigDirection.js +3 -3
- package/dist/hooks/useConfigDirection.js.map +1 -1
- package/dist/hooks/useDateInput.d.ts.map +1 -1
- package/dist/hooks/useDateInput.js +1 -2
- package/dist/hooks/useDateInput.js.map +1 -1
- package/dist/hooks/useFocusTrap/useAutoFocus.js +1 -0
- package/dist/hooks/useFocusTrap/useAutoFocus.js.map +1 -1
- package/dist/hooks/useFocusTrap/useFocusTrap.d.ts.map +1 -1
- package/dist/hooks/useFocusTrap/useFocusTrap.js +2 -0
- package/dist/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
- package/dist/hooks/useFocusVisible.d.ts.map +1 -1
- package/dist/hooks/useFocusVisible.js +8 -13
- package/dist/hooks/useFocusVisible.js.map +1 -1
- package/dist/hooks/useFocusWithin.d.ts.map +1 -1
- package/dist/hooks/useFocusWithin.js +5 -4
- package/dist/hooks/useFocusWithin.js.map +1 -1
- package/dist/hooks/useGlobalEscKeyDown.d.ts.map +1 -1
- package/dist/hooks/useGlobalEscKeyDown.js +17 -15
- package/dist/hooks/useGlobalEscKeyDown.js.map +1 -1
- package/dist/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
- package/dist/hooks/useGlobalOnClickOutside.js +6 -2
- package/dist/hooks/useGlobalOnClickOutside.js.map +1 -1
- package/dist/hooks/useKeyboardInputTracker.d.ts +1 -19
- package/dist/hooks/useKeyboardInputTracker.d.ts.map +1 -1
- package/dist/hooks/useKeyboardInputTracker.js +48 -41
- package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
- package/dist/hooks/useLatestRef.d.ts +3 -0
- package/dist/hooks/useLatestRef.d.ts.map +1 -0
- package/dist/hooks/useLatestRef.js +13 -0
- package/dist/hooks/useLatestRef.js.map +1 -0
- package/dist/hooks/useLocale.d.ts.map +1 -1
- package/dist/hooks/useLocale.js +3 -3
- package/dist/hooks/useLocale.js.map +1 -1
- package/dist/hooks/useMediaQueryMatch.js +1 -0
- package/dist/hooks/useMediaQueryMatch.js.map +1 -1
- package/dist/hooks/useMutationObserver.d.ts +1 -2
- package/dist/hooks/useMutationObserver.d.ts.map +1 -1
- package/dist/hooks/useMutationObserver.js +3 -3
- package/dist/hooks/useMutationObserver.js.map +1 -1
- package/dist/hooks/usePlatform.d.ts.map +1 -1
- package/dist/hooks/usePlatform.js +3 -3
- package/dist/hooks/usePlatform.js.map +1 -1
- package/dist/hooks/useResizeObserver.d.ts.map +1 -1
- package/dist/hooks/useResizeObserver.js +4 -6
- package/dist/hooks/useResizeObserver.js.map +1 -1
- package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.js +2 -1
- package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
- package/dist/hooks/useSyncHTMLWithTokens.js +3 -1
- package/dist/hooks/useSyncHTMLWithTokens.js.map +1 -1
- package/dist/hooks/useWaitTransitionFinish.d.ts.map +1 -1
- package/dist/hooks/useWaitTransitionFinish.js +13 -15
- package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/array.d.ts +17 -0
- package/dist/lib/array.d.ts.map +1 -0
- package/dist/lib/array.js +18 -0
- package/dist/lib/array.js.map +1 -0
- package/dist/lib/curve.d.ts +9 -0
- package/dist/lib/curve.d.ts.map +1 -0
- package/dist/lib/curve.js +21 -0
- package/dist/lib/curve.js.map +1 -0
- package/dist/lib/dom.d.ts +2 -1
- package/dist/lib/dom.d.ts.map +1 -1
- package/dist/lib/dom.js +5 -2
- package/dist/lib/dom.js.map +1 -1
- package/dist/lib/fx.d.ts +1 -8
- package/dist/lib/fx.d.ts.map +1 -1
- package/dist/lib/fx.js +4 -55
- package/dist/lib/fx.js.map +1 -1
- package/dist/lib/layouts/index.d.ts +1 -1
- package/dist/lib/layouts/index.d.ts.map +1 -1
- package/dist/lib/layouts/index.js.map +1 -1
- package/dist/lib/layouts/layoutProps.d.ts +7 -0
- package/dist/lib/layouts/layoutProps.d.ts.map +1 -1
- package/dist/lib/layouts/layoutProps.js +11 -0
- package/dist/lib/layouts/layoutProps.js.map +1 -1
- package/dist/lib/layouts/resolveLayoutProps.d.ts.map +1 -1
- package/dist/lib/layouts/resolveLayoutProps.js +13 -11
- package/dist/lib/layouts/resolveLayoutProps.js.map +1 -1
- package/dist/lib/layouts/types.d.ts +29 -0
- package/dist/lib/layouts/types.d.ts.map +1 -1
- package/dist/lib/layouts/types.js.map +1 -1
- package/dist/lib/material/shapes/Shape.d.ts +8 -0
- package/dist/lib/material/shapes/Shape.d.ts.map +1 -0
- package/dist/lib/material/shapes/Shape.js +18 -0
- package/dist/lib/material/shapes/Shape.js.map +1 -0
- package/dist/lib/material/shapes/shapes.d.ts +43 -0
- package/dist/lib/material/shapes/shapes.d.ts.map +1 -0
- package/dist/lib/material/shapes/shapes.js +2250 -0
- package/dist/lib/material/shapes/shapes.js.map +1 -0
- package/dist/lib/math.d.ts +23 -0
- package/dist/lib/math.d.ts.map +1 -0
- package/dist/lib/math.js +31 -0
- package/dist/lib/math.js.map +1 -0
- package/dist/lib/svg/path/approximate.d.ts +21 -0
- package/dist/lib/svg/path/approximate.d.ts.map +1 -0
- package/dist/lib/svg/path/approximate.js +57 -0
- package/dist/lib/svg/path/approximate.js.map +1 -0
- package/dist/lib/svg/path/interpolate.d.ts +5 -0
- package/dist/lib/svg/path/interpolate.d.ts.map +1 -0
- package/dist/lib/svg/path/interpolate.js +121 -0
- package/dist/lib/svg/path/interpolate.js.map +1 -0
- package/dist/lib/svg/path/path.d.ts +48 -0
- package/dist/lib/svg/path/path.d.ts.map +1 -0
- package/dist/lib/svg/path/path.js +50 -0
- package/dist/lib/svg/path/path.js.map +1 -0
- package/dist/lib/svg/path/point.d.ts +3 -0
- package/dist/lib/svg/path/point.d.ts.map +1 -0
- package/dist/lib/svg/path/point.js +3 -0
- package/dist/lib/svg/path/point.js.map +1 -0
- package/dist/lib/svg/path/transform.d.ts +64 -0
- package/dist/lib/svg/path/transform.d.ts.map +1 -0
- package/dist/lib/svg/path/transform.js +110 -0
- package/dist/lib/svg/path/transform.js.map +1 -0
- package/dist/lib/tokens/useTokenClassName.d.ts.map +1 -1
- package/dist/lib/tokens/useTokenClassName.js +4 -1
- package/dist/lib/tokens/useTokenClassName.js.map +1 -1
- package/dist/lib/touch/UIPanGestureRecognizer.d.ts.map +1 -1
- package/dist/lib/touch/UIPanGestureRecognizer.js +2 -2
- package/dist/lib/touch/UIPanGestureRecognizer.js.map +1 -1
- package/dist/types.d.ts +9 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -4
- package/dist/types.js.map +1 -1
- package/dist/vkui.css +1 -1
- package/dist/vkui.css.map +1 -1
- package/package.json +7 -6
- package/src/components/ActionSheet/ActionSheet.tsx +6 -3
- package/src/components/AdaptivityProvider/AdaptivityContext.tsx +3 -3
- package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +2 -2
- package/src/components/AppRoot/AppRoot.tsx +1 -14
- package/src/components/AppRoot/AppRootContext.ts +0 -2
- package/src/components/Calendar/Calendar.tsx +2 -2
- package/src/components/CalendarDay/CalendarDay.tsx +4 -2
- package/src/components/CalendarDays/CalendarDays.tsx +2 -2
- package/src/components/CalendarHeader/CalendarHeader.tsx +4 -2
- package/src/components/CalendarRange/CalendarRange.tsx +2 -2
- package/src/components/CalendarTime/CalendarTime.module.css +38 -0
- package/src/components/CalendarTime/CalendarTime.module.css.d.ts.map +1 -1
- package/src/components/CalendarTime/CalendarTime.tsx +68 -55
- package/src/components/CalendarTime/CalendarTimePicker.tsx +148 -62
- package/src/components/CalendarTime/ComboBox.tsx +189 -0
- package/src/components/CardScroll/CardScroll.tsx +6 -5
- package/src/components/CarouselBase/CarouselBase.tsx +2 -1
- package/src/components/ChipsSelect/useChipsSelect.ts +1 -0
- package/src/components/ConfigProvider/ConfigProvider.tsx +6 -3
- package/src/components/ConfigProvider/ConfigProviderOverride.tsx +2 -1
- package/src/components/ConfigProvider/ConfigProviderSubContexts.tsx +43 -0
- package/src/components/ContentBadge/ContentBadge.module.css +84 -91
- package/src/components/ContentBadge/ContentBadge.module.css.d.ts.map +1 -1
- package/src/components/ContentBadge/ContentBadge.tsx +73 -5
- package/src/components/CustomSelect/CustomSelect.tsx +19 -10
- package/src/components/DateInput/DateInput.tsx +3 -3
- package/src/components/DateRangeInput/DateRangeInput.tsx +2 -2
- package/src/components/Epic/ScrollSaver.tsx +1 -0
- package/src/components/FixedLayout/ParentWidthWrapper.tsx +48 -0
- package/src/components/Flex/Flex.tsx +11 -6
- package/src/components/GridAvatar/GridAvatar.module.css +1 -1
- package/src/components/GridAvatar/GridAvatar.module.css.d.ts.map +1 -1
- package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.tsx +1 -1
- package/src/components/NativeSelect/NativeSelect.tsx +4 -2
- package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +1 -1
- package/src/components/PanelHeader/PanelHeader.tsx +1 -1
- package/src/components/Popper/Popper.tsx +1 -1
- package/src/components/PullToRefresh/PullToRefresh.module.css +1 -1
- package/src/components/PullToRefresh/PullToRefresh.tsx +10 -3
- package/src/components/Root/Root.tsx +10 -7
- package/src/components/SimpleGrid/SimpleGrid.tsx +25 -11
- package/src/components/Skeleton/Skeleton.tsx +6 -4
- package/src/components/Snackbar/Snackbar.tsx +6 -3
- package/src/components/Spacing/Spacing.tsx +1 -1
- package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css +13 -0
- package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css.d.ts.map +1 -0
- package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.tsx +73 -0
- package/src/components/Spinner/ExpressiveSpinner/icons.tsx +104 -0
- package/src/components/Spinner/SvgIcon.tsx +31 -0
- package/src/components/Spinner/icons.tsx +10 -13
- package/src/components/SplitLayout/SplitLayout.tsx +3 -3
- package/src/components/TabsItem/TabsItem.tsx +4 -5
- package/src/components/Tappable/Tappable.tsx +2 -2
- package/src/components/WriteBar/WriteBar.tsx +25 -59
- package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css +12 -0
- package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css.d.ts.map +1 -0
- package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.tsx +20 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css +18 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css.d.ts.map +1 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.tsx +22 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css +3 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css.d.ts.map +1 -0
- package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.tsx +23 -0
- package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css +14 -0
- package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css.d.ts.map +1 -0
- package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.tsx +31 -0
- package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css +42 -0
- package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css.d.ts.map +1 -0
- package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.tsx +48 -0
- package/src/helpers/math.ts +8 -0
- package/src/hoc/withPlatform.tsx +3 -3
- package/src/hooks/useAdaptivityConditionalRender/types.ts +2 -2
- package/src/hooks/useAnimationFrame.tsx +42 -0
- package/src/hooks/useAutoFocus.ts +1 -1
- package/src/hooks/useColorScheme.ts +3 -4
- package/src/hooks/useConfigDirection.ts +3 -4
- package/src/hooks/useDateInput.ts +1 -2
- package/src/hooks/useFocusTrap/useAutoFocus.ts +1 -1
- package/src/hooks/useFocusTrap/useFocusTrap.tsx +2 -0
- package/src/hooks/useFocusVisible.ts +10 -18
- package/src/hooks/useFocusWithin.ts +26 -23
- package/src/hooks/useGlobalEscKeyDown.ts +12 -15
- package/src/hooks/useGlobalOnClickOutside.ts +5 -2
- package/src/hooks/useKeyboardInputTracker.ts +68 -55
- package/src/hooks/useLatestRef.ts +12 -0
- package/src/hooks/useLocale.ts +3 -4
- package/src/hooks/useMediaQueryMatch.ts +1 -1
- package/src/hooks/useMutationObserver.ts +2 -3
- package/src/hooks/usePlatform.ts +3 -4
- package/src/hooks/useResizeObserver.ts +4 -5
- package/src/hooks/useSyncHTMLWithBaseVKUIClasses.ts +1 -1
- package/src/hooks/useSyncHTMLWithTokens.ts +1 -1
- package/src/hooks/useWaitTransitionFinish.ts +15 -15
- package/src/index.ts +1 -0
- package/src/lib/array.ts +19 -0
- package/src/lib/curve.ts +36 -0
- package/src/lib/dom.tsx +10 -4
- package/src/lib/fx.ts +5 -63
- package/src/lib/layouts/index.ts +1 -0
- package/src/lib/layouts/layoutProps.ts +8 -0
- package/src/lib/layouts/resolveLayoutProps.ts +19 -17
- package/src/lib/layouts/types.ts +29 -0
- package/src/lib/material/shapes/Shape.tsx +17 -0
- package/src/lib/material/shapes/shapes.ts +329 -0
- package/src/lib/math.ts +37 -0
- package/src/lib/svg/path/approximate.ts +81 -0
- package/src/lib/svg/path/interpolate.ts +151 -0
- package/src/lib/svg/path/path.ts +102 -0
- package/src/lib/svg/path/point.ts +2 -0
- package/src/lib/svg/path/transform.ts +147 -0
- package/src/lib/tokens/useTokenClassName.ts +7 -5
- package/src/lib/touch/UIPanGestureRecognizer.ts +2 -2
- package/src/types.ts +16 -0
- package/dist/cssm/components/WriteBar/WriteBar.module.css +0 -118
- package/src/components/WriteBar/WriteBar.module.css +0 -116
- package/src/components/WriteBar/WriteBar.module.css.d.ts.map +0 -1
package/src/lib/fx.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { cubicBezierTwoDimensional } from './curve';
|
|
2
|
+
|
|
1
3
|
/**
|
|
2
4
|
* ease function
|
|
3
5
|
* @param x absolute progress of the animation in bounds 0 (beginning) and 1 (end)
|
|
@@ -6,68 +8,8 @@ export function easeInOutSine(x: number): number {
|
|
|
6
8
|
return 0.5 * (1 - Math.cos(Math.PI * x));
|
|
7
9
|
}
|
|
8
10
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
* Алгебраический метод решения взят из PRа {@link https://github.com/gre/bezier-easing/pull/57}
|
|
13
|
-
*/
|
|
14
|
-
export function cubicBezier(mX1: number, mY1: number, mX2: number, mY2: number) {
|
|
15
|
-
if (!(0 <= mX1 && mX1 <= 1 && 0 <= mX2 && mX2 <= 1)) {
|
|
16
|
-
throw new Error('Bezier x values must be in [0, 1] range');
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
if (mX1 === mY1 && mX2 === mY2) {
|
|
20
|
-
return LinearEasing;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const a = 6 * (3 * mX1 - 3 * mX2 + 1);
|
|
24
|
-
const b = 6 * (mX2 - 2 * mX1);
|
|
25
|
-
const c = 3 * mX1;
|
|
26
|
-
const a2 = a * a;
|
|
27
|
-
const b2 = b * b;
|
|
28
|
-
const d = b / a;
|
|
29
|
-
const e = (3 * b * c) / a2 - (b2 * b) / (a2 * a);
|
|
30
|
-
const w1 = (2 * c) / a - b2 / a2;
|
|
31
|
-
const w = w1 * w1 * w1;
|
|
32
|
-
const o = 3 / a;
|
|
33
|
-
const ay = 3 * mY1 - 3 * mY2 + 1;
|
|
34
|
-
const by = mY2 - 2 * mY1;
|
|
35
|
-
const cy = 3 * mY1;
|
|
36
|
-
|
|
37
|
-
const funcX2T = a ? x2t : LinearEasing;
|
|
38
|
-
|
|
39
|
-
return (x: number) => {
|
|
40
|
-
if (x === 0 || x === 1) {
|
|
41
|
-
return x;
|
|
42
|
-
}
|
|
43
|
-
return funcY(funcX2T(x, e, o, w, d), ay, by, cy);
|
|
11
|
+
export function cubicBezier(x1: number, y1: number, x2: number, y2: number) {
|
|
12
|
+
return function (progress: number): number {
|
|
13
|
+
return cubicBezierTwoDimensional(0, 0, x1, y1, x2, y2, 1, 1, progress)[1];
|
|
44
14
|
};
|
|
45
15
|
}
|
|
46
|
-
|
|
47
|
-
function LinearEasing(x: number) {
|
|
48
|
-
return x;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function x2t(x: number, a: number, b: number, c: number, d: number) {
|
|
52
|
-
const q = a + b * x;
|
|
53
|
-
const s = q ** 2 + c;
|
|
54
|
-
if (s > 0) {
|
|
55
|
-
const root = Math.sqrt(s);
|
|
56
|
-
return Math.cbrt(q + root) + Math.cbrt(q - root) - d;
|
|
57
|
-
}
|
|
58
|
-
const l = Math.cbrt(Math.sqrt(q * q - s));
|
|
59
|
-
const angle = q ? Math.atan(Math.sqrt(-s) / q) : -Math.PI / 2;
|
|
60
|
-
let φ;
|
|
61
|
-
if (b < 0) {
|
|
62
|
-
φ = (q > 0 ? 2 * Math.PI : Math.PI) - angle;
|
|
63
|
-
} else if (d < 0) {
|
|
64
|
-
φ = (q > 0 ? 2 * Math.PI : -3 * Math.PI) + angle;
|
|
65
|
-
} else {
|
|
66
|
-
φ = (q > 0 ? 0 : Math.PI) + angle;
|
|
67
|
-
}
|
|
68
|
-
return 2 * l * Math.cos(φ / 3) - d;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
function funcY(t: number, ay: number, by: number, cy: number) {
|
|
72
|
-
return ((ay * t + 3 * by) * t + cy) * t;
|
|
73
|
-
}
|
package/src/lib/layouts/index.ts
CHANGED
|
@@ -27,6 +27,7 @@ const CSS_GLOBAL_KEYWORDS: CSSGlobalValue[] = ['inherit', 'initial', 'unset'];
|
|
|
27
27
|
|
|
28
28
|
const CSS_KEYWORDS = [...CSS_INTRINSIC_KEYWORDS, ...CSS_GLOBAL_KEYWORDS];
|
|
29
29
|
const PADDING_VALUES = [...DESIGN_SYSTEM_SIZES, ...CSS_GLOBAL_KEYWORDS, 'system'];
|
|
30
|
+
const MARGIN_VALUES = [...DESIGN_SYSTEM_SIZES, ...CSS_GLOBAL_KEYWORDS];
|
|
30
31
|
const SIZE_VALUES = CSS_KEYWORDS;
|
|
31
32
|
const MINMAX_SIZE_VALUES = [...CSS_KEYWORDS.filter((opt) => opt !== 'auto')];
|
|
32
33
|
const FLEX_VALUES = CSS_GLOBAL_KEYWORDS;
|
|
@@ -49,6 +50,13 @@ export const SYSTEM_PADDING_VERTICAL = 'var(--vkui--size_base_padding_vertical--
|
|
|
49
50
|
export const SYSTEM_PADDING_HORIZONTAL = 'var(--vkui--size_base_padding_horizontal--regular)';
|
|
50
51
|
|
|
51
52
|
export const LAYOUT_PROPS = {
|
|
53
|
+
margin: MARGIN_VALUES,
|
|
54
|
+
marginInline: MARGIN_VALUES,
|
|
55
|
+
marginBlock: MARGIN_VALUES,
|
|
56
|
+
marginInlineStart: MARGIN_VALUES,
|
|
57
|
+
marginInlineEnd: MARGIN_VALUES,
|
|
58
|
+
marginBlockStart: MARGIN_VALUES,
|
|
59
|
+
marginBlockEnd: MARGIN_VALUES,
|
|
52
60
|
padding: PADDING_VALUES,
|
|
53
61
|
paddingInline: PADDING_VALUES,
|
|
54
62
|
paddingBlock: PADDING_VALUES,
|
|
@@ -24,23 +24,25 @@ export function resolveLayoutProps<T extends ComponentProps>(
|
|
|
24
24
|
let resolvedStyle: React.CSSProperties | undefined;
|
|
25
25
|
|
|
26
26
|
for (const key in LAYOUT_PROPS) {
|
|
27
|
-
if (key in outProps
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
resolvedClassName
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
27
|
+
if (key in outProps) {
|
|
28
|
+
if (outProps[key] !== undefined) {
|
|
29
|
+
const propDef = LAYOUT_PROPS[key as LayoutPropKeys];
|
|
30
|
+
const value = outProps[key];
|
|
31
|
+
const cssProperty = key.replace(/([A-Z])/g, '-$1').toLowerCase();
|
|
32
|
+
if (typeof value === 'string' && (propDef as string[]).includes(value)) {
|
|
33
|
+
resolvedClassName = classNames(
|
|
34
|
+
resolvedClassName,
|
|
35
|
+
generateConstantClassName(cssProperty, value),
|
|
36
|
+
);
|
|
37
|
+
} else if (key !== 'position' && !key.startsWith('overflow')) {
|
|
38
|
+
resolvedClassName = classNames(resolvedClassName, generateVariableClassName(cssProperty));
|
|
39
|
+
resolvedStyle = mergeStyle(resolvedStyle, {
|
|
40
|
+
[generateVariable(cssProperty)]:
|
|
41
|
+
typeof value === 'number' && key !== 'flexGrow' && key !== 'flexShrink'
|
|
42
|
+
? `${value}px`
|
|
43
|
+
: value,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
44
46
|
}
|
|
45
47
|
delete outProps[key];
|
|
46
48
|
}
|
package/src/lib/layouts/types.ts
CHANGED
|
@@ -18,6 +18,7 @@ export type PaddingProp = LiteralUnion<
|
|
|
18
18
|
DesignSystemSize | CSSGlobalValue | 'system',
|
|
19
19
|
number | string
|
|
20
20
|
>;
|
|
21
|
+
export type MarginProp = LiteralUnion<DesignSystemSize | CSSGlobalValue, number | string>;
|
|
21
22
|
|
|
22
23
|
// Типы для параметров позиционирования
|
|
23
24
|
export type InsetProp = LiteralUnion<DesignSystemSize | CSSGlobalValue | 'auto', number | string>;
|
|
@@ -39,6 +40,34 @@ type AlignSelfProp = SelfPositionProp | 'baseline' | 'stretch';
|
|
|
39
40
|
type JustifySelfProp = SelfPositionProp | 'baseline' | 'stretch';
|
|
40
41
|
|
|
41
42
|
export interface LayoutProps {
|
|
43
|
+
/**
|
|
44
|
+
* Внешние отступы со всех сторон.
|
|
45
|
+
*/
|
|
46
|
+
margin?: MarginProp | undefined;
|
|
47
|
+
/**
|
|
48
|
+
* Внешние отступы по строчной оси.
|
|
49
|
+
*/
|
|
50
|
+
marginInline?: MarginProp | undefined;
|
|
51
|
+
/**
|
|
52
|
+
* Внешние отступы по блочной оси.
|
|
53
|
+
*/
|
|
54
|
+
marginBlock?: MarginProp | undefined;
|
|
55
|
+
/**
|
|
56
|
+
* Внешний начальный отступ по строчной оси.
|
|
57
|
+
*/
|
|
58
|
+
marginInlineStart?: MarginProp | undefined;
|
|
59
|
+
/**
|
|
60
|
+
* Внешний конечный отступ по строчной оси.
|
|
61
|
+
*/
|
|
62
|
+
marginInlineEnd?: MarginProp | undefined;
|
|
63
|
+
/**
|
|
64
|
+
* Внешний начальный отступ по блочной оси.
|
|
65
|
+
*/
|
|
66
|
+
marginBlockStart?: MarginProp | undefined;
|
|
67
|
+
/**
|
|
68
|
+
* Внешний конечный отступ по блочной оси.
|
|
69
|
+
*/
|
|
70
|
+
marginBlockEnd?: MarginProp | undefined;
|
|
42
71
|
/**
|
|
43
72
|
* Внутренние отступы со всех сторон.
|
|
44
73
|
*/
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { RootComponent } from '../../../components/RootComponent/RootComponent';
|
|
2
|
+
import { type HasRootRef } from '../../../types';
|
|
3
|
+
import { svgPathToString } from '../../svg/path/path';
|
|
4
|
+
import * as shapes from './shapes';
|
|
5
|
+
|
|
6
|
+
export interface ShapeProps extends React.ComponentProps<'svg'>, HasRootRef<SVGElement> {
|
|
7
|
+
size?: number;
|
|
8
|
+
params: shapes.ShapeParameters;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function Shape({ size = 24, params, ...props }: ShapeProps) {
|
|
12
|
+
return (
|
|
13
|
+
<RootComponent Component="svg" width={size} height={size} {...props}>
|
|
14
|
+
<path d={svgPathToString(shapes.shape(params, size))} fill="currentColor" />
|
|
15
|
+
</RootComponent>
|
|
16
|
+
);
|
|
17
|
+
}
|
|
@@ -0,0 +1,329 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Набор форм M3
|
|
3
|
+
*
|
|
4
|
+
* https://m3.material.io/styles/shape/overview-principles
|
|
5
|
+
*/
|
|
6
|
+
import { type DeepReadonly, type ReadonlyWeakMap } from '../../../types';
|
|
7
|
+
import { type SVGPathSupport } from '../../svg/path/path';
|
|
8
|
+
import * as transform from '../../svg/path/transform';
|
|
9
|
+
|
|
10
|
+
export interface ShapeParameters {
|
|
11
|
+
/**
|
|
12
|
+
* SVG путь для фигуры размером [0,1] на [0,1]
|
|
13
|
+
*/
|
|
14
|
+
readonly path: DeepReadonly<SVGPathSupport>;
|
|
15
|
+
/**
|
|
16
|
+
* Масштабирующий коэффициент предназначен для возможности помещения
|
|
17
|
+
* в произвольный контейнер фигуры учитывая вращение
|
|
18
|
+
*/
|
|
19
|
+
readonly rotateScaleFactor: number;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Возвращает фигуру определенного размера
|
|
24
|
+
*/
|
|
25
|
+
export function shape(shapeParams: ShapeParameters, size: number): SVGPathSupport {
|
|
26
|
+
return transform.scale(shapeParams.path, size, size);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Возвращает фигуру с возможностью поворота, которая помещается в контейнер
|
|
31
|
+
* определенного размера
|
|
32
|
+
*/
|
|
33
|
+
export function shapeWithRotate(shapeParams: ShapeParameters, size: number): SVGPathSupport {
|
|
34
|
+
const scaleSize = shapeParams.rotateScaleFactor * size;
|
|
35
|
+
const translateFactor = (size - scaleSize) / 2;
|
|
36
|
+
|
|
37
|
+
return transform.translate(shape(shapeParams, scaleSize), translateFactor, translateFactor);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export const ovalParams: ShapeParameters = {
|
|
41
|
+
path: [
|
|
42
|
+
['M', [0.771, 0.771]],
|
|
43
|
+
['C', [0.539, 1.003, 0.2296, 1.0698, 0.0799, 0.9201]],
|
|
44
|
+
['C', [-0.0698, 0.7704, -0.003, 0.461, 0.229, 0.229]],
|
|
45
|
+
['C', [0.461, -0.003, 0.7704, -0.0698, 0.9201, 0.0799]],
|
|
46
|
+
['C', [1.0698, 0.2296, 1.003, 0.539, 0.771, 0.771]],
|
|
47
|
+
['Z', []],
|
|
48
|
+
],
|
|
49
|
+
rotateScaleFactor: 30 / 38,
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
export const cookie4Params: ShapeParameters = {
|
|
53
|
+
path: [
|
|
54
|
+
['M', [0.6383, 0.0222]],
|
|
55
|
+
['C', [0.8531, -0.0711, 1.0711, 0.1469, 0.9778, 0.3617]],
|
|
56
|
+
['L', [0.9624, 0.3972]],
|
|
57
|
+
['C', [0.9339, 0.4628, 0.9339, 0.5372, 0.9624, 0.6028]],
|
|
58
|
+
['L', [0.9778, 0.6383]],
|
|
59
|
+
['C', [1.0711, 0.8531, 0.8531, 1.0711, 0.6383, 0.9778]],
|
|
60
|
+
['L', [0.6028, 0.9624]],
|
|
61
|
+
['C', [0.5372, 0.9339, 0.4628, 0.9339, 0.3972, 0.9624]],
|
|
62
|
+
['L', [0.3617, 0.9778]],
|
|
63
|
+
['C', [0.1469, 1.0711, -0.0711, 0.8531, 0.0222, 0.6383]],
|
|
64
|
+
['L', [0.0376, 0.6028]],
|
|
65
|
+
['C', [0.0661, 0.5372, 0.0661, 0.4628, 0.0376, 0.3972]],
|
|
66
|
+
['L', [0.0222, 0.3617]],
|
|
67
|
+
['C', [-0.0711, 0.1469, 0.1469, -0.0711, 0.3617, 0.0222]],
|
|
68
|
+
['L', [0.3972, 0.0376]],
|
|
69
|
+
['C', [0.4628, 0.0661, 0.5372, 0.0661, 0.6028, 0.0376]],
|
|
70
|
+
['L', [0.6383, 0.0222]],
|
|
71
|
+
['Z', []],
|
|
72
|
+
],
|
|
73
|
+
rotateScaleFactor: 28 / 38,
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
export const sunnyParams: ShapeParameters = {
|
|
77
|
+
path: [
|
|
78
|
+
['M', [0.7702, 0.1213]],
|
|
79
|
+
['C', [0.8013, 0.1234, 0.8168, 0.1245, 0.8294, 0.13]],
|
|
80
|
+
['C', [0.8476, 0.1379, 0.8621, 0.1524, 0.87, 0.1706]],
|
|
81
|
+
['C', [0.8755, 0.1832, 0.8766, 0.1987, 0.8787, 0.2298]],
|
|
82
|
+
['L', [0.8835, 0.3008]],
|
|
83
|
+
['C', [0.8844, 0.3134, 0.8848, 0.3197, 0.8862, 0.3257]],
|
|
84
|
+
['C', [0.8882, 0.3344, 0.8916, 0.3426, 0.8963, 0.3502]],
|
|
85
|
+
['C', [0.8996, 0.3554, 0.9038, 0.3601, 0.912, 0.3696]],
|
|
86
|
+
['L', [0.9588, 0.4232]],
|
|
87
|
+
['C', [0.9793, 0.4467, 0.9896, 0.4585, 0.9946, 0.4712]],
|
|
88
|
+
['C', [1.0018, 0.4897, 1.0018, 0.5103, 0.9946, 0.5287]],
|
|
89
|
+
['C', [0.9896, 0.5415, 0.9793, 0.5533, 0.9588, 0.5768]],
|
|
90
|
+
['L', [0.912, 0.6303]],
|
|
91
|
+
['C', [0.9038, 0.6398, 0.8996, 0.6446, 0.8963, 0.6498]],
|
|
92
|
+
['C', [0.8916, 0.6573, 0.8882, 0.6656, 0.8862, 0.6743]],
|
|
93
|
+
['C', [0.8848, 0.6803, 0.8844, 0.6866, 0.8835, 0.6992]],
|
|
94
|
+
['L', [0.8787, 0.7702]],
|
|
95
|
+
['C', [0.8766, 0.8013, 0.8755, 0.8168, 0.87, 0.8294]],
|
|
96
|
+
['C', [0.8621, 0.8476, 0.8476, 0.8621, 0.8294, 0.87]],
|
|
97
|
+
['C', [0.8168, 0.8755, 0.8013, 0.8766, 0.7702, 0.8787]],
|
|
98
|
+
['L', [0.6992, 0.8835]],
|
|
99
|
+
['C', [0.6866, 0.8844, 0.6803, 0.8848, 0.6743, 0.8862]],
|
|
100
|
+
['C', [0.6656, 0.8882, 0.6573, 0.8916, 0.6498, 0.8963]],
|
|
101
|
+
['C', [0.6446, 0.8996, 0.6398, 0.9038, 0.6303, 0.912]],
|
|
102
|
+
['L', [0.5768, 0.9588]],
|
|
103
|
+
['C', [0.5533, 0.9793, 0.5415, 0.9896, 0.5287, 0.9946]],
|
|
104
|
+
['C', [0.5103, 1.0018, 0.4897, 1.0018, 0.4712, 0.9946]],
|
|
105
|
+
['C', [0.4585, 0.9896, 0.4467, 0.9793, 0.4232, 0.9588]],
|
|
106
|
+
['L', [0.3696, 0.912]],
|
|
107
|
+
['C', [0.3601, 0.9038, 0.3554, 0.8996, 0.3502, 0.8963]],
|
|
108
|
+
['C', [0.3426, 0.8916, 0.3344, 0.8882, 0.3257, 0.8862]],
|
|
109
|
+
['C', [0.3197, 0.8848, 0.3134, 0.8844, 0.3008, 0.8835]],
|
|
110
|
+
['L', [0.2298, 0.8787]],
|
|
111
|
+
['C', [0.1987, 0.8766, 0.1832, 0.8755, 0.1706, 0.87]],
|
|
112
|
+
['C', [0.1524, 0.8621, 0.1379, 0.8476, 0.13, 0.8294]],
|
|
113
|
+
['C', [0.1245, 0.8168, 0.1234, 0.8013, 0.1213, 0.7702]],
|
|
114
|
+
['L', [0.1165, 0.6992]],
|
|
115
|
+
['C', [0.1156, 0.6866, 0.1152, 0.6803, 0.1138, 0.6743]],
|
|
116
|
+
['C', [0.1118, 0.6656, 0.1084, 0.6573, 0.1037, 0.6498]],
|
|
117
|
+
['C', [0.1004, 0.6446, 0.0962, 0.6398, 0.0879, 0.6303]],
|
|
118
|
+
['L', [0.0412, 0.5768]],
|
|
119
|
+
['C', [0.0207, 0.5533, 0.0104, 0.5415, 0.0054, 0.5287]],
|
|
120
|
+
['C', [-0.0018, 0.5103, -0.0018, 0.4897, 0.0054, 0.4712]],
|
|
121
|
+
['C', [0.0104, 0.4585, 0.0207, 0.4467, 0.0412, 0.4232]],
|
|
122
|
+
['L', [0.0879, 0.3696]],
|
|
123
|
+
['C', [0.0962, 0.3601, 0.1004, 0.3554, 0.1037, 0.3502]],
|
|
124
|
+
['C', [0.1084, 0.3426, 0.1118, 0.3344, 0.1138, 0.3257]],
|
|
125
|
+
['C', [0.1152, 0.3197, 0.1156, 0.3134, 0.1165, 0.3008]],
|
|
126
|
+
['L', [0.1213, 0.2298]],
|
|
127
|
+
['C', [0.1234, 0.1987, 0.1245, 0.1832, 0.13, 0.1706]],
|
|
128
|
+
['C', [0.1379, 0.1524, 0.1524, 0.1379, 0.1706, 0.13]],
|
|
129
|
+
['C', [0.1832, 0.1245, 0.1987, 0.1234, 0.2298, 0.1213]],
|
|
130
|
+
['L', [0.3008, 0.1165]],
|
|
131
|
+
['C', [0.3134, 0.1156, 0.3197, 0.1152, 0.3257, 0.1138]],
|
|
132
|
+
['C', [0.3344, 0.1118, 0.3426, 0.1084, 0.3502, 0.1037]],
|
|
133
|
+
['C', [0.3554, 0.1004, 0.3601, 0.0962, 0.3696, 0.0879]],
|
|
134
|
+
['L', [0.4232, 0.0412]],
|
|
135
|
+
['C', [0.4467, 0.0207, 0.4585, 0.0104, 0.4712, 0.0054]],
|
|
136
|
+
['C', [0.4897, -0.0018, 0.5103, -0.0018, 0.5287, 0.0054]],
|
|
137
|
+
['C', [0.5415, 0.0104, 0.5533, 0.0207, 0.5768, 0.0412]],
|
|
138
|
+
['L', [0.6303, 0.0879]],
|
|
139
|
+
['C', [0.6398, 0.0962, 0.6446, 0.1004, 0.6498, 0.1037]],
|
|
140
|
+
['C', [0.6573, 0.1084, 0.6656, 0.1118, 0.6743, 0.1138]],
|
|
141
|
+
['C', [0.6803, 0.1152, 0.6866, 0.1156, 0.6992, 0.1165]],
|
|
142
|
+
['L', [0.7702, 0.1213]],
|
|
143
|
+
['Z', []],
|
|
144
|
+
],
|
|
145
|
+
rotateScaleFactor: 34 / 38,
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
export const pillParams: ShapeParameters = {
|
|
149
|
+
path: [
|
|
150
|
+
['M', [0.2662, 0.1259]],
|
|
151
|
+
['C', [0.4341, -0.042, 0.7062, -0.042, 0.8741, 0.1259]],
|
|
152
|
+
['C', [1.042, 0.2938, 1.042, 0.5659, 0.8741, 0.7338]],
|
|
153
|
+
['L', [0.7338, 0.8741]],
|
|
154
|
+
['C', [0.5659, 1.042, 0.2938, 1.042, 0.1259, 0.8741]],
|
|
155
|
+
['C', [-0.042, 0.7062, -0.042, 0.4341, 0.1259, 0.2662]],
|
|
156
|
+
['L', [0.2662, 0.1259]],
|
|
157
|
+
['Z', []],
|
|
158
|
+
],
|
|
159
|
+
rotateScaleFactor: 30 / 38,
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
export const pentagonParams: ShapeParameters = {
|
|
163
|
+
path: [
|
|
164
|
+
['M', [0.3426, 0.0864]],
|
|
165
|
+
['C', [0.3914, 0.0509, 0.4158, 0.0331, 0.4418, 0.0243]],
|
|
166
|
+
['C', [0.4795, 0.0115, 0.5205, 0.0115, 0.5582, 0.0243]],
|
|
167
|
+
['C', [0.5842, 0.0331, 0.6086, 0.0509, 0.6574, 0.0864]],
|
|
168
|
+
['L', [0.7641, 0.1641]],
|
|
169
|
+
['L', [0.8707, 0.237]],
|
|
170
|
+
['C', [0.9213, 0.2715, 0.9466, 0.2888, 0.9635, 0.3105]],
|
|
171
|
+
['C', [0.988, 0.3419, 1.0008, 0.3806, 1, 0.4201]],
|
|
172
|
+
['C', [0.9994, 0.4474, 0.9893, 0.4759, 0.9692, 0.533]],
|
|
173
|
+
['L', [0.9273, 0.6519]],
|
|
174
|
+
['L', [0.8887, 0.7738]],
|
|
175
|
+
['C', [0.8705, 0.8309, 0.8615, 0.8595, 0.8456, 0.8818]],
|
|
176
|
+
['C', [0.8227, 0.9139, 0.7894, 0.9376, 0.751, 0.9489]],
|
|
177
|
+
['C', [0.7245, 0.9568, 0.6939, 0.9563, 0.6328, 0.9554]],
|
|
178
|
+
['L', [0.5, 0.9534]],
|
|
179
|
+
['L', [0.3672, 0.9554]],
|
|
180
|
+
['C', [0.3061, 0.9563, 0.2755, 0.9568, 0.249, 0.9489]],
|
|
181
|
+
['C', [0.2106, 0.9376, 0.1773, 0.9139, 0.1544, 0.8818]],
|
|
182
|
+
['C', [0.1385, 0.8595, 0.1295, 0.8309, 0.1113, 0.7738]],
|
|
183
|
+
['L', [0.0727, 0.6519]],
|
|
184
|
+
['L', [0.0308, 0.533]],
|
|
185
|
+
['C', [0.0107, 0.4759, 0.0006, 0.4474, 0, 0.4201]],
|
|
186
|
+
['C', [-0.0008, 0.3806, 0.012, 0.3419, 0.0365, 0.3105]],
|
|
187
|
+
['C', [0.0534, 0.2888, 0.0787, 0.2715, 0.1293, 0.237]],
|
|
188
|
+
['L', [0.2359, 0.1641]],
|
|
189
|
+
['L', [0.3426, 0.0864]],
|
|
190
|
+
['Z', []],
|
|
191
|
+
],
|
|
192
|
+
rotateScaleFactor: 34 / 38,
|
|
193
|
+
};
|
|
194
|
+
|
|
195
|
+
export const cookie9Params: ShapeParameters = {
|
|
196
|
+
path: [
|
|
197
|
+
['M', [0.3914, 0.0472]],
|
|
198
|
+
['C', [0.3968, 0.0428, 0.3995, 0.0406, 0.402, 0.0387]],
|
|
199
|
+
['C', [0.46, -0.0051, 0.54, -0.0051, 0.598, 0.0387]],
|
|
200
|
+
['C', [0.6005, 0.0406, 0.6032, 0.0428, 0.6086, 0.0472]],
|
|
201
|
+
['C', [0.611, 0.0491, 0.6122, 0.0501, 0.6134, 0.051]],
|
|
202
|
+
['C', [0.6406, 0.0725, 0.6741, 0.0846, 0.7088, 0.0857]],
|
|
203
|
+
['C', [0.7103, 0.0858, 0.7119, 0.0858, 0.715, 0.0858]],
|
|
204
|
+
['C', [0.7219, 0.0859, 0.7254, 0.0859, 0.7285, 0.0861]],
|
|
205
|
+
['C', [0.8011, 0.0898, 0.8625, 0.1411, 0.8787, 0.2118]],
|
|
206
|
+
['C', [0.8794, 0.2148, 0.88, 0.2182, 0.8813, 0.2251]],
|
|
207
|
+
['C', [0.8819, 0.2281, 0.8822, 0.2296, 0.8825, 0.2311]],
|
|
208
|
+
['C', [0.8896, 0.265, 0.9074, 0.2958, 0.9333, 0.3189]],
|
|
209
|
+
['C', [0.9344, 0.3199, 0.9356, 0.3209, 0.9379, 0.3229]],
|
|
210
|
+
['C', [0.9432, 0.3274, 0.9458, 0.3297, 0.9481, 0.3318]],
|
|
211
|
+
['C', [1.0014, 0.3812, 1.0153, 0.4598, 0.9821, 0.5244]],
|
|
212
|
+
['C', [0.9807, 0.5271, 0.979, 0.5302, 0.9756, 0.5362]],
|
|
213
|
+
['C', [0.9741, 0.5389, 0.9733, 0.5403, 0.9726, 0.5416]],
|
|
214
|
+
['C', [0.9562, 0.5722, 0.95, 0.6071, 0.955, 0.6414]],
|
|
215
|
+
['C', [0.9552, 0.6429, 0.9555, 0.6445, 0.956, 0.6475]],
|
|
216
|
+
['C', [0.9571, 0.6544, 0.9576, 0.6578, 0.958, 0.6609]],
|
|
217
|
+
['C', [0.967, 0.7328, 0.927, 0.802, 0.86, 0.8302]],
|
|
218
|
+
['C', [0.8572, 0.8314, 0.8539, 0.8327, 0.8474, 0.8351]],
|
|
219
|
+
['C', [0.8445, 0.8362, 0.843, 0.8368, 0.8416, 0.8373]],
|
|
220
|
+
['C', [0.8094, 0.8502, 0.7821, 0.873, 0.7638, 0.9025]],
|
|
221
|
+
['C', [0.763, 0.9038, 0.7622, 0.9051, 0.7606, 0.9078]],
|
|
222
|
+
['C', [0.7571, 0.9137, 0.7553, 0.9167, 0.7536, 0.9193]],
|
|
223
|
+
['C', [0.7142, 0.9802, 0.6389, 1.0075, 0.5694, 0.9862]],
|
|
224
|
+
['C', [0.5665, 0.9853, 0.5632, 0.9841, 0.5566, 0.9818]],
|
|
225
|
+
['C', [0.5537, 0.9808, 0.5522, 0.9803, 0.5508, 0.9798]],
|
|
226
|
+
['C', [0.5178, 0.969, 0.4822, 0.969, 0.4492, 0.9798]],
|
|
227
|
+
['C', [0.4478, 0.9803, 0.4463, 0.9808, 0.4434, 0.9818]],
|
|
228
|
+
['C', [0.4368, 0.9841, 0.4335, 0.9853, 0.4306, 0.9862]],
|
|
229
|
+
['C', [0.3611, 1.0075, 0.2858, 0.9802, 0.2464, 0.9193]],
|
|
230
|
+
['C', [0.2447, 0.9167, 0.2429, 0.9137, 0.2394, 0.9078]],
|
|
231
|
+
['C', [0.2378, 0.9051, 0.237, 0.9038, 0.2362, 0.9025]],
|
|
232
|
+
['C', [0.2179, 0.873, 0.1906, 0.8502, 0.1584, 0.8373]],
|
|
233
|
+
['C', [0.157, 0.8368, 0.1555, 0.8362, 0.1526, 0.8351]],
|
|
234
|
+
['C', [0.1461, 0.8327, 0.1428, 0.8314, 0.14, 0.8302]],
|
|
235
|
+
['C', [0.073, 0.802, 0.033, 0.7328, 0.042, 0.6609]],
|
|
236
|
+
['C', [0.0424, 0.6578, 0.0429, 0.6544, 0.044, 0.6475]],
|
|
237
|
+
['C', [0.0445, 0.6445, 0.0448, 0.6429, 0.045, 0.6414]],
|
|
238
|
+
['C', [0.05, 0.6071, 0.0438, 0.5722, 0.0274, 0.5416]],
|
|
239
|
+
['C', [0.0267, 0.5403, 0.0259, 0.5389, 0.0244, 0.5362]],
|
|
240
|
+
['C', [0.021, 0.5302, 0.0193, 0.5271, 0.0179, 0.5244]],
|
|
241
|
+
['C', [-0.0153, 0.4598, -0.0014, 0.3812, 0.0519, 0.3318]],
|
|
242
|
+
['C', [0.0542, 0.3297, 0.0568, 0.3274, 0.0621, 0.3229]],
|
|
243
|
+
['C', [0.0644, 0.3209, 0.0656, 0.3199, 0.0667, 0.3189]],
|
|
244
|
+
['C', [0.0926, 0.2958, 0.1104, 0.265, 0.1175, 0.2311]],
|
|
245
|
+
['C', [0.1178, 0.2296, 0.1181, 0.2281, 0.1187, 0.2251]],
|
|
246
|
+
['C', [0.12, 0.2182, 0.1206, 0.2148, 0.1213, 0.2118]],
|
|
247
|
+
['C', [0.1375, 0.1411, 0.1989, 0.0898, 0.2715, 0.0861]],
|
|
248
|
+
['C', [0.2746, 0.0859, 0.2781, 0.0859, 0.285, 0.0858]],
|
|
249
|
+
['C', [0.2881, 0.0858, 0.2897, 0.0858, 0.2912, 0.0857]],
|
|
250
|
+
['C', [0.3259, 0.0846, 0.3594, 0.0725, 0.3866, 0.051]],
|
|
251
|
+
['C', [0.3878, 0.0501, 0.389, 0.0491, 0.3914, 0.0472]],
|
|
252
|
+
['Z', []],
|
|
253
|
+
],
|
|
254
|
+
rotateScaleFactor: 34 / 38,
|
|
255
|
+
};
|
|
256
|
+
|
|
257
|
+
export const softBurstParams: ShapeParameters = {
|
|
258
|
+
path: [
|
|
259
|
+
['M', [0.4549, 0.0247]],
|
|
260
|
+
['C', [0.4757, -0.0082, 0.5243, -0.0082, 0.545, 0.0247]],
|
|
261
|
+
['L', [0.5947, 0.1036]],
|
|
262
|
+
['C', [0.6084, 0.1253, 0.6359, 0.1341, 0.6598, 0.1245]],
|
|
263
|
+
['L', [0.7471, 0.0894]],
|
|
264
|
+
['C', [0.7835, 0.0747, 0.8229, 0.1029, 0.82, 0.1416]],
|
|
265
|
+
['L', [0.8131, 0.2342]],
|
|
266
|
+
['C', [0.8112, 0.2596, 0.8282, 0.2827, 0.8533, 0.2887]],
|
|
267
|
+
['L', [0.9449, 0.3109]],
|
|
268
|
+
['C', [0.9831, 0.3202, 0.9981, 0.3657, 0.9727, 0.3953]],
|
|
269
|
+
['L', [0.9119, 0.4663]],
|
|
270
|
+
['C', [0.8952, 0.4858, 0.8952, 0.5142, 0.9119, 0.5337]],
|
|
271
|
+
['L', [0.9727, 0.6047]],
|
|
272
|
+
['C', [0.9981, 0.6343, 0.9831, 0.6798, 0.9449, 0.6891]],
|
|
273
|
+
['L', [0.8533, 0.7113]],
|
|
274
|
+
['C', [0.8282, 0.7173, 0.8112, 0.7404, 0.8131, 0.7658]],
|
|
275
|
+
['L', [0.82, 0.8584]],
|
|
276
|
+
['C', [0.8229, 0.8971, 0.7835, 0.9252, 0.7471, 0.9106]],
|
|
277
|
+
['L', [0.6598, 0.8755]],
|
|
278
|
+
['C', [0.6359, 0.8659, 0.6084, 0.8747, 0.5947, 0.8964]],
|
|
279
|
+
['L', [0.545, 0.9753]],
|
|
280
|
+
['C', [0.5243, 1.0082, 0.4757, 1.0082, 0.4549, 0.9753]],
|
|
281
|
+
['L', [0.4053, 0.8964]],
|
|
282
|
+
['C', [0.3916, 0.8747, 0.3641, 0.8659, 0.3402, 0.8755]],
|
|
283
|
+
['L', [0.2529, 0.9106]],
|
|
284
|
+
['C', [0.2165, 0.9252, 0.1771, 0.8971, 0.18, 0.8584]],
|
|
285
|
+
['L', [0.1869, 0.7658]],
|
|
286
|
+
['C', [0.1888, 0.7404, 0.1718, 0.7173, 0.1467, 0.7113]],
|
|
287
|
+
['L', [0.0551, 0.6891]],
|
|
288
|
+
['C', [0.0169, 0.6798, 0.0019, 0.6343, 0.0273, 0.6047]],
|
|
289
|
+
['L', [0.0881, 0.5337]],
|
|
290
|
+
['C', [0.1048, 0.5142, 0.1048, 0.4858, 0.0881, 0.4663]],
|
|
291
|
+
['L', [0.0273, 0.3953]],
|
|
292
|
+
['C', [0.0019, 0.3657, 0.0169, 0.3202, 0.0551, 0.3109]],
|
|
293
|
+
['L', [0.1467, 0.2887]],
|
|
294
|
+
['C', [0.1718, 0.2827, 0.1888, 0.2596, 0.1869, 0.2342]],
|
|
295
|
+
['L', [0.18, 0.1416]],
|
|
296
|
+
['C', [0.1771, 0.1029, 0.2165, 0.0747, 0.2529, 0.0894]],
|
|
297
|
+
['L', [0.3402, 0.1245]],
|
|
298
|
+
['C', [0.3641, 0.1341, 0.3916, 0.1253, 0.4053, 0.1036]],
|
|
299
|
+
['L', [0.4549, 0.0247]],
|
|
300
|
+
['Z', []],
|
|
301
|
+
],
|
|
302
|
+
rotateScaleFactor: 34 / 38,
|
|
303
|
+
};
|
|
304
|
+
|
|
305
|
+
/**
|
|
306
|
+
* Список всех форм
|
|
307
|
+
*/
|
|
308
|
+
export const shapeList = [
|
|
309
|
+
ovalParams,
|
|
310
|
+
pillParams,
|
|
311
|
+
pentagonParams,
|
|
312
|
+
sunnyParams,
|
|
313
|
+
cookie4Params,
|
|
314
|
+
cookie9Params,
|
|
315
|
+
softBurstParams,
|
|
316
|
+
] as const;
|
|
317
|
+
|
|
318
|
+
/**
|
|
319
|
+
* Название форм
|
|
320
|
+
*/
|
|
321
|
+
export const shapeNameMap: ReadonlyWeakMap<ShapeParameters, string> = new WeakMap([
|
|
322
|
+
[ovalParams, 'Oval'],
|
|
323
|
+
[pillParams, 'Pill'],
|
|
324
|
+
[pentagonParams, 'Pentagon'],
|
|
325
|
+
[sunnyParams, 'Sunny'],
|
|
326
|
+
[cookie4Params, '4-sided cookie'],
|
|
327
|
+
[cookie9Params, '9-sided cookie'],
|
|
328
|
+
[softBurstParams, 'Soft burst'],
|
|
329
|
+
]);
|
package/src/lib/math.ts
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Длина гипотенузы
|
|
3
|
+
*/
|
|
4
|
+
function hypotenuse(a: number, b: number): number {
|
|
5
|
+
return Math.sqrt(a * a + b * b);
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Евклидово расстояние между двумя точками
|
|
10
|
+
*
|
|
11
|
+
* ```ts
|
|
12
|
+
* import { distancePoint } from './math';
|
|
13
|
+
* import * as assert from 'node:assert/strict';
|
|
14
|
+
*
|
|
15
|
+
* assert.equal(distance(1, 1, 4, 5), 5)
|
|
16
|
+
* ```
|
|
17
|
+
*/
|
|
18
|
+
export function distance(x1: number, y1: number, x2: number, y2: number): number {
|
|
19
|
+
return hypotenuse(x1 - x2, y1 - y2);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Евклидово расстояние между двумя точками
|
|
24
|
+
*
|
|
25
|
+
* ```ts
|
|
26
|
+
* import { distancePoint } from './math';
|
|
27
|
+
* import * as assert from 'node:assert/strict';
|
|
28
|
+
*
|
|
29
|
+
* assert.equal(distancePoint([1, 1], [4, 5]), 5)
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export function distancePoint(
|
|
33
|
+
[x1, y1]: readonly [number, number],
|
|
34
|
+
[x2, y2]: readonly [number, number],
|
|
35
|
+
): number {
|
|
36
|
+
return distance(x1, y1, x2, y2);
|
|
37
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { type DeepReadonly } from '../../../types';
|
|
2
|
+
import * as array from '../../array';
|
|
3
|
+
import { cubicBezierTwoDimensional } from '../../curve';
|
|
4
|
+
import { distancePoint } from '../../math';
|
|
5
|
+
import type { SVGPathSupport } from './path';
|
|
6
|
+
import { type Point, type Points } from './point';
|
|
7
|
+
|
|
8
|
+
export interface MaxSegmentLengthOptions {
|
|
9
|
+
maxSegmentLength?: number;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Аппроксимирует кривую Безье в точки
|
|
14
|
+
*/
|
|
15
|
+
function approximateCurves(
|
|
16
|
+
prevPoint: [number, number],
|
|
17
|
+
args: [number, number, number, number, number, number],
|
|
18
|
+
{ maxSegmentLength }: Required<MaxSegmentLengthOptions>,
|
|
19
|
+
): Points {
|
|
20
|
+
const distancePoints = distancePoint([args[4], args[5]], prevPoint);
|
|
21
|
+
const acc: Points = new Array(Math.ceil(Math.max(2, distancePoints / maxSegmentLength)));
|
|
22
|
+
|
|
23
|
+
for (let index = 0; index < acc.length; index++) {
|
|
24
|
+
const progress = Math.min(1, (maxSegmentLength / distancePoints) * index);
|
|
25
|
+
|
|
26
|
+
acc[index] = cubicBezierTwoDimensional(
|
|
27
|
+
prevPoint[0],
|
|
28
|
+
prevPoint[1],
|
|
29
|
+
args[0],
|
|
30
|
+
args[1],
|
|
31
|
+
args[2],
|
|
32
|
+
args[3],
|
|
33
|
+
args[4],
|
|
34
|
+
args[5],
|
|
35
|
+
progress,
|
|
36
|
+
);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return acc;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Аппроксимирует svg путь в точки
|
|
44
|
+
*
|
|
45
|
+
* ```ts
|
|
46
|
+
* import * as approximate from './approximate';
|
|
47
|
+
* import * as assert from 'node:assert/strict';
|
|
48
|
+
*
|
|
49
|
+
* assert.equal(
|
|
50
|
+
* approximate.approximateRing([['M', [20, 40]], ['L', [40, 60]]]),
|
|
51
|
+
* [[20, 40], [40, 60]],
|
|
52
|
+
* );
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
export function approximateRing(
|
|
56
|
+
path: DeepReadonly<SVGPathSupport>,
|
|
57
|
+
{ maxSegmentLength = 1 }: MaxSegmentLengthOptions = {},
|
|
58
|
+
): Points {
|
|
59
|
+
const prevPoint: Point = [0, 0];
|
|
60
|
+
|
|
61
|
+
return path.reduce<Points>((acc, [command, args]) => {
|
|
62
|
+
switch (command) {
|
|
63
|
+
case 'M':
|
|
64
|
+
case 'L':
|
|
65
|
+
acc.push(array.copy(args));
|
|
66
|
+
prevPoint[0] = args[0];
|
|
67
|
+
prevPoint[1] = args[1];
|
|
68
|
+
break;
|
|
69
|
+
case 'C':
|
|
70
|
+
acc.push(...approximateCurves(prevPoint, array.copy(args), { maxSegmentLength }));
|
|
71
|
+
prevPoint[0] = args[4];
|
|
72
|
+
prevPoint[1] = args[5];
|
|
73
|
+
|
|
74
|
+
break;
|
|
75
|
+
case 'Z':
|
|
76
|
+
break;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return acc;
|
|
80
|
+
}, []);
|
|
81
|
+
}
|