@vkontakte/vkui 6.0.1-beta.0 → 6.0.1
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/cjs/components/AppRoot/ScrollContext.js +2 -2
- package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
- package/dist/cjs/components/AspectRatio/AspectRatio.d.ts +0 -1
- package/dist/cjs/components/AspectRatio/AspectRatio.d.ts.map +1 -1
- package/dist/cjs/components/ChipsInputBase/types.d.ts +1 -0
- package/dist/cjs/components/ChipsInputBase/types.d.ts.map +1 -1
- package/dist/cjs/components/ChipsInputBase/types.js.map +1 -1
- package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
- package/dist/cjs/components/ChipsSelect/ChipsSelect.js +33 -3
- package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
- package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/cjs/components/FormField/FormField.d.ts +0 -6
- package/dist/cjs/components/FormField/FormField.d.ts.map +1 -1
- package/dist/cjs/components/FormField/FormField.js.map +1 -1
- package/dist/cjs/components/Group/Group.d.ts.map +1 -1
- package/dist/cjs/components/Group/Group.js +1 -3
- package/dist/cjs/components/Group/Group.js.map +1 -1
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts.map +1 -1
- package/dist/cjs/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/cjs/components/ImageBase/validators.d.ts +0 -1
- package/dist/cjs/components/ImageBase/validators.d.ts.map +1 -1
- package/dist/cjs/components/ModalRoot/ModalRoot.js +20 -3
- package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +1 -1
- package/dist/cjs/components/NativeSelect/NativeSelect.d.ts.map +1 -1
- package/dist/cjs/components/NativeSelect/NativeSelect.js +7 -16
- package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/cjs/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
- package/dist/cjs/components/PullToRefresh/PullToRefresh.js +53 -61
- package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cjs/components/Radio/Radio.d.ts +2 -3
- package/dist/cjs/components/Radio/Radio.d.ts.map +1 -1
- package/dist/cjs/components/Radio/Radio.js +3 -13
- package/dist/cjs/components/Radio/Radio.js.map +1 -1
- package/dist/cjs/components/Search/Search.d.ts +1 -1
- package/dist/cjs/components/Search/Search.d.ts.map +1 -1
- package/dist/cjs/components/Search/Search.js +8 -14
- package/dist/cjs/components/Search/Search.js.map +1 -1
- package/dist/cjs/components/TabsItem/TabsItem.d.ts +2 -2
- package/dist/cjs/components/TabsItem/TabsItem.d.ts.map +1 -1
- package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cjs/components/Textarea/Textarea.d.ts +3 -3
- package/dist/cjs/components/Textarea/Textarea.d.ts.map +1 -1
- package/dist/cjs/components/Textarea/Textarea.js +9 -21
- package/dist/cjs/components/Textarea/Textarea.js.map +1 -1
- package/dist/cjs/components/WriteBar/WriteBar.d.ts +1 -1
- package/dist/cjs/components/WriteBar/WriteBar.d.ts.map +1 -1
- package/dist/cjs/components/WriteBar/WriteBar.js +5 -10
- package/dist/cjs/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/cjs/index.d.ts +0 -3
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +0 -4
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/floating/adapters.d.ts.map +1 -1
- package/dist/cjs/lib/floating/adapters.js +12 -23
- package/dist/cjs/lib/floating/adapters.js.map +1 -1
- package/dist/cjs/lib/floating/customResizeObserver.d.ts +15 -0
- package/dist/cjs/lib/floating/customResizeObserver.d.ts.map +1 -0
- package/dist/cjs/lib/floating/customResizeObserver.js +86 -0
- package/dist/cjs/lib/floating/customResizeObserver.js.map +1 -0
- package/dist/components/AppRoot/ScrollContext.js +2 -2
- package/dist/components/AppRoot/ScrollContext.js.map +1 -1
- package/dist/components/AspectRatio/AspectRatio.d.ts +0 -1
- package/dist/components/AspectRatio/AspectRatio.d.ts.map +1 -1
- package/dist/components/ChipsInputBase/types.d.ts +1 -0
- 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.map +1 -1
- package/dist/components/ChipsSelect/ChipsSelect.js +33 -3
- package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
- package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/components/FormField/FormField.d.ts +0 -6
- package/dist/components/FormField/FormField.d.ts.map +1 -1
- package/dist/components/FormField/FormField.js.map +1 -1
- package/dist/components/Group/Group.d.ts.map +1 -1
- package/dist/components/Group/Group.js +1 -3
- package/dist/components/Group/Group.js.map +1 -1
- package/dist/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- 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/validators.d.ts +0 -1
- package/dist/components/ImageBase/validators.d.ts.map +1 -1
- package/dist/components/ModalRoot/ModalRoot.js +20 -3
- package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.d.ts +1 -1
- package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
- package/dist/components/NativeSelect/NativeSelect.js +7 -16
- package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
- package/dist/components/PullToRefresh/PullToRefresh.js +53 -61
- package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/components/Radio/Radio.d.ts +2 -3
- package/dist/components/Radio/Radio.d.ts.map +1 -1
- package/dist/components/Radio/Radio.js +3 -13
- package/dist/components/Radio/Radio.js.map +1 -1
- package/dist/components/Search/Search.d.ts +1 -1
- package/dist/components/Search/Search.d.ts.map +1 -1
- package/dist/components/Search/Search.js +8 -14
- package/dist/components/Search/Search.js.map +1 -1
- package/dist/components/TabsItem/TabsItem.d.ts +2 -2
- package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
- package/dist/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/components/Textarea/Textarea.d.ts +3 -3
- package/dist/components/Textarea/Textarea.d.ts.map +1 -1
- package/dist/components/Textarea/Textarea.js +9 -21
- package/dist/components/Textarea/Textarea.js.map +1 -1
- package/dist/components/WriteBar/WriteBar.d.ts +1 -1
- package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
- package/dist/components/WriteBar/WriteBar.js +5 -10
- package/dist/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/components.css +5 -6
- package/dist/components.css.map +1 -1
- package/dist/components.js.tmp +1337 -1322
- package/dist/cssm/components/AppRoot/ScrollContext.js +2 -2
- package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
- package/dist/cssm/components/AspectRatio/AspectRatio.d.ts +0 -1
- package/dist/cssm/components/AspectRatio/AspectRatio.d.ts.map +1 -1
- package/dist/cssm/components/ChipsInputBase/types.d.ts +1 -0
- package/dist/cssm/components/ChipsInputBase/types.d.ts.map +1 -1
- package/dist/cssm/components/ChipsInputBase/types.js.map +1 -1
- package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts.map +1 -1
- package/dist/cssm/components/ChipsSelect/ChipsSelect.js +33 -3
- package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
- package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +2 -2
- package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
- package/dist/cssm/components/FormField/FormField.d.ts +0 -6
- package/dist/cssm/components/FormField/FormField.d.ts.map +1 -1
- package/dist/cssm/components/FormField/FormField.js.map +1 -1
- package/dist/cssm/components/FormField/FormField.module.css +2 -4
- package/dist/cssm/components/Group/Group.d.ts.map +1 -1
- package/dist/cssm/components/Group/Group.js +1 -3
- package/dist/cssm/components/Group/Group.js.map +1 -1
- package/dist/cssm/components/Group/Group.module.css +1 -10
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts +3 -2
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.d.ts.map +1 -1
- package/dist/cssm/components/ImageBase/ImageBaseBadge/ImageBaseBadge.js.map +1 -1
- package/dist/cssm/components/ImageBase/validators.d.ts +0 -1
- package/dist/cssm/components/ImageBase/validators.d.ts.map +1 -1
- package/dist/cssm/components/ModalRoot/ModalRoot.js +20 -3
- package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
- package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +1 -1
- package/dist/cssm/components/NativeSelect/NativeSelect.d.ts.map +1 -1
- package/dist/cssm/components/NativeSelect/NativeSelect.js +6 -13
- package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js +53 -61
- package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
- package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +5 -0
- package/dist/cssm/components/Radio/Radio.d.ts +2 -3
- package/dist/cssm/components/Radio/Radio.d.ts.map +1 -1
- package/dist/cssm/components/Radio/Radio.js +1 -6
- package/dist/cssm/components/Radio/Radio.js.map +1 -1
- package/dist/cssm/components/Search/Search.d.ts +1 -1
- package/dist/cssm/components/Search/Search.d.ts.map +1 -1
- package/dist/cssm/components/Search/Search.js +8 -12
- package/dist/cssm/components/Search/Search.js.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.d.ts +2 -2
- package/dist/cssm/components/TabsItem/TabsItem.d.ts.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
- package/dist/cssm/components/TabsItem/TabsItem.module.css +0 -1
- package/dist/cssm/components/Textarea/Textarea.d.ts +3 -3
- package/dist/cssm/components/Textarea/Textarea.d.ts.map +1 -1
- package/dist/cssm/components/Textarea/Textarea.js +8 -16
- package/dist/cssm/components/Textarea/Textarea.js.map +1 -1
- package/dist/cssm/components/Textarea/Textarea.module.css +0 -8
- package/dist/cssm/components/WriteBar/WriteBar.d.ts +1 -1
- package/dist/cssm/components/WriteBar/WriteBar.d.ts.map +1 -1
- package/dist/cssm/components/WriteBar/WriteBar.js +4 -10
- package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
- package/dist/cssm/index.d.ts +0 -3
- package/dist/cssm/index.d.ts.map +1 -1
- package/dist/cssm/index.js +3 -2
- package/dist/cssm/index.js.map +1 -1
- package/dist/cssm/lib/floating/adapters.d.ts.map +1 -1
- package/dist/cssm/lib/floating/adapters.js +12 -23
- package/dist/cssm/lib/floating/adapters.js.map +1 -1
- package/dist/cssm/lib/floating/customResizeObserver.d.ts +15 -0
- package/dist/cssm/lib/floating/customResizeObserver.d.ts.map +1 -0
- package/dist/cssm/lib/floating/customResizeObserver.js +89 -0
- package/dist/cssm/lib/floating/customResizeObserver.js.map +1 -0
- package/dist/cssm/styles/common.css +1 -0
- package/dist/cssm/styles/themes.css +0 -9
- package/dist/index.d.ts +0 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -2
- package/dist/index.js.map +1 -1
- package/dist/lib/floating/adapters.d.ts.map +1 -1
- package/dist/lib/floating/adapters.js +12 -23
- package/dist/lib/floating/adapters.js.map +1 -1
- package/dist/lib/floating/customResizeObserver.d.ts +15 -0
- package/dist/lib/floating/customResizeObserver.d.ts.map +1 -0
- package/dist/lib/floating/customResizeObserver.js +90 -0
- package/dist/lib/floating/customResizeObserver.js.map +1 -0
- package/dist/vkui.css +6 -7
- package/dist/vkui.css.map +1 -1
- package/dist/vkui.js.tmp +1337 -1322
- package/package.json +5 -5
- package/src/components/Accordion/Accordion.e2e-playground.tsx +39 -0
- package/src/components/Accordion/Accordion.e2e.tsx +8 -0
- package/src/components/Accordion/Accordion.stories.tsx +32 -0
- package/src/components/Accordion/Accordion.test.tsx +29 -0
- package/src/components/Accordion/Readme.md +110 -0
- package/src/components/Accordion/__image_snapshots__/accordion-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-android-chromium-light-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Accordion/__image_snapshots__/accordion-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ActionSheet/ActionSheet.e2e-playground.tsx +97 -0
- package/src/components/ActionSheet/ActionSheet.e2e.tsx +53 -0
- package/src/components/ActionSheet/ActionSheet.stories.tsx +124 -0
- package/src/components/ActionSheet/ActionSheet.test.tsx +179 -0
- package/src/components/ActionSheet/Readme.md +226 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-desktop-sizey-regular-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-mobile-sizey-regular-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-mobile-sizey-regular-android-chromium-light-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-mobile-sizey-regular-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ActionSheet/__image_snapshots__/actionsheet-viewwidth-mobile-sizey-regular-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ActionSheetItem/ActionSheetItem.stories.tsx +71 -0
- package/src/components/ActionSheetItem/ActionSheetItem.test.tsx +31 -0
- package/src/components/ActionSheetItem/Readme.md +1 -0
- package/src/components/AdaptiveIconRenderer/AdaptiveIconRenderer.stories.tsx +21 -0
- package/src/components/AdaptiveIconRenderer/Readme.md +20 -0
- package/src/components/AdaptivityProvider/AdaptivityProvider.stories.tsx +34 -0
- package/src/components/AdaptivityProvider/AdaptivityProvider.test.tsx +358 -0
- package/src/components/AdaptivityProvider/Readme.md +3 -0
- package/src/components/Alert/Alert.e2e-playground.tsx +96 -0
- package/src/components/Alert/Alert.e2e.tsx +42 -0
- package/src/components/Alert/Alert.stories.tsx +48 -0
- package/src/components/Alert/Alert.test.tsx +114 -0
- package/src/components/Alert/Readme.md +168 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-desktop-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-long-word-android-chromium-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-long-word-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-long-word-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-long-word-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-long-word-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-mobile-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-mobile-android-chromium-light-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-mobile-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Alert/__image_snapshots__/alert-mobile-ios-webkit-light-1-snap.png +3 -0
- package/src/components/AppRoot/AppRoot.test.tsx +381 -0
- package/src/components/AppRoot/AppRootPortal.test.tsx +77 -0
- package/src/components/AppRoot/Readme.md +1 -0
- package/src/components/AppRoot/ScrollContext.tsx +2 -2
- package/src/components/AppearanceProvider/AppearanceProvider.stories.tsx +28 -0
- package/src/components/AspectRatio/AspectRatio.e2e-playground.tsx +20 -0
- package/src/components/AspectRatio/AspectRatio.e2e.tsx +12 -0
- package/src/components/AspectRatio/AspectRatio.stories.tsx +69 -0
- package/src/components/AspectRatio/AspectRatio.test.tsx +6 -0
- package/src/components/AspectRatio/Readme.md +44 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-android-chromium-dark-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-android-chromium-light-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-ios-webkit-light-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/AspectRatio/__image_snapshots__/aspectratio-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Avatar/Avatar.e2e-playground.tsx +91 -0
- package/src/components/Avatar/Avatar.e2e.tsx +8 -0
- package/src/components/Avatar/Avatar.stories.tsx +107 -0
- package/src/components/Avatar/Avatar.test.tsx +92 -0
- package/src/components/Avatar/Readme.md +262 -0
- package/src/components/Avatar/__image_snapshots__/avatar-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-android-chromium-light-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Avatar/__image_snapshots__/avatar-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Badge/Badge.stories.tsx +31 -0
- package/src/components/Badge/Badge.test.tsx +6 -0
- package/src/components/Badge/Readme.md +70 -0
- package/src/components/Banner/Banner.e2e-playground.tsx +81 -0
- package/src/components/Banner/Banner.e2e.tsx +8 -0
- package/src/components/Banner/Banner.stories.tsx +47 -0
- package/src/components/Banner/Banner.test.tsx +6 -0
- package/src/components/Banner/Readme.md +231 -0
- package/src/components/Banner/__image_snapshots__/banner-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-android-chromium-light-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Banner/__image_snapshots__/banner-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Button/Button.e2e-playground.tsx +132 -0
- package/src/components/Button/Button.e2e.tsx +31 -0
- package/src/components/Button/Button.stories.tsx +59 -0
- package/src/components/Button/Button.test.tsx +45 -0
- package/src/components/Button/Readme.md +158 -0
- package/src/components/Button/__image_snapshots__/button-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-android-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-android-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-counter-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-paddings-android-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-paddings-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-paddings-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-paddings-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-paddings-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Button/__image_snapshots__/button-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/ButtonGroup.e2e-playground.tsx +89 -0
- package/src/components/ButtonGroup/ButtonGroup.e2e.tsx +28 -0
- package/src/components/ButtonGroup/ButtonGroup.stories.tsx +101 -0
- package/src/components/ButtonGroup/ButtonGroup.test.tsx +6 -0
- package/src/components/ButtonGroup/Readme.md +371 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-android-chromium-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-align-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-android-chromium-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ButtonGroup/__image_snapshots__/buttongroup-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Calendar/Calendar.e2e-playground.tsx +60 -0
- package/src/components/Calendar/Calendar.e2e.tsx +8 -0
- package/src/components/Calendar/Calendar.stories.tsx +51 -0
- package/src/components/Calendar/Calendar.test.tsx +54 -0
- package/src/components/Calendar/Readme.md +121 -0
- package/src/components/Calendar/__image_snapshots__/calendar-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-android-chromium-light-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Calendar/__image_snapshots__/calendar-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CalendarDay/CalendarDay.test.tsx +27 -0
- package/src/components/CalendarHeader/CalendarHeader.test.tsx +51 -0
- package/src/components/CalendarRange/CalendarRange.e2e-playground.tsx +42 -0
- package/src/components/CalendarRange/CalendarRange.e2e.tsx +12 -0
- package/src/components/CalendarRange/CalendarRange.stories.tsx +66 -0
- package/src/components/CalendarRange/CalendarRange.test.tsx +21 -0
- package/src/components/CalendarRange/Readme.md +77 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-android-chromium-dark-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-android-chromium-light-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/CalendarRange/__image_snapshots__/calendarrange-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Card/Card.e2e-playground.tsx +26 -0
- package/src/components/Card/Card.e2e.tsx +8 -0
- package/src/components/Card/Card.stories.tsx +22 -0
- package/src/components/Card/Card.test.tsx +6 -0
- package/src/components/Card/Readme.md +40 -0
- package/src/components/Card/__image_snapshots__/card-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-android-chromium-light-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Card/__image_snapshots__/card-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CardGrid/CardGrid.stories.tsx +54 -0
- package/src/components/CardGrid/CardGrid.test.tsx +6 -0
- package/src/components/CardGrid/Readme.md +46 -0
- package/src/components/CardScroll/CardScroll.e2e-playground.tsx +31 -0
- package/src/components/CardScroll/CardScroll.e2e.tsx +12 -0
- package/src/components/CardScroll/CardScroll.stories.tsx +54 -0
- package/src/components/CardScroll/CardScroll.test.tsx +6 -0
- package/src/components/CardScroll/Readme.md +62 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-android-chromium-dark-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-android-chromium-light-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/CardScroll/__image_snapshots__/cardscroll-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Cell/Cell.e2e-playground.tsx +37 -0
- package/src/components/Cell/Cell.e2e.tsx +8 -0
- package/src/components/Cell/Cell.stories.tsx +54 -0
- package/src/components/Cell/Cell.test.tsx +136 -0
- package/src/components/Cell/CellCheckbox/CellCheckbox.stories.tsx +39 -0
- package/src/components/Cell/CellCheckbox/CellCheckbox.test.tsx +11 -0
- package/src/components/Cell/CellDragger/CellDragger.test.tsx +6 -0
- package/src/components/Cell/Readme.md +155 -0
- package/src/components/Cell/__image_snapshots__/cell-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-android-chromium-light-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Cell/__image_snapshots__/cell-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CellButton/CellButton.e2e-playground.tsx +45 -0
- package/src/components/CellButton/CellButton.e2e.tsx +12 -0
- package/src/components/CellButton/CellButton.stories.tsx +24 -0
- package/src/components/CellButton/CellButton.test.tsx +7 -0
- package/src/components/CellButton/Readme.md +58 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-android-chromium-dark-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-android-chromium-light-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/CellButton/__image_snapshots__/cellbutton-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/Checkbox.e2e-playground.tsx +78 -0
- package/src/components/Checkbox/Checkbox.e2e.tsx +38 -0
- package/src/components/Checkbox/Checkbox.stories.tsx +34 -0
- package/src/components/Checkbox/Checkbox.test.tsx +25 -0
- package/src/components/Checkbox/Readme.md +37 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-android-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-android-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-simple-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-android-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-sizes-and-description-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Checkbox/__image_snapshots__/checkbox-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ChipsInput/ChipsInput.e2e-playground.tsx +36 -0
- package/src/components/ChipsInput/ChipsInput.e2e.tsx +12 -0
- package/src/components/ChipsInput/ChipsInput.stories.tsx +24 -0
- package/src/components/ChipsInput/ChipsInput.test.tsx +6 -0
- package/src/components/ChipsInput/Readme.md +103 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-android-chromium-light-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ChipsInput/__image_snapshots__/chipsinput-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/Chip.e2e-playground.tsx +24 -0
- package/src/components/ChipsInputBase/Chip/Chip.e2e.tsx +8 -0
- package/src/components/ChipsInputBase/Chip/Chip.stories.tsx +42 -0
- package/src/components/ChipsInputBase/Chip/Chip.test.tsx +67 -0
- package/src/components/ChipsInputBase/Chip/Readme.md +70 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-android-chromium-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ChipsInputBase/Chip/__image_snapshots__/chip-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ChipsInputBase/ChipsInputBase.test.tsx +327 -0
- package/src/components/ChipsInputBase/types.ts +1 -0
- package/src/components/ChipsSelect/ChipsSelect.stories.tsx +43 -0
- package/src/components/ChipsSelect/ChipsSelect.test.tsx +445 -0
- package/src/components/ChipsSelect/ChipsSelect.tsx +47 -4
- package/src/components/ChipsSelect/Readme.md +132 -0
- package/src/components/Clickable/Clickable.stories.tsx +23 -0
- package/src/components/Clickable/Clickable.test.tsx +37 -0
- package/src/components/ConfigProvider/ConfigProvider.stories.tsx +31 -0
- package/src/components/ConfigProvider/ConfigProvider.test.tsx +116 -0
- package/src/components/ConfigProvider/Readme.md +7 -0
- package/src/components/ContentCard/ContentCard.e2e-playground.tsx +25 -0
- package/src/components/ContentCard/ContentCard.e2e.tsx +12 -0
- package/src/components/ContentCard/ContentCard.stories.tsx +29 -0
- package/src/components/ContentCard/ContentCard.test.tsx +67 -0
- package/src/components/ContentCard/Readme.md +72 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-android-chromium-light-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ContentCard/__image_snapshots__/contentcard-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Counter/Counter.e2e-playground.tsx +25 -0
- package/src/components/Counter/Counter.e2e.tsx +8 -0
- package/src/components/Counter/Counter.stories.tsx +27 -0
- package/src/components/Counter/Counter.test.tsx +14 -0
- package/src/components/Counter/Readme.md +148 -0
- package/src/components/Counter/__image_snapshots__/counter-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-android-chromium-light-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Counter/__image_snapshots__/counter-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CustomScrollView/CustomScrollView.test.tsx +6 -0
- package/src/components/CustomSelect/CustomSelect.e2e-playground.tsx +78 -0
- package/src/components/CustomSelect/CustomSelect.e2e.tsx +40 -0
- package/src/components/CustomSelect/CustomSelect.stories.tsx +21 -0
- package/src/components/CustomSelect/CustomSelect.test.tsx +1103 -0
- package/src/components/CustomSelect/Readme.md +360 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-android-chromium-dark-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-android-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-no-max-height-android-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-no-max-height-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-no-max-height-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-no-max-height-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-no-max-height-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/CustomSelect/__image_snapshots__/customselect-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/CustomSelectDropdown/CustomSelectDropdown.test.tsx +23 -0
- package/src/components/CustomSelectOption/CustomSelectOption.e2e-playground.tsx +42 -0
- package/src/components/CustomSelectOption/CustomSelectOption.e2e.tsx +16 -0
- package/src/components/CustomSelectOption/CustomSelectOption.stories.tsx +21 -0
- package/src/components/CustomSelectOption/CustomSelectOption.test.tsx +35 -0
- package/src/components/CustomSelectOption/CustomSelectOption.tsx +2 -2
- package/src/components/CustomSelectOption/Readme.md +47 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-android-chromium-dark-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-android-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-ios-webkit-light-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/CustomSelectOption/__image_snapshots__/customselectoption-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/DateInput/DateInput.e2e-playground.tsx +22 -0
- package/src/components/DateInput/DateInput.e2e.tsx +8 -0
- package/src/components/DateInput/DateInput.stories.tsx +27 -0
- package/src/components/DateInput/DateInput.test.tsx +10 -0
- package/src/components/DateInput/Readme.md +109 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-android-chromium-dark-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-android-chromium-light-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-ios-webkit-light-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/DateInput/__image_snapshots__/dateinput-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/DatePicker/DatePicker.e2e-playground.tsx +31 -0
- package/src/components/DatePicker/DatePicker.e2e.tsx +12 -0
- package/src/components/DatePicker/DatePicker.stories.tsx +23 -0
- package/src/components/DatePicker/DatePicker.test.tsx +159 -0
- package/src/components/DatePicker/Readme.md +40 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-android-chromium-dark-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-android-chromium-light-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-ios-webkit-light-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/DatePicker/__image_snapshots__/datepicker-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/DateRangeInput/DateRangeInput.e2e-playground.tsx +27 -0
- package/src/components/DateRangeInput/DateRangeInput.e2e.tsx +12 -0
- package/src/components/DateRangeInput/DateRangeInput.stories.tsx +66 -0
- package/src/components/DateRangeInput/DateRangeInput.test.tsx +10 -0
- package/src/components/DateRangeInput/Readme.md +92 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-android-chromium-dark-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-android-chromium-light-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-ios-webkit-light-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/DateRangeInput/__image_snapshots__/daterangeinput-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Div/Div.stories.tsx +26 -0
- package/src/components/Div/Div.test.tsx +6 -0
- package/src/components/Div/Readme.md +17 -0
- package/src/components/Epic/Epic.stories.tsx +219 -0
- package/src/components/Epic/Epic.test.tsx +13 -0
- package/src/components/Epic/Readme.md +195 -0
- package/src/components/File/File.stories.tsx +17 -0
- package/src/components/File/File.test.tsx +6 -0
- package/src/components/File/Readme.md +19 -0
- package/src/components/FixedLayout/FixedLayout.stories.tsx +130 -0
- package/src/components/FixedLayout/FixedLayout.test.tsx +6 -0
- package/src/components/FixedLayout/Readme.md +93 -0
- package/src/components/FocusTrap/FocusTrap.test.tsx +165 -0
- package/src/components/Footer/Footer.stories.tsx +53 -0
- package/src/components/Footer/Footer.test.tsx +6 -0
- package/src/components/Footer/Readme.md +23 -0
- package/src/components/FormField/FormField.module.css +2 -4
- package/src/components/FormField/FormField.stories.tsx +62 -0
- package/src/components/FormField/FormField.test.tsx +6 -0
- package/src/components/FormField/FormField.tsx +0 -6
- package/src/components/FormField/Readme.md +34 -0
- package/src/components/FormItem/FormItem.e2e-playground.tsx +64 -0
- package/src/components/FormItem/FormItem.e2e.tsx +8 -0
- package/src/components/FormItem/FormItem.stories.tsx +32 -0
- package/src/components/FormItem/FormItem.test.tsx +26 -0
- package/src/components/FormItem/Readme.md +215 -0
- package/src/components/FormItem/__image_snapshots__/formitem-android-chromium-dark-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-android-chromium-light-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-ios-webkit-light-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/FormItem/__image_snapshots__/formitem-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/FormLayoutGroup.e2e-playground.tsx +220 -0
- package/src/components/FormLayoutGroup/FormLayoutGroup.e2e.tsx +12 -0
- package/src/components/FormLayoutGroup/FormLayoutGroup.stories.tsx +36 -0
- package/src/components/FormLayoutGroup/FormLayoutGroup.test.tsx +6 -0
- package/src/components/FormLayoutGroup/Readme.md +79 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-android-chromium-dark-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-android-chromium-light-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-ios-webkit-light-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/FormLayoutGroup/__image_snapshots__/formlayoutgroup-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/FormStatus/FormStatus.stories.tsx +23 -0
- package/src/components/FormStatus/FormStatus.test.tsx +6 -0
- package/src/components/FormStatus/Readme.md +23 -0
- package/src/components/Gallery/Gallery.stories.tsx +24 -0
- package/src/components/Gallery/Gallery.test.tsx +48 -0
- package/src/components/Gallery/Readme.md +127 -0
- package/src/components/Gradient/Gradient.e2e-playground.tsx +25 -0
- package/src/components/Gradient/Gradient.e2e.tsx +8 -0
- package/src/components/Gradient/Gradient.stories.tsx +27 -0
- package/src/components/Gradient/Gradient.test.tsx +6 -0
- package/src/components/Gradient/Readme.md +71 -0
- package/src/components/Gradient/__image_snapshots__/gradient-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-android-chromium-light-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Gradient/__image_snapshots__/gradient-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/GridAvatar/GridAvatar.e2e-playground.tsx +38 -0
- package/src/components/GridAvatar/GridAvatar.e2e.tsx +12 -0
- package/src/components/GridAvatar/GridAvatar.stories.tsx +53 -0
- package/src/components/GridAvatar/GridAvatar.test.tsx +46 -0
- package/src/components/GridAvatar/Readme.md +46 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-android-chromium-dark-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-android-chromium-light-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-ios-webkit-light-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/GridAvatar/__image_snapshots__/gridavatar-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Group/Group.e2e-playground.tsx +27 -0
- package/src/components/Group/Group.e2e.tsx +8 -0
- package/src/components/Group/Group.module.css +1 -9
- package/src/components/Group/Group.stories.tsx +75 -0
- package/src/components/Group/Group.test.tsx +6 -0
- package/src/components/Group/Group.tsx +0 -3
- package/src/components/Group/Readme.md +142 -0
- package/src/components/Group/__image_snapshots__/group-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-android-chromium-light-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Group/__image_snapshots__/group-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Header/Header.e2e-playground.tsx +60 -0
- package/src/components/Header/Header.e2e.tsx +8 -0
- package/src/components/Header/Header.stories.tsx +70 -0
- package/src/components/Header/Header.test.tsx +132 -0
- package/src/components/Header/Readme.md +129 -0
- package/src/components/Header/__image_snapshots__/header-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-android-chromium-light-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Header/__image_snapshots__/header-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalCell/HorizontalCell.stories.tsx +78 -0
- package/src/components/HorizontalCell/HorizontalCell.test.tsx +28 -0
- package/src/components/HorizontalCell/Readme.md +192 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.e2e-playground.tsx +87 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.e2e.tsx +35 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.stories.tsx +132 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/HorizontalCellShowMore.test.tsx +32 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/Readme.md +1 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-android-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-ios-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-normal-size-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-android-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-ios-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalCellShowMore/__image_snapshots__/horizontalcellshowmore-small-size-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/HorizontalScroll.e2e-playground.tsx +115 -0
- package/src/components/HorizontalScroll/HorizontalScroll.e2e.tsx +90 -0
- package/src/components/HorizontalScroll/HorizontalScroll.stories.tsx +79 -0
- package/src/components/HorizontalScroll/HorizontalScroll.test.tsx +60 -0
- package/src/components/HorizontalScroll/Readme.md +220 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-android-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-ios-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-does-not-have-arrows-without-mouse-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-android-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-ios-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-has-arrows-on-mouse-hover-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-viewwidth-mobile-haspointer-false-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-viewwidth-mobile-haspointer-false-android-chromium-light-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-viewwidth-small-tablet-haspointer-true-android-chromium-dark-1-snap.png +3 -0
- package/src/components/HorizontalScroll/__image_snapshots__/horizontalscroll-viewwidth-small-tablet-haspointer-true-android-chromium-light-1-snap.png +3 -0
- package/src/components/IconButton/IconButton.e2e-playground.tsx +40 -0
- package/src/components/IconButton/IconButton.e2e.tsx +12 -0
- package/src/components/IconButton/IconButton.stories.tsx +24 -0
- package/src/components/IconButton/IconButton.test.tsx +26 -0
- package/src/components/IconButton/Readme.md +72 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-android-chromium-dark-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-android-chromium-light-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-ios-webkit-light-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/IconButton/__image_snapshots__/iconbutton-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Image/Image.e2e-playground.tsx +124 -0
- package/src/components/Image/Image.e2e.tsx +44 -0
- package/src/components/Image/Image.stories.tsx +20 -0
- package/src/components/Image/Image.test.tsx +32 -0
- package/src/components/Image/Readme.md +189 -0
- package/src/components/Image/__image_snapshots__/image-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-android-chromium-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-state-focus-visible-android-chromium-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-state-focus-visible-overlay-android-chromium-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Image/__image_snapshots__/image-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ImageBase/ImageBase.test.tsx +192 -0
- package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.stories.tsx +25 -0
- package/src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.tsx +3 -2
- package/src/components/ImageBase/ImageBaseOverlay/ImageBaseOverlay.stories.tsx +25 -0
- package/src/components/InfoRow/InfoRow.e2e-playground.tsx +19 -0
- package/src/components/InfoRow/InfoRow.e2e.tsx +8 -0
- package/src/components/InfoRow/InfoRow.stories.tsx +46 -0
- package/src/components/InfoRow/InfoRow.test.tsx +6 -0
- package/src/components/InfoRow/Readme.md +26 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-android-chromium-dark-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-android-chromium-light-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-ios-webkit-light-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/InfoRow/__image_snapshots__/inforow-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Input/Input.e2e-playground.tsx +27 -0
- package/src/components/Input/Input.e2e.tsx +8 -0
- package/src/components/Input/Input.stories.tsx +15 -0
- package/src/components/Input/Input.test.tsx +15 -0
- package/src/components/Input/Readme.md +150 -0
- package/src/components/Input/__image_snapshots__/input-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-android-chromium-light-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Input/__image_snapshots__/input-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/InputLike/InputLike.test.tsx +10 -0
- package/src/components/Link/Link.e2e-playground.tsx +17 -0
- package/src/components/Link/Link.e2e.tsx +23 -0
- package/src/components/Link/Link.stories.tsx +35 -0
- package/src/components/Link/Link.test.tsx +34 -0
- package/src/components/Link/Readme.md +39 -0
- package/src/components/Link/__image_snapshots__/link-state-focus-visible-android-chromium-light-1-snap.png +3 -0
- package/src/components/List/List.stories.tsx +64 -0
- package/src/components/List/List.test.tsx +6 -0
- package/src/components/List/Readme.md +40 -0
- package/src/components/LocaleProvider/LocaleProvider.stories.tsx +42 -0
- package/src/components/LocaleProvider/LocaleProvider.test.tsx +31 -0
- package/src/components/MiniInfoCell/MiniInfoCell.e2e-playground.tsx +67 -0
- package/src/components/MiniInfoCell/MiniInfoCell.e2e.tsx +12 -0
- package/src/components/MiniInfoCell/MiniInfoCell.stories.tsx +25 -0
- package/src/components/MiniInfoCell/MiniInfoCell.test.tsx +6 -0
- package/src/components/MiniInfoCell/Readme.md +137 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-android-chromium-dark-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-android-chromium-light-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-ios-webkit-light-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/MiniInfoCell/__image_snapshots__/miniinfocell-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ModalCard/ModalCard.e2e-playground.tsx +138 -0
- package/src/components/ModalCard/ModalCard.e2e.tsx +46 -0
- package/src/components/ModalCard/ModalCard.stories.tsx +152 -0
- package/src/components/ModalCard/ModalCard.test.tsx +60 -0
- package/src/components/ModalCard/Readme.md +9 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-mobile-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-mobile-android-chromium-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-mobile-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-mobile-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-tablet-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-tablet-android-chromium-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-tablet-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-tablet-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalCard/__image_snapshots__/modalcard-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ModalCardBase/ModalCardBase.stories.tsx +32 -0
- package/src/components/ModalCardBase/Readme.md +144 -0
- package/src/components/ModalDismissButton/ModalDismissButton.stories.tsx +25 -0
- package/src/components/ModalDismissButton/ModalDismissButton.test.tsx +8 -0
- package/src/components/ModalDismissButton/Readme.md +55 -0
- package/src/components/ModalPage/ModalPage.stories.tsx +235 -0
- package/src/components/ModalPage/ModalPage.test.tsx +42 -0
- package/src/components/ModalPage/Readme.md +14 -0
- package/src/components/ModalPageHeader/ModalPageHeader.e2e-playground.tsx +75 -0
- package/src/components/ModalPageHeader/ModalPageHeader.e2e.tsx +75 -0
- package/src/components/ModalPageHeader/ModalPageHeader.stories.tsx +73 -0
- package/src/components/ModalPageHeader/ModalPageHeader.test.tsx +35 -0
- package/src/components/ModalPageHeader/Readme.md +44 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-android-chromium-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-ios-only-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-ios-only-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-desktop-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-android-chromium-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-ios-only-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-ios-only-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ModalPageHeader/__image_snapshots__/modalpageheader-viewwidth-mobile-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/ModalRoot/ModalRoot.stories.tsx +124 -0
- package/src/components/ModalRoot/ModalRoot.test.tsx +253 -0
- package/src/components/ModalRoot/ModalRoot.tsx +31 -8
- package/src/components/ModalRoot/Readme.md +746 -0
- package/src/components/ModalRoot/useModalManager.test.tsx +289 -0
- package/src/components/NativeSelect/NativeSelect.e2e-playground.tsx +49 -0
- package/src/components/NativeSelect/NativeSelect.e2e.tsx +12 -0
- package/src/components/NativeSelect/NativeSelect.stories.tsx +23 -0
- package/src/components/NativeSelect/NativeSelect.test.tsx +95 -0
- package/src/components/NativeSelect/NativeSelect.tsx +6 -14
- package/src/components/NativeSelect/Readme.md +21 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-android-chromium-dark-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-android-chromium-light-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-ios-webkit-light-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/NativeSelect/__image_snapshots__/nativeselect-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/NavIdContext/useNavId.test.tsx +46 -0
- package/src/components/NavTransitionDirectionContext/NavTransitionDirectionContext.test.tsx +106 -0
- package/src/components/OnboardingTooltip/OnboardingTooltip.e2e-playground.tsx +53 -0
- package/src/components/OnboardingTooltip/OnboardingTooltip.e2e.tsx +12 -0
- package/src/components/OnboardingTooltip/OnboardingTooltip.stories.tsx +286 -0
- package/src/components/OnboardingTooltip/OnboardingTooltip.test.tsx +128 -0
- package/src/components/OnboardingTooltip/Readme.md +318 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-android-chromium-dark-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-android-chromium-light-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-ios-webkit-light-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/OnboardingTooltip/__image_snapshots__/onboardingtooltip-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Pagination/Pagination.e2e-playground.tsx +30 -0
- package/src/components/Pagination/Pagination.e2e.tsx +12 -0
- package/src/components/Pagination/Pagination.stories.tsx +31 -0
- package/src/components/Pagination/Pagination.test.tsx +6 -0
- package/src/components/Pagination/Readme.md +105 -0
- package/src/components/Pagination/__image_snapshots__/pagination-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-android-chromium-light-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Pagination/__image_snapshots__/pagination-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Panel/Panel.e2e-playground.tsx +50 -0
- package/src/components/Panel/Panel.e2e.tsx +14 -0
- package/src/components/Panel/Panel.stories.tsx +93 -0
- package/src/components/Panel/Panel.test.tsx +7 -0
- package/src/components/Panel/Readme.md +71 -0
- package/src/components/Panel/__image_snapshots__/panel-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-android-chromium-light-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Panel/__image_snapshots__/panel-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PanelHeader/PanelHeader.e2e-playground.tsx +35 -0
- package/src/components/PanelHeader/PanelHeader.e2e.tsx +16 -0
- package/src/components/PanelHeader/PanelHeader.stories.tsx +169 -0
- package/src/components/PanelHeader/PanelHeader.test.tsx +44 -0
- package/src/components/PanelHeader/Readme.md +189 -0
- package/src/components/PanelHeader/__image_snapshots__/panelheader-android-chromium-light-1-snap.png +3 -0
- package/src/components/PanelHeader/__image_snapshots__/panelheader-ios-webkit-light-1-snap.png +3 -0
- package/src/components/PanelHeader/__image_snapshots__/panelheader-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/PanelHeader/__image_snapshots__/panelheader-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/PanelHeader/__image_snapshots__/panelheader-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PanelHeaderBack/PanelHeaderBack.test.tsx +6 -0
- package/src/components/PanelHeaderButton/PanelHeaderButton.stories.tsx +63 -0
- package/src/components/PanelHeaderButton/PanelHeaderButton.test.tsx +23 -0
- package/src/components/PanelHeaderButton/Readme.md +78 -0
- package/src/components/PanelHeaderClose/PanelHeaderClose.test.tsx +6 -0
- package/src/components/PanelHeaderContent/PanelHeaderContent.stories.tsx +49 -0
- package/src/components/PanelHeaderContent/PanelHeaderContent.test.tsx +6 -0
- package/src/components/PanelHeaderContent/Readme.md +38 -0
- package/src/components/PanelHeaderContext/PanelHeaderContext.stories.tsx +101 -0
- package/src/components/PanelHeaderContext/PanelHeaderContext.test.tsx +67 -0
- package/src/components/PanelHeaderContext/Readme.md +78 -0
- package/src/components/PanelHeaderEdit/PanelHeaderEdit.test.tsx +6 -0
- package/src/components/PanelHeaderSubmit/PanelHeaderSubmit.test.tsx +6 -0
- package/src/components/PanelSpinner/PanelSpinner.stories.tsx +17 -0
- package/src/components/PanelSpinner/PanelSpinner.test.tsx +6 -0
- package/src/components/PanelSpinner/Readme.md +21 -0
- package/src/components/Placeholder/Placeholder.e2e-playground.tsx +71 -0
- package/src/components/Placeholder/Placeholder.e2e.tsx +18 -0
- package/src/components/Placeholder/Placeholder.stories.tsx +23 -0
- package/src/components/Placeholder/Placeholder.test.tsx +6 -0
- package/src/components/Placeholder/Readme.md +107 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-android-chromium-light-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Placeholder/__image_snapshots__/placeholder-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PlatformProvider/PlatformProvider.stories.tsx +42 -0
- package/src/components/PlatformProvider/PlatformProvider.test.tsx +28 -0
- package/src/components/PopoutRoot/PopoutRoot.test.tsx +14 -0
- package/src/components/PopoutWrapper/PopoutWrapper.stories.tsx +32 -0
- package/src/components/PopoutWrapper/PopoutWrapper.test.tsx +26 -0
- package/src/components/PopoutWrapper/Readme.md +31 -0
- package/src/components/Popover/Popover.stories.tsx +218 -0
- package/src/components/Popover/Popover.test.tsx +103 -0
- package/src/components/Popover/Readme.md +214 -0
- package/src/components/Popper/Popper.stories.tsx +36 -0
- package/src/components/Popper/Popper.test.tsx +88 -0
- package/src/components/Popper/Readme.md +73 -0
- package/src/components/Progress/Progress.e2e-playground.tsx +23 -0
- package/src/components/Progress/Progress.e2e.tsx +8 -0
- package/src/components/Progress/Progress.stories.tsx +29 -0
- package/src/components/Progress/Progress.test.tsx +15 -0
- package/src/components/Progress/Readme.md +20 -0
- package/src/components/Progress/__image_snapshots__/progress-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-android-chromium-light-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Progress/__image_snapshots__/progress-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/PullToRefresh.e2e-playground.tsx +66 -0
- package/src/components/PullToRefresh/PullToRefresh.e2e.tsx +62 -0
- package/src/components/PullToRefresh/PullToRefresh.module.css +5 -0
- package/src/components/PullToRefresh/PullToRefresh.stories.tsx +58 -0
- package/src/components/PullToRefresh/PullToRefresh.test.tsx +181 -0
- package/src/components/PullToRefresh/PullToRefresh.tsx +64 -72
- package/src/components/PullToRefresh/Readme.md +52 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-in-default-environment-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-in-default-environment-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-in-default-environment-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-when-parent-has-padding-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-when-parent-has-padding-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-renders-spinner-properly-when-parent-has-padding-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-takes-whole-parent-height-and-allow-smaller-content-to-center-vertically-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-takes-whole-parent-height-and-allow-smaller-content-to-center-vertically-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/PullToRefresh/__image_snapshots__/pulltorefresh-takes-whole-parent-height-and-allow-smaller-content-to-center-vertically-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Radio/Radio.e2e-playground.tsx +38 -0
- package/src/components/Radio/Radio.e2e.tsx +26 -0
- package/src/components/Radio/Radio.stories.tsx +28 -0
- package/src/components/Radio/Radio.test.tsx +55 -0
- package/src/components/Radio/Radio.tsx +2 -16
- package/src/components/Radio/Readme.md +30 -0
- package/src/components/Radio/__image_snapshots__/radio-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-android-chromium-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-android-chromium-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-sizes-and-description-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Radio/__image_snapshots__/radio-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/RadioGroup/RadioGroup.e2e-playground.tsx +50 -0
- package/src/components/RadioGroup/RadioGroup.e2e.tsx +12 -0
- package/src/components/RadioGroup/RadioGroup.stories.tsx +41 -0
- package/src/components/RadioGroup/RadioGroup.test.tsx +6 -0
- package/src/components/RadioGroup/Readme.md +56 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-android-chromium-dark-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-android-chromium-light-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-ios-webkit-light-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/RadioGroup/__image_snapshots__/radiogroup-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Removable/Removable.test.tsx +63 -0
- package/src/components/RichCell/Readme.md +132 -0
- package/src/components/RichCell/RichCell.e2e-playground.tsx +72 -0
- package/src/components/RichCell/RichCell.e2e.tsx +10 -0
- package/src/components/RichCell/RichCell.stories.tsx +43 -0
- package/src/components/RichCell/RichCell.test.tsx +7 -0
- package/src/components/RichCell/__image_snapshots__/richcell-android-chromium-dark-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-android-chromium-light-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-ios-webkit-light-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/RichCell/__image_snapshots__/richcell-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Root/Readme.md +35 -0
- package/src/components/Root/Root.stories.tsx +52 -0
- package/src/components/Root/Root.test.tsx +216 -0
- package/src/components/RootComponent/RootComponent.test.tsx +6 -0
- package/src/components/ScreenSpinner/Readme.md +61 -0
- package/src/components/ScreenSpinner/ScreenSpinner.stories.tsx +15 -0
- package/src/components/ScreenSpinner/ScreenSpinner.test.tsx +6 -0
- package/src/components/ScrollArrow/ScrollArrow.e2e-playground.tsx +21 -0
- package/src/components/ScrollArrow/ScrollArrow.e2e.tsx +12 -0
- package/src/components/ScrollArrow/ScrollArrow.stories.tsx +15 -0
- package/src/components/ScrollArrow/ScrollArrow.test.tsx +22 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-android-chromium-dark-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-android-chromium-light-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-ios-webkit-light-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/ScrollArrow/__image_snapshots__/scrollarrow-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Search/Readme.md +254 -0
- package/src/components/Search/Search.e2e-playground.tsx +62 -0
- package/src/components/Search/Search.e2e.tsx +21 -0
- package/src/components/Search/Search.stories.tsx +29 -0
- package/src/components/Search/Search.test.tsx +126 -0
- package/src/components/Search/Search.tsx +12 -14
- package/src/components/Search/__image_snapshots__/search-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-android-chromium-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-android-chromium-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-shows-after-when-focused-on-ios-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Search/__image_snapshots__/search-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/SegmentedControl/Readme.md +87 -0
- package/src/components/SegmentedControl/SegmentedControl.e2e-playground.tsx +48 -0
- package/src/components/SegmentedControl/SegmentedControl.e2e.tsx +12 -0
- package/src/components/SegmentedControl/SegmentedControl.stories.tsx +40 -0
- package/src/components/SegmentedControl/SegmentedControl.test.tsx +72 -0
- package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.test.tsx +9 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-android-chromium-dark-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-android-chromium-light-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-ios-webkit-light-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/SegmentedControl/__image_snapshots__/segmentedcontrol-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Select/Readme.md +111 -0
- package/src/components/Select/Select.stories.tsx +20 -0
- package/src/components/Select/Select.test.tsx +13 -0
- package/src/components/SelectMimicry/Readme.md +74 -0
- package/src/components/SelectMimicry/SelectMimicry.e2e-playground.tsx +36 -0
- package/src/components/SelectMimicry/SelectMimicry.e2e.tsx +12 -0
- package/src/components/SelectMimicry/SelectMimicry.stories.tsx +33 -0
- package/src/components/SelectMimicry/SelectMimicry.test.tsx +6 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-android-chromium-dark-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-android-chromium-light-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-ios-webkit-light-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/SelectMimicry/__image_snapshots__/selectmimicry-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Separator/Readme.md +21 -0
- package/src/components/Separator/Separator.stories.tsx +45 -0
- package/src/components/Separator/Separator.test.tsx +6 -0
- package/src/components/SimpleCell/Readme.md +119 -0
- package/src/components/SimpleCell/SimpleCell.e2e-playground.tsx +107 -0
- package/src/components/SimpleCell/SimpleCell.e2e.tsx +12 -0
- package/src/components/SimpleCell/SimpleCell.stories.tsx +49 -0
- package/src/components/SimpleCell/SimpleCell.test.tsx +25 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-android-chromium-dark-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-android-chromium-light-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-ios-webkit-light-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/SimpleCell/__image_snapshots__/simplecell-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Slider/Readme.md +164 -0
- package/src/components/Slider/Slider.e2e-playground.tsx +74 -0
- package/src/components/Slider/Slider.e2e.tsx +107 -0
- package/src/components/Slider/Slider.stories.tsx +62 -0
- package/src/components/Slider/Slider.test.tsx +237 -0
- package/src/components/Slider/__image_snapshots__/slider-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-android-chromium-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Slider/__image_snapshots__/slider-with-tooltip-slider-with-tooltip-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Snackbar/Readme.md +170 -0
- package/src/components/Snackbar/Snackbar.stories.tsx +66 -0
- package/src/components/Snackbar/Snackbar.test.tsx +15 -0
- package/src/components/Snackbar/subcomponents/Basic/Basic.e2e-playground.tsx +71 -0
- package/src/components/Snackbar/subcomponents/Basic/Basic.e2e.tsx +12 -0
- package/src/components/Snackbar/subcomponents/Basic/Basic.stories.tsx +37 -0
- package/src/components/Snackbar/subcomponents/Basic/Basic.test.tsx +6 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-android-chromium-light-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Snackbar/subcomponents/Basic/__image_snapshots__/snackbarbasic-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Spacing/Readme.md +92 -0
- package/src/components/Spacing/Spacing.stories.tsx +42 -0
- package/src/components/Spacing/Spacing.test.tsx +6 -0
- package/src/components/Spinner/Readme.md +22 -0
- package/src/components/Spinner/Spinner.stories.tsx +17 -0
- package/src/components/Spinner/Spinner.test.tsx +6 -0
- package/src/components/SplitCol/Readme.md +1 -0
- package/src/components/SplitCol/SplitCol.stories.tsx +78 -0
- package/src/components/SplitCol/SplitCol.test.tsx +6 -0
- package/src/components/SplitLayout/Readme.md +123 -0
- package/src/components/SplitLayout/SplitLayout.stories.tsx +173 -0
- package/src/components/SplitLayout/SplitLayout.test.tsx +6 -0
- package/src/components/SubnavigationBar/Readme.md +249 -0
- package/src/components/SubnavigationBar/SubnavigationBar.stories.tsx +69 -0
- package/src/components/SubnavigationBar/SubnavigationBar.test.tsx +25 -0
- package/src/components/SubnavigationButton/Readme.md +111 -0
- package/src/components/SubnavigationButton/SubnavigationButton.e2e-playground.tsx +65 -0
- package/src/components/SubnavigationButton/SubnavigationButton.e2e.tsx +12 -0
- package/src/components/SubnavigationButton/SubnavigationButton.stories.tsx +43 -0
- package/src/components/SubnavigationButton/SubnavigationButton.test.tsx +9 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-android-chromium-dark-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-android-chromium-light-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-ios-webkit-light-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/SubnavigationButton/__image_snapshots__/subnavigationbutton-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Switch/Readme.md +33 -0
- package/src/components/Switch/Switch.e2e-playground.tsx +32 -0
- package/src/components/Switch/Switch.e2e.tsx +28 -0
- package/src/components/Switch/Switch.stories.tsx +32 -0
- package/src/components/Switch/Switch.test.tsx +96 -0
- package/src/components/Switch/__image_snapshots__/switch-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-android-chromium-light-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-state-focus-visible-android-chromium-light-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Switch/__image_snapshots__/switch-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Tabbar/Readme.md +7 -0
- package/src/components/Tabbar/Tabbar.e2e-playground.tsx +54 -0
- package/src/components/Tabbar/Tabbar.e2e.tsx +10 -0
- package/src/components/Tabbar/Tabbar.stories.tsx +85 -0
- package/src/components/Tabbar/Tabbar.test.tsx +6 -0
- package/src/components/Tabbar/__image_snapshots__/tabbar-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Tabbar/__image_snapshots__/tabbar-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tabbar/__image_snapshots__/tabbar-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Tabbar/__image_snapshots__/tabbar-ios-webkit-light-1-snap.png +3 -0
- package/src/components/TabbarItem/Readme.md +99 -0
- package/src/components/TabbarItem/TabbarItem.stories.tsx +72 -0
- package/src/components/TabbarItem/TabbarItem.test.tsx +43 -0
- package/src/components/Tabs/Readme.md +247 -0
- package/src/components/Tabs/Tabs.e2e-playground.tsx +177 -0
- package/src/components/Tabs/Tabs.e2e.tsx +23 -0
- package/src/components/Tabs/Tabs.stories.tsx +129 -0
- package/src/components/Tabs/Tabs.test.tsx +189 -0
- package/src/components/Tabs/__image_snapshots__/tabs-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-layout-fill-mode-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-layout-fill-mode-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-layout-fill-mode-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-layout-fill-mode-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-layout-fill-mode-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Tabs/__image_snapshots__/tabs-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/TabsItem/Readme.md +1 -0
- package/src/components/TabsItem/TabsItem.module.css +0 -1
- package/src/components/TabsItem/TabsItem.stories.tsx +83 -0
- package/src/components/TabsItem/TabsItem.test.tsx +10 -0
- package/src/components/TabsItem/TabsItem.tsx +2 -4
- package/src/components/Tappable/Readme.md +54 -0
- package/src/components/Tappable/Tappable.e2e-playground.tsx +61 -0
- package/src/components/Tappable/Tappable.e2e.tsx +32 -0
- package/src/components/Tappable/Tappable.stories.tsx +23 -0
- package/src/components/Tappable/Tappable.test.tsx +342 -0
- package/src/components/Tappable/__image_snapshots__/tappable-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-state-focus-visible-focusvisiblemode-inside-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-state-focus-visible-focusvisiblemode-outside-android-chromium-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Tappable/__image_snapshots__/tappable-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Textarea/Readme.md +23 -0
- package/src/components/Textarea/Textarea.e2e-playground.tsx +63 -0
- package/src/components/Textarea/Textarea.e2e.tsx +51 -0
- package/src/components/Textarea/Textarea.module.css +0 -8
- package/src/components/Textarea/Textarea.stories.tsx +15 -0
- package/src/components/Textarea/Textarea.test.tsx +114 -0
- package/src/components/Textarea/Textarea.tsx +9 -22
- package/src/components/Textarea/__image_snapshots__/textarea-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-android-chromium-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-fits-size-to-content-android-chromium-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-fits-size-to-content-android-chromium-light-2-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-state-focus-visible-android-chromium-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Textarea/__image_snapshots__/textarea-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Tooltip/Readme.md +7 -0
- package/src/components/Tooltip/Tooltip.stories.tsx +26 -0
- package/src/components/Tooltip/Tooltip.test.tsx +32 -0
- package/src/components/TooltipBase/Readme.md +6 -0
- package/src/components/Touch/Readme.md +94 -0
- package/src/components/Touch/Touch.stories.tsx +102 -0
- package/src/components/Touch/Touch.test.tsx +433 -0
- package/src/components/Typography/Caption/Caption.e2e-playground.tsx +27 -0
- package/src/components/Typography/Caption/Caption.e2e.tsx +8 -0
- package/src/components/Typography/Caption/Caption.stories.tsx +40 -0
- package/src/components/Typography/Caption/Caption.test.tsx +11 -0
- package/src/components/Typography/Caption/Readme.md +29 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Caption/__image_snapshots__/caption-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Footnote/Footnote.e2e-playground.tsx +26 -0
- package/src/components/Typography/Footnote/Footnote.e2e.tsx +8 -0
- package/src/components/Typography/Footnote/Footnote.stories.tsx +28 -0
- package/src/components/Typography/Footnote/Footnote.test.tsx +7 -0
- package/src/components/Typography/Footnote/Readme.md +18 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Footnote/__image_snapshots__/footnote-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Headline/Headline.e2e-playground.tsx +36 -0
- package/src/components/Typography/Headline/Headline.e2e.tsx +8 -0
- package/src/components/Typography/Headline/Headline.stories.tsx +28 -0
- package/src/components/Typography/Headline/Headline.test.tsx +7 -0
- package/src/components/Typography/Headline/Readme.md +28 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Headline/__image_snapshots__/headline-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/Paragraph.e2e-playground.tsx +25 -0
- package/src/components/Typography/Paragraph/Paragraph.e2e.tsx +8 -0
- package/src/components/Typography/Paragraph/Paragraph.stories.tsx +20 -0
- package/src/components/Typography/Paragraph/Paragraph.test.tsx +7 -0
- package/src/components/Typography/Paragraph/Readme.md +19 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Paragraph/__image_snapshots__/paragraph-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Subhead/Readme.md +35 -0
- package/src/components/Typography/Subhead/Subhead.e2e-playground.tsx +25 -0
- package/src/components/Typography/Subhead/Subhead.e2e.tsx +8 -0
- package/src/components/Typography/Subhead/Subhead.stories.tsx +20 -0
- package/src/components/Typography/Subhead/Subhead.test.tsx +7 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Subhead/__image_snapshots__/subhead-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Text/Readme.md +19 -0
- package/src/components/Typography/Text/Text.e2e-playground.tsx +29 -0
- package/src/components/Typography/Text/Text.e2e.tsx +8 -0
- package/src/components/Typography/Text/Text.stories.tsx +20 -0
- package/src/components/Typography/Text/Text.test.tsx +7 -0
- package/src/components/Typography/Text/__image_snapshots__/text-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Text/__image_snapshots__/text-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Title/Readme.md +29 -0
- package/src/components/Typography/Title/Title.e2e-playground.tsx +34 -0
- package/src/components/Typography/Title/Title.e2e.tsx +8 -0
- package/src/components/Typography/Title/Title.stories.tsx +32 -0
- package/src/components/Typography/Title/Title.test.tsx +7 -0
- package/src/components/Typography/Title/__image_snapshots__/title-android-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-android-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-ios-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/Typography/Title/__image_snapshots__/title-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/Typography/Typography.stories.tsx +88 -0
- package/src/components/Typography/Typography.test.tsx +6 -0
- package/src/components/UsersStack/Readme.md +90 -0
- package/src/components/UsersStack/UsersStack.e2e-playground.tsx +39 -0
- package/src/components/UsersStack/UsersStack.e2e.tsx +12 -0
- package/src/components/UsersStack/UsersStack.stories.tsx +24 -0
- package/src/components/UsersStack/UsersStack.test.tsx +6 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-android-chromium-dark-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-android-chromium-light-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-ios-webkit-light-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/UsersStack/__image_snapshots__/usersstack-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/View/Readme.md +519 -0
- package/src/components/View/View.stories.tsx +179 -0
- package/src/components/View/View.test.tsx +506 -0
- package/src/components/View/ViewInfinite.test.tsx +491 -0
- package/src/components/VisuallyHidden/VisuallyHidden.stories.tsx +25 -0
- package/src/components/VisuallyHidden/VisuallyHidden.test.tsx +22 -0
- package/src/components/WriteBar/Readme.md +238 -0
- package/src/components/WriteBar/WriteBar.e2e-playground.tsx +111 -0
- package/src/components/WriteBar/WriteBar.e2e.tsx +19 -0
- package/src/components/WriteBar/WriteBar.stories.tsx +29 -0
- package/src/components/WriteBar/WriteBar.test.tsx +45 -0
- package/src/components/WriteBar/WriteBar.tsx +4 -10
- package/src/components/WriteBar/__image_snapshots__/writebar-android-chromium-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-android-chromium-light-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-icons-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-icons-ios-webkit-light-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-ios-webkit-light-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/WriteBar/__image_snapshots__/writebar-vkcom-webkit-light-1-snap.png +3 -0
- package/src/components/WriteBarIcon/Readme.md +39 -0
- package/src/components/WriteBarIcon/WriteBarIcon.e2e-playground.tsx +31 -0
- package/src/components/WriteBarIcon/WriteBarIcon.e2e.tsx +12 -0
- package/src/components/WriteBarIcon/WriteBarIcon.stories.tsx +19 -0
- package/src/components/WriteBarIcon/WriteBarIcon.test.tsx +30 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-android-chromium-dark-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-android-chromium-light-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-ios-webkit-dark-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-ios-webkit-light-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-chromium-dark-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-chromium-light-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-firefox-dark-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-firefox-light-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-webkit-dark-1-snap.png +3 -0
- package/src/components/WriteBarIcon/__image_snapshots__/writebaricon-vkcom-webkit-light-1-snap.png +3 -0
- package/src/helpers/avatar.test.ts +20 -0
- package/src/helpers/getMergedSameEventsByProps.test.ts +91 -0
- package/src/helpers/math.test.ts +37 -0
- package/src/helpers/range.test.ts +18 -0
- package/src/hooks/useAdaptivityConditionalRender/useAdaptivityConditionalRender.test.tsx +167 -0
- package/src/hooks/useAdaptivityHasPointer.test.tsx +25 -0
- package/src/hooks/useAutoDetectAppearance.test.ts +89 -0
- package/src/hooks/useAutoFocus.test.tsx +32 -0
- package/src/hooks/useBooleanState.test.tsx +38 -0
- package/src/hooks/useDraggableWithDomApi/autoScroll.test.ts +148 -0
- package/src/hooks/useDraggableWithDomApi/utils.test.ts +157 -0
- package/src/hooks/useEnsuredControl.test.tsx +206 -0
- package/src/hooks/useExternRef.test.tsx +80 -0
- package/src/hooks/useFocusVisible.test.tsx +60 -0
- package/src/hooks/useFocusVisibleClassName.test.ts +46 -0
- package/src/hooks/useFocusWithin.test.tsx +38 -0
- package/src/hooks/useGlobalOnClickOutside.test.tsx +98 -0
- package/src/hooks/useKeyboardInputTracker.test.ts +79 -0
- package/src/hooks/useObjectMemo.test.tsx +27 -0
- package/src/hooks/usePagintaion.test.ts +74 -0
- package/src/hooks/usePatchChildren.test.tsx +164 -0
- package/src/hooks/usePlatform.test.tsx +39 -0
- package/src/hooks/useStableCallback.test.ts +23 -0
- package/src/hooks/useTimeout.test.ts +49 -0
- package/src/index.ts +0 -3
- package/src/lib/SSR.test.ts +66 -0
- package/src/lib/accessibility.test.tsx +80 -0
- package/src/lib/adaptivity/functions.test.ts +175 -0
- package/src/lib/calendar.test.tsx +116 -0
- package/src/lib/callMultiple.test.ts +13 -0
- package/src/lib/children.test.tsx +133 -0
- package/src/lib/comparing.test.ts +11 -0
- package/src/lib/createPortal.test.tsx +13 -0
- package/src/lib/date.test.ts +440 -0
- package/src/lib/dom.test.ts +223 -0
- package/src/lib/floating/README.md +5 -0
- package/src/lib/floating/adapters.test.ts +90 -0
- package/src/lib/floating/adapters.ts +14 -25
- package/src/lib/floating/customResizeObserver.test.ts +147 -0
- package/src/lib/floating/customResizeObserver.ts +100 -0
- package/src/lib/floating/functions.test.ts +79 -0
- package/src/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.test.tsx +484 -0
- package/src/lib/floating/useFloatingWithInteractions/useResolveTriggerType.test.ts +29 -0
- package/src/lib/getNavId.test.ts +23 -0
- package/src/lib/isRefObject.test.ts +14 -0
- package/src/lib/mergeCalls.test.ts +32 -0
- package/src/lib/select.test.ts +47 -0
- package/src/lib/tokens/useTokenClassName.test.tsx +27 -0
- package/src/lib/touch.test.ts +39 -0
- package/src/lib/utils.test.tsx +85 -0
- package/src/lib/warnOnce.test.ts +46 -0
- package/src/storybook/Icons.tsx +66 -0
- package/src/storybook/ModalWrapper.tsx +32 -0
- package/src/storybook/VKUIDecorators.tsx +92 -0
- package/src/storybook/constants.ts +16 -0
- package/src/styles/common.css +1 -0
- package/src/testing/createWrapper.tsx +8 -0
- package/src/testing/e2e/AppDefaultWrapper.tsx +17 -0
- package/src/testing/e2e/ComponentPlayground.tsx +90 -0
- package/src/testing/e2e/constants.ts +7 -0
- package/src/testing/e2e/index.playground.ts +13 -0
- package/src/testing/e2e/index.playwright.ts +117 -0
- package/src/testing/e2e/screenshotWithClipToContent.ts +55 -0
- package/src/testing/e2e/test-image.svg +4 -0
- package/src/testing/e2e/types.ts +31 -0
- package/src/testing/e2e/utils.tsx +142 -0
- package/src/testing/icons.tsx +97 -0
- package/src/testing/mock.ts +241 -0
- package/src/testing/user_dataset.ts +307 -0
- package/src/testing/utils.tsx +333 -0
- package/src/vkui.js +1 -0
- package/dist/cjs/components/Mark/Mark.d.ts +0 -12
- package/dist/cjs/components/Mark/Mark.d.ts.map +0 -1
- package/dist/cjs/components/Mark/Mark.js +0 -20
- package/dist/cjs/components/Mark/Mark.js.map +0 -1
- package/dist/components/Mark/Mark.d.ts +0 -12
- package/dist/components/Mark/Mark.d.ts.map +0 -1
- package/dist/components/Mark/Mark.js +0 -15
- package/dist/components/Mark/Mark.js.map +0 -1
- package/dist/cssm/components/Mark/Mark.d.ts +0 -12
- package/dist/cssm/components/Mark/Mark.d.ts.map +0 -1
- package/dist/cssm/components/Mark/Mark.js +0 -16
- package/dist/cssm/components/Mark/Mark.js.map +0 -1
- package/dist/cssm/components/Mark/Mark.module.css +0 -8
- package/src/components/Mark/Mark.module.css +0 -8
- package/src/components/Mark/Mark.tsx +0 -17
|
@@ -236,9 +236,9 @@ const useScrollLockEffect = (effect, deps)=>{
|
|
|
236
236
|
]);
|
|
237
237
|
};
|
|
238
238
|
const useScrollLock = (enabled = true)=>{
|
|
239
|
-
const { enableScrollLock, disableScrollLock } = useScroll();
|
|
239
|
+
const { enableScrollLock, disableScrollLock, isScrollLock } = useScroll();
|
|
240
240
|
(0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(()=>{
|
|
241
|
-
if (enabled) {
|
|
241
|
+
if (enabled && !isScrollLock) {
|
|
242
242
|
enableScrollLock();
|
|
243
243
|
return disableScrollLock;
|
|
244
244
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/AppRoot/ScrollContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { noop } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { useDOM } from '../../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { HasChildren } from '../../types';\n\nconst clearDisableScrollStyle = (node: HTMLElement) => {\n Object.assign(node.style, {\n position: '',\n top: '',\n left: '',\n right: '',\n overflowY: '',\n overflowX: '',\n });\n};\n\nconst getPageYOffsetWithoutKeyboardHeight = (window: Window) => {\n // Note: здесь расчёт на то, что `clientHeight` равен `window.innerHeight`.\n // Это достигается тем, что тегу `html` задали`height: 100%` и у него нет отступов сверху и снизу. Если есть отступы,\n // то надо задать `box-sizing: border-box`, чтобы они не учитывались.\n const diffOfClientHeightAndViewportHeight =\n window.document.documentElement.clientHeight - window.innerHeight;\n return window.pageYOffset - diffOfClientHeightAndViewportHeight;\n};\n\nexport interface ScrollContextInterface {\n getScroll(this: void): { x: number; y: number };\n scrollTo(this: void, x?: number, y?: number): void;\n isScrollLock: boolean;\n enableScrollLock(this: void): void;\n disableScrollLock(this: void): void;\n beforeScrollLockFnSetRef?: React.RefObject<Set<() => void>>;\n}\n\nexport const ScrollContext = React.createContext<ScrollContextInterface>({\n getScroll: () => ({ x: 0, y: 0 }),\n scrollTo: noop,\n isScrollLock: false,\n enableScrollLock: noop,\n disableScrollLock: noop,\n});\n\nexport const useScroll = () => React.useContext(ScrollContext);\n\nexport interface ScrollControllerProps extends HasChildren {\n elRef: React.RefObject<HTMLElement>;\n}\n\nexport const GlobalScrollController = ({ children }: ScrollControllerProps) => {\n const { window, document } = useDOM();\n const [isScrollLock, setScrollLock] = React.useState(false);\n const beforeScrollLockFnSetRef = React.useRef<Set<() => void>>(new Set());\n\n const getScroll = React.useCallback<ScrollContextInterface['getScroll']>(\n () => ({\n x: window!.pageXOffset,\n y: getPageYOffsetWithoutKeyboardHeight(window!),\n }),\n [window],\n );\n const scrollTo = React.useCallback<ScrollContextInterface['scrollTo']>(\n (x = 0, y = 0) => {\n // Some iOS versions do not normalize scroll — do it manually.\n window!.scrollTo(\n x ? clamp(x, 0, document!.body.scrollWidth - window!.innerWidth) : 0,\n y ? clamp(y, 0, document!.body.scrollHeight - window!.innerHeight) : 0,\n );\n },\n [document, window],\n );\n\n const enableScrollLock = React.useCallback<ScrollContextInterface['enableScrollLock']>(() => {\n beforeScrollLockFnSetRef.current.forEach((fn) => {\n fn();\n });\n\n const scrollY = window!.pageYOffset;\n const scrollX = window!.pageXOffset;\n const overflowY = window!.innerWidth > document!.documentElement.clientWidth ? 'scroll' : '';\n const overflowX = window!.innerHeight > document!.documentElement.clientHeight ? 'scroll' : '';\n\n Object.assign(document!.body.style, {\n position: 'fixed',\n top: `-${scrollY}px`,\n left: `-${scrollX}px`,\n right: '0',\n overflowY,\n overflowX,\n });\n setScrollLock(true);\n }, [document, window]);\n\n const disableScrollLock = React.useCallback<ScrollContextInterface['disableScrollLock']>(() => {\n const scrollY = document!.body.style.top;\n const scrollX = document!.body.style.left;\n\n clearDisableScrollStyle(document!.body);\n window!.scrollTo(-parseInt(scrollX || '0'), -parseInt(scrollY || '0'));\n setScrollLock(false);\n }, [document, window]);\n\n const scrollController = React.useMemo<ScrollContextInterface>(\n () => ({\n getScroll,\n scrollTo,\n isScrollLock,\n disableScrollLock,\n enableScrollLock,\n\n beforeScrollLockFnSetRef: beforeScrollLockFnSetRef,\n }),\n [getScroll, scrollTo, isScrollLock, disableScrollLock, enableScrollLock],\n );\n\n return <ScrollContext.Provider value={scrollController}>{children}</ScrollContext.Provider>;\n};\n\nexport const ElementScrollController = ({ elRef, children }: ScrollControllerProps) => {\n const [isScrollLock, setScrollLock] = React.useState(false);\n const beforeScrollLockFnSetRef = React.useRef<Set<() => void>>(new Set());\n\n const getScroll = React.useCallback<ScrollContextInterface['getScroll']>(\n () => ({\n x: elRef.current?.scrollLeft ?? 0,\n y: elRef.current?.scrollTop ?? 0,\n }),\n [elRef],\n );\n const scrollTo = React.useCallback<ScrollContextInterface['scrollTo']>(\n (x = 0, y = 0) => {\n const el = elRef.current;\n // Some iOS versions do not normalize scroll — do it manually.\n el?.scrollTo(\n x ? clamp(x, 0, el.scrollWidth - el.clientWidth) : 0,\n y ? clamp(y, 0, el.scrollHeight - el.clientHeight) : 0,\n );\n },\n [elRef],\n );\n\n const enableScrollLock = React.useCallback<ScrollContextInterface['enableScrollLock']>(() => {\n const el = elRef.current;\n if (!el) {\n return;\n }\n beforeScrollLockFnSetRef.current.forEach((fn) => {\n fn();\n });\n\n const scrollY = el.scrollTop;\n const scrollX = el.scrollLeft;\n const overflowY = el.scrollWidth > el.clientWidth ? 'scroll' : '';\n const overflowX = el.scrollHeight > el.clientHeight ? 'scroll' : '';\n\n Object.assign(el.style, {\n position: 'absolute',\n top: `-${scrollY}px`,\n left: `-${scrollX}px`,\n right: '0',\n overflowY,\n overflowX,\n });\n setScrollLock(true);\n }, [elRef]);\n\n const disableScrollLock = React.useCallback<ScrollContextInterface['disableScrollLock']>(() => {\n const el = elRef.current;\n if (!el) {\n return;\n }\n\n const scrollY = el.style.top;\n const scrollX = el.style.left;\n\n clearDisableScrollStyle(el);\n el.scrollTo(-parseInt(scrollX || '0'), -parseInt(scrollY || '0'));\n setScrollLock(false);\n }, [elRef]);\n\n const scrollController = React.useMemo<ScrollContextInterface>(\n () => ({\n getScroll,\n scrollTo,\n isScrollLock,\n disableScrollLock,\n enableScrollLock,\n beforeScrollLockFnSetRef,\n }),\n [getScroll, scrollTo, isScrollLock, disableScrollLock, enableScrollLock],\n );\n\n return <ScrollContext.Provider value={scrollController}>{children}</ScrollContext.Provider>;\n};\n\n/**\n * Вызывает функцию effect, до блокировки прокрутки\n * @param effect функция, которая может возвращать функцию очистки\n * @param deps effect обновится только при изменении значений в списке.\n */\nexport const useScrollLockEffect = (effect: React.EffectCallback, deps: React.DependencyList) => {\n const destructorRef = React.useRef<ReturnType<React.EffectCallback>>(noop);\n const { isScrollLock, beforeScrollLockFnSetRef } = useScroll();\n\n // Изменяем effectCallback только при изменении deps\n const effectCallback = React.useCallback(() => {\n destructorRef.current = effect();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, deps);\n\n // Добавляем effectCallback в список функций, которые необходимо вызвать\n // до блокировки\n React.useEffect(() => {\n const beforeSet = beforeScrollLockFnSetRef?.current;\n if (!beforeSet) {\n return noop;\n }\n\n beforeSet.add(effectCallback);\n\n return () => {\n beforeSet.delete(effectCallback);\n };\n }, [beforeScrollLockFnSetRef, effectCallback]);\n\n // Вызываем сбрасывающую функцию, после отключения блокировки\n React.useEffect(() => {\n if (!isScrollLock && destructorRef.current) {\n destructorRef.current();\n }\n }, [isScrollLock]);\n};\n\nexport const useScrollLock = (enabled = true) => {\n const { enableScrollLock, disableScrollLock } = useScroll();\n useIsomorphicLayoutEffect(() => {\n if (enabled) {\n enableScrollLock();\n return disableScrollLock;\n }\n return noop;\n }, [enableScrollLock, disableScrollLock, enabled]);\n};\n"],"names":["ElementScrollController","GlobalScrollController","ScrollContext","useScroll","useScrollLock","useScrollLockEffect","clearDisableScrollStyle","node","Object","assign","style","position","top","left","right","overflowY","overflowX","getPageYOffsetWithoutKeyboardHeight","window","diffOfClientHeightAndViewportHeight","document","documentElement","clientHeight","innerHeight","pageYOffset","React","createContext","getScroll","x","y","scrollTo","noop","isScrollLock","enableScrollLock","disableScrollLock","useContext","children","useDOM","setScrollLock","useState","beforeScrollLockFnSetRef","useRef","Set","useCallback","pageXOffset","clamp","body","scrollWidth","innerWidth","scrollHeight","current","forEach","fn","scrollY","scrollX","clientWidth","parseInt","scrollController","useMemo","Provider","value","elRef","scrollLeft","scrollTop","el","effect","deps","destructorRef","effectCallback","useEffect","beforeSet","add","delete","enabled","useIsomorphicLayoutEffect"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/AppRoot/ScrollContext.tsx"],"sourcesContent":["import * as React from 'react';\nimport { noop } from '@vkontakte/vkjs';\nimport { clamp } from '../../helpers/math';\nimport { useDOM } from '../../lib/dom';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport { HasChildren } from '../../types';\n\nconst clearDisableScrollStyle = (node: HTMLElement) => {\n Object.assign(node.style, {\n position: '',\n top: '',\n left: '',\n right: '',\n overflowY: '',\n overflowX: '',\n });\n};\n\nconst getPageYOffsetWithoutKeyboardHeight = (window: Window) => {\n // Note: здесь расчёт на то, что `clientHeight` равен `window.innerHeight`.\n // Это достигается тем, что тегу `html` задали`height: 100%` и у него нет отступов сверху и снизу. Если есть отступы,\n // то надо задать `box-sizing: border-box`, чтобы они не учитывались.\n const diffOfClientHeightAndViewportHeight =\n window.document.documentElement.clientHeight - window.innerHeight;\n return window.pageYOffset - diffOfClientHeightAndViewportHeight;\n};\n\nexport interface ScrollContextInterface {\n getScroll(this: void): { x: number; y: number };\n scrollTo(this: void, x?: number, y?: number): void;\n isScrollLock: boolean;\n enableScrollLock(this: void): void;\n disableScrollLock(this: void): void;\n beforeScrollLockFnSetRef?: React.RefObject<Set<() => void>>;\n}\n\nexport const ScrollContext = React.createContext<ScrollContextInterface>({\n getScroll: () => ({ x: 0, y: 0 }),\n scrollTo: noop,\n isScrollLock: false,\n enableScrollLock: noop,\n disableScrollLock: noop,\n});\n\nexport const useScroll = () => React.useContext(ScrollContext);\n\nexport interface ScrollControllerProps extends HasChildren {\n elRef: React.RefObject<HTMLElement>;\n}\n\nexport const GlobalScrollController = ({ children }: ScrollControllerProps) => {\n const { window, document } = useDOM();\n const [isScrollLock, setScrollLock] = React.useState(false);\n const beforeScrollLockFnSetRef = React.useRef<Set<() => void>>(new Set());\n\n const getScroll = React.useCallback<ScrollContextInterface['getScroll']>(\n () => ({\n x: window!.pageXOffset,\n y: getPageYOffsetWithoutKeyboardHeight(window!),\n }),\n [window],\n );\n const scrollTo = React.useCallback<ScrollContextInterface['scrollTo']>(\n (x = 0, y = 0) => {\n // Some iOS versions do not normalize scroll — do it manually.\n window!.scrollTo(\n x ? clamp(x, 0, document!.body.scrollWidth - window!.innerWidth) : 0,\n y ? clamp(y, 0, document!.body.scrollHeight - window!.innerHeight) : 0,\n );\n },\n [document, window],\n );\n\n const enableScrollLock = React.useCallback<ScrollContextInterface['enableScrollLock']>(() => {\n beforeScrollLockFnSetRef.current.forEach((fn) => {\n fn();\n });\n\n const scrollY = window!.pageYOffset;\n const scrollX = window!.pageXOffset;\n const overflowY = window!.innerWidth > document!.documentElement.clientWidth ? 'scroll' : '';\n const overflowX = window!.innerHeight > document!.documentElement.clientHeight ? 'scroll' : '';\n\n Object.assign(document!.body.style, {\n position: 'fixed',\n top: `-${scrollY}px`,\n left: `-${scrollX}px`,\n right: '0',\n overflowY,\n overflowX,\n });\n setScrollLock(true);\n }, [document, window]);\n\n const disableScrollLock = React.useCallback<ScrollContextInterface['disableScrollLock']>(() => {\n const scrollY = document!.body.style.top;\n const scrollX = document!.body.style.left;\n\n clearDisableScrollStyle(document!.body);\n window!.scrollTo(-parseInt(scrollX || '0'), -parseInt(scrollY || '0'));\n setScrollLock(false);\n }, [document, window]);\n\n const scrollController = React.useMemo<ScrollContextInterface>(\n () => ({\n getScroll,\n scrollTo,\n isScrollLock,\n disableScrollLock,\n enableScrollLock,\n\n beforeScrollLockFnSetRef: beforeScrollLockFnSetRef,\n }),\n [getScroll, scrollTo, isScrollLock, disableScrollLock, enableScrollLock],\n );\n\n return <ScrollContext.Provider value={scrollController}>{children}</ScrollContext.Provider>;\n};\n\nexport const ElementScrollController = ({ elRef, children }: ScrollControllerProps) => {\n const [isScrollLock, setScrollLock] = React.useState(false);\n const beforeScrollLockFnSetRef = React.useRef<Set<() => void>>(new Set());\n\n const getScroll = React.useCallback<ScrollContextInterface['getScroll']>(\n () => ({\n x: elRef.current?.scrollLeft ?? 0,\n y: elRef.current?.scrollTop ?? 0,\n }),\n [elRef],\n );\n const scrollTo = React.useCallback<ScrollContextInterface['scrollTo']>(\n (x = 0, y = 0) => {\n const el = elRef.current;\n // Some iOS versions do not normalize scroll — do it manually.\n el?.scrollTo(\n x ? clamp(x, 0, el.scrollWidth - el.clientWidth) : 0,\n y ? clamp(y, 0, el.scrollHeight - el.clientHeight) : 0,\n );\n },\n [elRef],\n );\n\n const enableScrollLock = React.useCallback<ScrollContextInterface['enableScrollLock']>(() => {\n const el = elRef.current;\n if (!el) {\n return;\n }\n beforeScrollLockFnSetRef.current.forEach((fn) => {\n fn();\n });\n\n const scrollY = el.scrollTop;\n const scrollX = el.scrollLeft;\n const overflowY = el.scrollWidth > el.clientWidth ? 'scroll' : '';\n const overflowX = el.scrollHeight > el.clientHeight ? 'scroll' : '';\n\n Object.assign(el.style, {\n position: 'absolute',\n top: `-${scrollY}px`,\n left: `-${scrollX}px`,\n right: '0',\n overflowY,\n overflowX,\n });\n setScrollLock(true);\n }, [elRef]);\n\n const disableScrollLock = React.useCallback<ScrollContextInterface['disableScrollLock']>(() => {\n const el = elRef.current;\n if (!el) {\n return;\n }\n\n const scrollY = el.style.top;\n const scrollX = el.style.left;\n\n clearDisableScrollStyle(el);\n el.scrollTo(-parseInt(scrollX || '0'), -parseInt(scrollY || '0'));\n setScrollLock(false);\n }, [elRef]);\n\n const scrollController = React.useMemo<ScrollContextInterface>(\n () => ({\n getScroll,\n scrollTo,\n isScrollLock,\n disableScrollLock,\n enableScrollLock,\n beforeScrollLockFnSetRef,\n }),\n [getScroll, scrollTo, isScrollLock, disableScrollLock, enableScrollLock],\n );\n\n return <ScrollContext.Provider value={scrollController}>{children}</ScrollContext.Provider>;\n};\n\n/**\n * Вызывает функцию effect, до блокировки прокрутки\n * @param effect функция, которая может возвращать функцию очистки\n * @param deps effect обновится только при изменении значений в списке.\n */\nexport const useScrollLockEffect = (effect: React.EffectCallback, deps: React.DependencyList) => {\n const destructorRef = React.useRef<ReturnType<React.EffectCallback>>(noop);\n const { isScrollLock, beforeScrollLockFnSetRef } = useScroll();\n\n // Изменяем effectCallback только при изменении deps\n const effectCallback = React.useCallback(() => {\n destructorRef.current = effect();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, deps);\n\n // Добавляем effectCallback в список функций, которые необходимо вызвать\n // до блокировки\n React.useEffect(() => {\n const beforeSet = beforeScrollLockFnSetRef?.current;\n if (!beforeSet) {\n return noop;\n }\n\n beforeSet.add(effectCallback);\n\n return () => {\n beforeSet.delete(effectCallback);\n };\n }, [beforeScrollLockFnSetRef, effectCallback]);\n\n // Вызываем сбрасывающую функцию, после отключения блокировки\n React.useEffect(() => {\n if (!isScrollLock && destructorRef.current) {\n destructorRef.current();\n }\n }, [isScrollLock]);\n};\n\nexport const useScrollLock = (enabled = true) => {\n const { enableScrollLock, disableScrollLock, isScrollLock } = useScroll();\n useIsomorphicLayoutEffect(() => {\n if (enabled && !isScrollLock) {\n enableScrollLock();\n return disableScrollLock;\n }\n return noop;\n }, [enableScrollLock, disableScrollLock, enabled]);\n};\n"],"names":["ElementScrollController","GlobalScrollController","ScrollContext","useScroll","useScrollLock","useScrollLockEffect","clearDisableScrollStyle","node","Object","assign","style","position","top","left","right","overflowY","overflowX","getPageYOffsetWithoutKeyboardHeight","window","diffOfClientHeightAndViewportHeight","document","documentElement","clientHeight","innerHeight","pageYOffset","React","createContext","getScroll","x","y","scrollTo","noop","isScrollLock","enableScrollLock","disableScrollLock","useContext","children","useDOM","setScrollLock","useState","beforeScrollLockFnSetRef","useRef","Set","useCallback","pageXOffset","clamp","body","scrollWidth","innerWidth","scrollHeight","current","forEach","fn","scrollY","scrollX","clientWidth","parseInt","scrollController","useMemo","Provider","value","elRef","scrollLeft","scrollTop","el","effect","deps","destructorRef","effectCallback","useEffect","beforeSet","add","delete","enabled","useIsomorphicLayoutEffect"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AspectRatio.d.ts","sourceRoot":"","sources":["../../../../src/components/AspectRatio/AspectRatio.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AspectRatio.d.ts","sourceRoot":"","sources":["../../../../src/components/AspectRatio/AspectRatio.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAuB,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAI7E,MAAM,WAAW,gBAAiB,SAAQ,yBAAyB,CAAC,cAAc,CAAC;IACjF,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC;IAC1B;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,EAC1B,KAAK,EACL,IAAgB,EAChB,KAAK,EAAE,SAAS,EAChB,GAAG,KAAK,EACT,EAAE,gBAAgB,GAAG,GAAG,CAAC,OAAO,CAehC"}
|
|
@@ -7,6 +7,7 @@ export type ChipOptionLabel = React.ReactElement | string | number;
|
|
|
7
7
|
export type ChipOption = {
|
|
8
8
|
value: ChipOptionValue;
|
|
9
9
|
label: ChipOptionLabel;
|
|
10
|
+
disabled?: boolean;
|
|
10
11
|
[index: string]: any;
|
|
11
12
|
};
|
|
12
13
|
export interface ChipProps extends HasComponent, HasDataAttribute, HTMLAttributesWithRootRef<HTMLElement> {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/ChipsInputBase/types.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/ChipsInputBase/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/ChipsInputBase/types.ts"],"sourcesContent":["import * as React from 'react';\nimport type {\n HasAlign,\n HasComponent,\n HasDataAttribute,\n HasRef,\n HTMLAttributesWithRootRef,\n} from '../../types';\nimport { FormFieldProps } from '../FormField/FormField';\n\nexport type NavigateTo = 'first' | 'prev' | 'next' | 'last';\n\nexport type ChipOptionValue = string | number;\n\nexport type ChipOptionLabel = React.ReactElement | string | number;\n\nexport type ChipOption = {\n value: ChipOptionValue;\n label: ChipOptionLabel;\n [index: string]: any;\n};\n\nexport interface ChipProps\n extends HasComponent,\n HasDataAttribute,\n HTMLAttributesWithRootRef<HTMLElement> {\n value?: ChipOptionValue;\n removable?: boolean;\n disabled?: boolean;\n readOnly?: boolean;\n removeLabel?: string;\n before?: React.ReactNode;\n after?: React.ReactNode;\n onRemove?(event: React.MouseEvent, value: ChipOptionValue): void;\n}\n\nexport interface RenderChipProps extends ChipProps {\n label: ChipOptionLabel;\n}\n\nexport type RenderChip<O extends ChipOption = ChipOption> = (\n props: RenderChipProps,\n option: O,\n) => React.ReactNode;\n\nexport type GetOptionValue<O extends ChipOption = ChipOption> = (option: O) => ChipOptionValue;\n\nexport type GetOptionLabel<O extends ChipOption = ChipOption> = (option: O) => ChipOptionLabel;\n\nexport type GetNewOptionData<O extends ChipOption = ChipOption> = (\n value: ChipOptionValue,\n label: ChipOptionLabel,\n) => O;\n\nexport type OnChange<O extends ChipOption = ChipOption> = (value: O[]) => void;\n\nexport type OnInputChange = (event: React.ChangeEvent<HTMLInputElement>) => void;\n\n/**\n * @public\n */\nexport interface UseChipsInputBaseProps<O extends ChipOption = ChipOption> {\n disabled?: boolean;\n\n value?: O[];\n defaultValue?: O[];\n onChange?: OnChange<O>;\n\n inputValue?: string;\n defaultInputValue?: string;\n onInputChange?: OnInputChange;\n}\n\n/**\n * @private\n */\ntype UseChipsInputBaseOnlyNeededProps<O extends ChipOption = ChipOption> = Omit<\n UseChipsInputBaseProps<O>,\n 'onChange' | 'defaultValue' | 'defaultInputValue'\n>;\n\n/**\n * @public\n */\nexport interface ChipsInputBaseProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseOnlyNeededProps<O>,\n Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n keyof UseChipsInputBaseProps<O> | 'defaultChecked'\n >,\n HasRef<HTMLInputElement>,\n HasAlign {\n getRootRef?: React.Ref<HTMLDivElement>;\n /**\n * Добавляет значение в список на событие `onBlur`\n */\n addOnBlur?: boolean;\n /**\n * Render prop функция для возврата своего компонента.\n *\n * @default Используется [Chip](#/Chip)\n */\n renderChip?: RenderChip;\n}\n\n/**\n * @private\n */\nexport interface ChipsInputBasePrivateProps<O extends ChipOption = ChipOption>\n extends ChipsInputBaseProps<O>,\n Pick<FormFieldProps, 'mode' | 'status' | 'before' | 'after'> {\n onAddChipOption(value: O | string): void;\n onRemoveChipOption(value: O | ChipOptionValue): void;\n}\n"],"names":[],"mappings":";;;;;iEAAuB"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/ChipsInputBase/types.ts"],"sourcesContent":["import * as React from 'react';\nimport type {\n HasAlign,\n HasComponent,\n HasDataAttribute,\n HasRef,\n HTMLAttributesWithRootRef,\n} from '../../types';\nimport { FormFieldProps } from '../FormField/FormField';\n\nexport type NavigateTo = 'first' | 'prev' | 'next' | 'last';\n\nexport type ChipOptionValue = string | number;\n\nexport type ChipOptionLabel = React.ReactElement | string | number;\n\nexport type ChipOption = {\n value: ChipOptionValue;\n label: ChipOptionLabel;\n disabled?: boolean;\n [index: string]: any;\n};\n\nexport interface ChipProps\n extends HasComponent,\n HasDataAttribute,\n HTMLAttributesWithRootRef<HTMLElement> {\n value?: ChipOptionValue;\n removable?: boolean;\n disabled?: boolean;\n readOnly?: boolean;\n removeLabel?: string;\n before?: React.ReactNode;\n after?: React.ReactNode;\n onRemove?(event: React.MouseEvent, value: ChipOptionValue): void;\n}\n\nexport interface RenderChipProps extends ChipProps {\n label: ChipOptionLabel;\n}\n\nexport type RenderChip<O extends ChipOption = ChipOption> = (\n props: RenderChipProps,\n option: O,\n) => React.ReactNode;\n\nexport type GetOptionValue<O extends ChipOption = ChipOption> = (option: O) => ChipOptionValue;\n\nexport type GetOptionLabel<O extends ChipOption = ChipOption> = (option: O) => ChipOptionLabel;\n\nexport type GetNewOptionData<O extends ChipOption = ChipOption> = (\n value: ChipOptionValue,\n label: ChipOptionLabel,\n) => O;\n\nexport type OnChange<O extends ChipOption = ChipOption> = (value: O[]) => void;\n\nexport type OnInputChange = (event: React.ChangeEvent<HTMLInputElement>) => void;\n\n/**\n * @public\n */\nexport interface UseChipsInputBaseProps<O extends ChipOption = ChipOption> {\n disabled?: boolean;\n\n value?: O[];\n defaultValue?: O[];\n onChange?: OnChange<O>;\n\n inputValue?: string;\n defaultInputValue?: string;\n onInputChange?: OnInputChange;\n}\n\n/**\n * @private\n */\ntype UseChipsInputBaseOnlyNeededProps<O extends ChipOption = ChipOption> = Omit<\n UseChipsInputBaseProps<O>,\n 'onChange' | 'defaultValue' | 'defaultInputValue'\n>;\n\n/**\n * @public\n */\nexport interface ChipsInputBaseProps<O extends ChipOption = ChipOption>\n extends UseChipsInputBaseOnlyNeededProps<O>,\n Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n keyof UseChipsInputBaseProps<O> | 'defaultChecked'\n >,\n HasRef<HTMLInputElement>,\n HasAlign {\n getRootRef?: React.Ref<HTMLDivElement>;\n /**\n * Добавляет значение в список на событие `onBlur`\n */\n addOnBlur?: boolean;\n /**\n * Render prop функция для возврата своего компонента.\n *\n * @default Используется [Chip](#/Chip)\n */\n renderChip?: RenderChip;\n}\n\n/**\n * @private\n */\nexport interface ChipsInputBasePrivateProps<O extends ChipOption = ChipOption>\n extends ChipsInputBaseProps<O>,\n Pick<FormFieldProps, 'mode' | 'status' | 'before' | 'after'> {\n onAddChipOption(value: O | string): void;\n onRemoveChipOption(value: O | ChipOptionValue): void;\n}\n"],"names":[],"mappings":";;;;;iEAAuB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChipsSelect.d.ts","sourceRoot":"","sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAc/B,OAAO,KAAK,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE/E,OAAO,EAEL,KAAK,uBAAuB,EAC7B,MAAM,0CAA0C,CAAC;AAElD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAa7D,OAAO,EAAkB,KAAK,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"ChipsSelect.d.ts","sourceRoot":"","sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAc/B,OAAO,KAAK,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE/E,OAAO,EAEL,KAAK,uBAAuB,EAC7B,MAAM,0CAA0C,CAAC;AAElD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAa7D,OAAO,EAAkB,KAAK,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAuC5E,MAAM,WAAW,gBAAgB,CAAC,CAAC,SAAS,UAAU,CACpD,SAAQ,mBAAmB,CAAC,CAAC,CAAC,EAC5B,mBAAmB,CAAC,CAAC,CAAC,EACtB,IAAI,CAAC,cAAc,EAAE,QAAQ,GAAG,MAAM,GAAG,QAAQ,CAAC;IACpD,SAAS,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC;IAC7B;;OAEG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB;;OAEG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB,YAAY,CAAC,CAAC,KAAK,EAAE,uBAAuB,EAAE,MAAM,EAAE,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC;IAC1E;;OAEG;IACH,aAAa,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC;CAChF;AAED;;GAEG;AACH,eAAO,MAAM,WAAW,gqBAwZvB,CAAC"}
|
|
@@ -30,6 +30,26 @@ const stylesDropdownVerticalPlacement = {
|
|
|
30
30
|
top: "vkuiChipsSelect--pop-up",
|
|
31
31
|
bottom: "vkuiChipsSelect--pop-down"
|
|
32
32
|
};
|
|
33
|
+
const findIndexAfter = (options = [], startIndex = -1)=>{
|
|
34
|
+
if (startIndex >= options.length - 1) {
|
|
35
|
+
return -1;
|
|
36
|
+
}
|
|
37
|
+
return options.findIndex((option, i)=>i > startIndex && (!(0, _constants1.isNotServicePreset)(option) || !option.disabled));
|
|
38
|
+
};
|
|
39
|
+
const findIndexBefore = (options = [], endIndex = options.length)=>{
|
|
40
|
+
let result = -1;
|
|
41
|
+
if (endIndex <= 0) {
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
for(let i = endIndex - 1; i >= 0; i--){
|
|
45
|
+
let option = options[i];
|
|
46
|
+
if (!(0, _constants1.isNotServicePreset)(option) || !option.disabled) {
|
|
47
|
+
result = i;
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
52
|
+
};
|
|
33
53
|
const ChipsSelect = (_param)=>{
|
|
34
54
|
var { // FormFieldProps
|
|
35
55
|
id: labelledbyId, getRootRef, className, status = 'default', icon: dropdownIconProp, onChangeStart, // CustomSelectDropdownProps
|
|
@@ -151,15 +171,21 @@ const ChipsSelect = (_param)=>{
|
|
|
151
171
|
if (index === oldIndex) {
|
|
152
172
|
/* istanbul ignore next: нет представления как воспроизвести */ return;
|
|
153
173
|
}
|
|
174
|
+
const option = options[index];
|
|
175
|
+
if ((0, _constants1.isNotServicePreset)(option) && option.disabled) {
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
154
178
|
scrollToElement(index);
|
|
155
179
|
setFocusedOptionIndex(index);
|
|
156
180
|
};
|
|
157
181
|
const focusOption = (nextIndex, type)=>{
|
|
158
182
|
let index = nextIndex === null ? -1 : nextIndex;
|
|
159
183
|
if (type === _constants1.FOCUS_ACTION_NEXT) {
|
|
160
|
-
|
|
184
|
+
const nextIndex = findIndexAfter(options, index);
|
|
185
|
+
index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index
|
|
161
186
|
} else if (type === _constants1.FOCUS_ACTION_PREV) {
|
|
162
|
-
|
|
187
|
+
const beforeIndex = findIndexBefore(options, index);
|
|
188
|
+
index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index
|
|
163
189
|
}
|
|
164
190
|
focusOptionByIndex(index, focusedOptionIndex);
|
|
165
191
|
};
|
|
@@ -176,7 +202,7 @@ const ChipsSelect = (_param)=>{
|
|
|
176
202
|
event.preventDefault();
|
|
177
203
|
if (!opened) {
|
|
178
204
|
setOpened(true);
|
|
179
|
-
|
|
205
|
+
focusOption(null, _constants1.FOCUS_ACTION_NEXT);
|
|
180
206
|
} else {
|
|
181
207
|
focusOption(focusedOptionIndex, event.key === _accessibility.Keys.ARROW_UP ? _constants1.FOCUS_ACTION_PREV : _constants1.FOCUS_ACTION_NEXT);
|
|
182
208
|
}
|
|
@@ -312,6 +338,7 @@ const ChipsSelect = (_param)=>{
|
|
|
312
338
|
key: `${typeof option.value}-${option.label}`
|
|
313
339
|
}, renderOption({
|
|
314
340
|
id: dropdownItemId,
|
|
341
|
+
disabled: option.disabled,
|
|
315
342
|
hovered: focusedOption ? getOptionValue(option) === getOptionValue(focusedOption) : false,
|
|
316
343
|
children: option.label,
|
|
317
344
|
selected: !!value.find((selectedOption)=>getOptionValue(selectedOption) === getOptionValue(option)),
|
|
@@ -321,6 +348,9 @@ const ChipsSelect = (_param)=>{
|
|
|
321
348
|
}
|
|
322
349
|
},
|
|
323
350
|
onMouseDown (event) {
|
|
351
|
+
if (option.disabled) {
|
|
352
|
+
return;
|
|
353
|
+
}
|
|
324
354
|
if (onChangeStart) {
|
|
325
355
|
onChangeStart(event, option);
|
|
326
356
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useGlobalOnClickOutside } from '../../hooks/useGlobalOnClickOutside';\nimport { Keys } from '../../lib/accessibility';\nimport type { Placement } from '../../lib/floating';\nimport { defaultFilterFn } from '../../lib/select';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport {\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n renderChipDefault,\n} from '../ChipsInputBase/constants';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n type CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport {\n DEFAULT_EMPTY_TEXT,\n DEFAULT_SELECTED_BEHAVIOR,\n FOCUS_ACTION_NEXT,\n FOCUS_ACTION_PREV,\n isCreateNewOptionPreset,\n isEmptyOptionPreset,\n isNotServicePreset,\n renderOptionDefault,\n} from './constants';\nimport type { FocusActionType } from './types';\nimport { useChipsSelect, type UseChipsSelectProps } from './useChipsSelect';\nimport styles from './ChipsSelect.module.css';\n\nconst stylesDropdownVerticalPlacement = {\n top: styles['ChipsSelect--pop-up'],\n bottom: styles['ChipsSelect--pop-down'],\n} as const;\n\nexport interface ChipsSelectProps<O extends ChipOption>\n extends ChipsInputBaseProps<O>,\n UseChipsSelectProps<O>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before'> {\n placement?: 'top' | 'bottom';\n /**\n * Отрисовка Spinner вместо списка опций в выпадающем списке\n */\n fetching?: boolean;\n /**\n * Закрытие выпадающего списка после выбора элемента\n */\n closeAfterSelect?: boolean;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n dropdownAutoWidth?: boolean;\n /**\n * Принудительно использовать портал.\n */\n forceDropdownPortal?: boolean;\n /**\n * Передача `data-testid`.\n */\n dropdownTestId?: string;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Добавляет значение в список на событие `onBlur` (использовать вместе с `creatable`)\n */\n addOnBlur?: boolean;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n\n renderOption?(props: CustomSelectOptionProps, option: O): React.ReactNode;\n /**\n * Событие срабатывающее перед onChange\n */\n onChangeStart?(event: React.MouseEvent | React.KeyboardEvent, option: O): void;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsSelect\n */\nexport const ChipsSelect = <Option extends ChipOption>({\n // FormFieldProps\n id: labelledbyId,\n getRootRef,\n className,\n status = 'default',\n icon: dropdownIconProp,\n onChangeStart,\n\n // CustomSelectDropdownProps\n options: optionsProp,\n placement: placementProp = 'bottom',\n closeAfterSelect = true,\n selectedBehavior = DEFAULT_SELECTED_BEHAVIOR,\n emptyText = DEFAULT_EMPTY_TEXT,\n creatable = false,\n fetching = false,\n dropdownAutoWidth,\n forceDropdownPortal,\n noMaxHeight = false,\n filterFn = defaultFilterFn,\n dropdownTestId,\n\n // ChipsInputProps\n getRef,\n value: valueProp,\n defaultValue,\n inputValue: inputValueProp,\n defaultInputValue,\n disabled,\n readOnly,\n getOptionValue = getOptionValueDefault,\n getOptionLabel = getOptionLabelDefault,\n getNewOptionData = getNewOptionDataDefault,\n renderChip = renderChipDefault,\n renderOption = renderOptionDefault,\n onChange,\n onFocus: onFocusProp,\n onInputChange: onInputChangeProp,\n onBlur: onBlurProp,\n onKeyDown: onKeyDownProp,\n ...restProps\n}: ChipsSelectProps<Option>) => {\n const {\n // Связано с ChipsInputProps\n // option\n value,\n addOptionFromInput,\n addOption,\n removeOption,\n // input\n inputRef: inputRefHook,\n inputValue,\n clearInput,\n onInputChange,\n\n // Связано с CustomSelectDropdownProps\n options,\n opened,\n setOpened,\n focusedOption,\n focusedOptionIndex,\n setFocusedOption,\n setFocusedOptionIndex,\n } = useChipsSelect({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue,\n onInputChange: onInputChangeProp,\n\n // dropdown\n options: optionsProp,\n emptyText,\n creatable,\n filterFn,\n selectedBehavior,\n\n // other\n disabled,\n });\n\n // Связано с ChipsInputProps\n const rootRef = useExternRef(getRootRef);\n const inputRef = useExternRef(getRef, inputRefHook);\n\n // Связано с CustomSelectDropdownProps\n const [dropdownVerticalPlacement, setDropdownVerticalPlacement] = React.useState<\n Extract<Placement, 'top' | 'bottom'> | undefined\n >(placementProp);\n const dropdownId = React.useId();\n const dropdownCurrentItemId =\n focusedOptionIndex !== null ? `${dropdownId}-${focusedOptionIndex}` : undefined;\n const dropdownScrollBoxRef = React.useRef<HTMLDivElement>(null);\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onFocusProp) {\n onFocusProp(event);\n }\n\n if (!readOnly) {\n setOpened(true);\n setFocusedOptionIndex(null);\n }\n };\n\n const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlurProp) {\n onBlurProp(event);\n }\n\n // Не добавляем значение, если его нужно выбрать строго из списка\n if (!readOnly && !event.defaultPrevented && !creatable) {\n event.preventDefault();\n }\n };\n\n const chipsSelectOptions = React.useRef<HTMLElement[]>([]).current;\n\n const scrollToElement = (index: number, center = false) => {\n const dropdown = dropdownScrollBoxRef.current;\n const item = chipsSelectOptions[index];\n\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n /* istanbul ignore next: нет представления как воспроизвести */\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n };\n\n const focusOptionByIndex = (index: number, oldIndex: number | null) => {\n const length = options.length;\n\n if (index < 0) {\n index = length - 1;\n } else if (index >= length) {\n index = 0;\n }\n\n if (index === oldIndex) {\n /* istanbul ignore next: нет представления как воспроизвести */\n return;\n }\n\n scrollToElement(index);\n setFocusedOptionIndex(index);\n };\n\n const focusOption = (nextIndex: number | null, type: FocusActionType) => {\n let index = nextIndex === null ? -1 : nextIndex;\n\n if (type === FOCUS_ACTION_NEXT) {\n index = index + 1;\n } else if (type === FOCUS_ACTION_PREV) {\n index = index - 1;\n }\n\n focusOptionByIndex(index, focusedOptionIndex);\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (onKeyDownProp) {\n onKeyDownProp(event);\n }\n\n if (event.defaultPrevented || readOnly) {\n return;\n }\n\n switch (event.key) {\n case Keys.ARROW_UP:\n case Keys.ARROW_DOWN:\n event.preventDefault();\n\n if (!opened) {\n setOpened(true);\n setFocusedOptionIndex(0);\n } else {\n focusOption(\n focusedOptionIndex,\n event.key === Keys.ARROW_UP ? FOCUS_ACTION_PREV : FOCUS_ACTION_NEXT,\n );\n }\n break;\n case Keys.ENTER: {\n if (!opened) {\n break;\n }\n if (focusedOptionIndex != null) {\n const foundOption = options[focusedOptionIndex];\n if (foundOption && isNotServicePreset(foundOption)) {\n event.preventDefault();\n\n if (onChangeStart) {\n onChangeStart(event, foundOption);\n }\n\n addOption(foundOption);\n setFocusedOptionIndex(null);\n clearInput();\n if (closeAfterSelect) {\n setOpened(false);\n }\n\n break;\n }\n }\n\n if (!creatable) {\n event.preventDefault();\n }\n break;\n }\n case Keys.ESCAPE:\n case Keys.TAB:\n if (opened) {\n setOpened(false);\n }\n }\n };\n\n React.useEffect(() => {\n if (focusedOptionIndex === null) {\n setFocusedOption(null);\n } else {\n const foundFocusedOptionIndex = options[focusedOptionIndex];\n\n if (foundFocusedOptionIndex && isNotServicePreset(foundFocusedOptionIndex)) {\n setFocusedOption(foundFocusedOptionIndex);\n }\n }\n }, [options, focusedOptionIndex, setFocusedOption]);\n\n const onDropdownPlacementChange = React.useCallback((placement: Placement) => {\n /* istanbul ignore next: */\n if (placement.startsWith('top')) {\n setDropdownVerticalPlacement('top');\n } else if (placement.startsWith('bottom')) {\n setDropdownVerticalPlacement('bottom');\n }\n }, []);\n\n const onDropdownMouseLeave = React.useCallback(() => {\n setFocusedOptionIndex(null);\n }, [setFocusedOptionIndex]);\n\n const handleClickOutside = React.useCallback(() => {\n setOpened(false);\n }, [setOpened]);\n\n useGlobalOnClickOutside(\n handleClickOutside,\n opened ? rootRef : null,\n opened ? dropdownScrollBoxRef : null,\n );\n\n return (\n <>\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n readOnly={readOnly}\n // FormFieldProps\n id={labelledbyId}\n getRootRef={rootRef}\n className={classNames(\n styles['ChipsSelect'],\n opened &&\n dropdownVerticalPlacement &&\n stylesDropdownVerticalPlacement[dropdownVerticalPlacement],\n className,\n )}\n status={status}\n after={dropdownIconProp || <DropdownIcon opened={opened} />}\n // option\n value={value}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n renderChip={renderChip}\n // input\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n // a11y\n role=\"combobox\"\n aria-expanded={opened}\n aria-autocomplete=\"list\"\n aria-controls={opened ? dropdownId : undefined}\n aria-activedescendant={opened ? dropdownCurrentItemId : undefined}\n aria-haspopup=\"listbox\"\n />\n {opened && (\n <CustomSelectDropdown\n data-testid={dropdownTestId}\n targetRef={rootRef}\n placement={placementProp}\n scrollBoxRef={dropdownScrollBoxRef}\n onPlacementChange={onDropdownPlacementChange}\n onMouseLeave={onDropdownMouseLeave}\n fetching={fetching}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n noMaxHeight={noMaxHeight}\n // a11y\n id={dropdownId}\n role=\"listbox\"\n aria-labelledby={labelledbyId}\n >\n {options.map((option, index) => {\n const dropdownItemId = `${dropdownId}-${index}`;\n\n if (isEmptyOptionPreset(option)) {\n return (\n <Footnote key=\"empty-text\" className={styles['ChipsSelect__empty']}>\n {option.placeholder}\n </Footnote>\n );\n }\n if (isCreateNewOptionPreset(option)) {\n return (\n <CustomSelectOption\n key=\"create-new-option\"\n id={dropdownItemId}\n hovered={focusedOptionIndex === index}\n onMouseDown={() => addOptionFromInput(inputValue)}\n onMouseEnter={() => setFocusedOptionIndex(index)}\n >\n {option.actionText}\n </CustomSelectOption>\n );\n }\n return (\n <React.Fragment key={`${typeof option.value}-${option.label}`}>\n {renderOption(\n {\n id: dropdownItemId,\n hovered: focusedOption\n ? getOptionValue(option) === getOptionValue(focusedOption)\n : false,\n children: option.label,\n selected: !!value.find(\n (selectedOption: Option) =>\n getOptionValue(selectedOption) === getOptionValue(option),\n ),\n getRootRef(node) {\n if (node) {\n chipsSelectOptions[index] = node;\n }\n },\n onMouseDown(event: React.MouseEvent<HTMLDivElement>) {\n if (onChangeStart) {\n onChangeStart(event, option);\n }\n\n if (!event.defaultPrevented) {\n closeAfterSelect && setOpened(false);\n addOption(option);\n clearInput();\n }\n },\n onMouseEnter() {\n setFocusedOptionIndex(index);\n },\n },\n option,\n )}\n </React.Fragment>\n );\n })}\n </CustomSelectDropdown>\n )}\n </>\n );\n};\n"],"names":["ChipsSelect","stylesDropdownVerticalPlacement","top","bottom","id","labelledbyId","getRootRef","className","status","icon","dropdownIconProp","onChangeStart","options","optionsProp","placement","placementProp","closeAfterSelect","selectedBehavior","DEFAULT_SELECTED_BEHAVIOR","emptyText","DEFAULT_EMPTY_TEXT","creatable","fetching","dropdownAutoWidth","forceDropdownPortal","noMaxHeight","filterFn","defaultFilterFn","dropdownTestId","getRef","value","valueProp","defaultValue","inputValue","inputValueProp","defaultInputValue","disabled","readOnly","getOptionValue","getOptionValueDefault","getOptionLabel","getOptionLabelDefault","getNewOptionData","getNewOptionDataDefault","renderChip","renderChipDefault","renderOption","renderOptionDefault","onChange","onFocus","onFocusProp","onInputChange","onInputChangeProp","onBlur","onBlurProp","onKeyDown","onKeyDownProp","restProps","addOptionFromInput","addOption","removeOption","inputRef","inputRefHook","clearInput","opened","setOpened","focusedOption","focusedOptionIndex","setFocusedOption","setFocusedOptionIndex","useChipsSelect","rootRef","useExternRef","dropdownVerticalPlacement","setDropdownVerticalPlacement","React","useState","dropdownId","useId","dropdownCurrentItemId","undefined","dropdownScrollBoxRef","useRef","handleFocus","event","handleBlur","defaultPrevented","preventDefault","chipsSelectOptions","current","scrollToElement","index","center","dropdown","item","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","oldIndex","length","focusOption","nextIndex","type","FOCUS_ACTION_NEXT","FOCUS_ACTION_PREV","handleKeyDown","key","Keys","ARROW_UP","ARROW_DOWN","ENTER","foundOption","isNotServicePreset","ESCAPE","TAB","useEffect","foundFocusedOptionIndex","onDropdownPlacementChange","useCallback","startsWith","onDropdownMouseLeave","handleClickOutside","useGlobalOnClickOutside","ChipsInputBase","classNames","after","DropdownIcon","onAddChipOption","onRemoveChipOption","role","aria-expanded","aria-autocomplete","aria-controls","aria-activedescendant","aria-haspopup","CustomSelectDropdown","data-testid","targetRef","scrollBoxRef","onPlacementChange","onMouseLeave","autoWidth","forcePortal","aria-labelledby","map","option","dropdownItemId","isEmptyOptionPreset","Footnote","placeholder","isCreateNewOptionPreset","CustomSelectOption","hovered","onMouseDown","onMouseEnter","actionText","Fragment","label","children","selected","find","selectedOption","node"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/ChipsSelect/ChipsSelect.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useGlobalOnClickOutside } from '../../hooks/useGlobalOnClickOutside';\nimport { Keys } from '../../lib/accessibility';\nimport type { Placement } from '../../lib/floating';\nimport { defaultFilterFn } from '../../lib/select';\nimport { ChipsInputBase } from '../ChipsInputBase/ChipsInputBase';\nimport {\n getNewOptionDataDefault,\n getOptionLabelDefault,\n getOptionValueDefault,\n renderChipDefault,\n} from '../ChipsInputBase/constants';\nimport type { ChipOption, ChipsInputBaseProps } from '../ChipsInputBase/types';\nimport { CustomSelectDropdown } from '../CustomSelectDropdown/CustomSelectDropdown';\nimport {\n CustomSelectOption,\n type CustomSelectOptionProps,\n} from '../CustomSelectOption/CustomSelectOption';\nimport { DropdownIcon } from '../DropdownIcon/DropdownIcon';\nimport type { FormFieldProps } from '../FormField/FormField';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport {\n DEFAULT_EMPTY_TEXT,\n DEFAULT_SELECTED_BEHAVIOR,\n FOCUS_ACTION_NEXT,\n FOCUS_ACTION_PREV,\n isCreateNewOptionPreset,\n isEmptyOptionPreset,\n isNotServicePreset,\n renderOptionDefault,\n} from './constants';\nimport type { FocusActionType, OptionPreset } from './types';\nimport { useChipsSelect, type UseChipsSelectProps } from './useChipsSelect';\nimport styles from './ChipsSelect.module.css';\n\nconst stylesDropdownVerticalPlacement = {\n top: styles['ChipsSelect--pop-up'],\n bottom: styles['ChipsSelect--pop-down'],\n} as const;\n\nconst findIndexAfter = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\n startIndex = -1,\n) => {\n if (startIndex >= options.length - 1) {\n return -1;\n }\n return options.findIndex(\n (option, i) => i > startIndex && (!isNotServicePreset(option) || !option.disabled),\n );\n};\n\nconst findIndexBefore = <O extends ChipOption>(\n options: Array<OptionPreset<O>> = [],\n endIndex: number = options.length,\n) => {\n let result = -1;\n if (endIndex <= 0) {\n return result;\n }\n for (let i = endIndex - 1; i >= 0; i--) {\n let option = options[i];\n\n if (!isNotServicePreset(option) || !option.disabled) {\n result = i;\n break;\n }\n }\n return result;\n};\n\nexport interface ChipsSelectProps<O extends ChipOption>\n extends ChipsInputBaseProps<O>,\n UseChipsSelectProps<O>,\n Pick<FormFieldProps, 'status' | 'mode' | 'before'> {\n placement?: 'top' | 'bottom';\n /**\n * Отрисовка Spinner вместо списка опций в выпадающем списке\n */\n fetching?: boolean;\n /**\n * Закрытие выпадающего списка после выбора элемента\n */\n closeAfterSelect?: boolean;\n /**\n * Ширина раскрывающегося списка зависит от контента\n */\n dropdownAutoWidth?: boolean;\n /**\n * Принудительно использовать портал.\n */\n forceDropdownPortal?: boolean;\n /**\n * Передача `data-testid`.\n */\n dropdownTestId?: string;\n /**\n * Иконка раскрывающегося списка\n */\n icon?: React.ReactNode;\n /**\n * Добавляет значение в список на событие `onBlur` (использовать вместе с `creatable`)\n */\n addOnBlur?: boolean;\n /**\n * Отключает максимальную высоту по умолчанию\n */\n noMaxHeight?: boolean;\n\n renderOption?(props: CustomSelectOptionProps, option: O): React.ReactNode;\n /**\n * Событие срабатывающее перед onChange\n */\n onChangeStart?(event: React.MouseEvent | React.KeyboardEvent, option: O): void;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/ChipsSelect\n */\nexport const ChipsSelect = <Option extends ChipOption>({\n // FormFieldProps\n id: labelledbyId,\n getRootRef,\n className,\n status = 'default',\n icon: dropdownIconProp,\n onChangeStart,\n\n // CustomSelectDropdownProps\n options: optionsProp,\n placement: placementProp = 'bottom',\n closeAfterSelect = true,\n selectedBehavior = DEFAULT_SELECTED_BEHAVIOR,\n emptyText = DEFAULT_EMPTY_TEXT,\n creatable = false,\n fetching = false,\n dropdownAutoWidth,\n forceDropdownPortal,\n noMaxHeight = false,\n filterFn = defaultFilterFn,\n dropdownTestId,\n\n // ChipsInputProps\n getRef,\n value: valueProp,\n defaultValue,\n inputValue: inputValueProp,\n defaultInputValue,\n disabled,\n readOnly,\n getOptionValue = getOptionValueDefault,\n getOptionLabel = getOptionLabelDefault,\n getNewOptionData = getNewOptionDataDefault,\n renderChip = renderChipDefault,\n renderOption = renderOptionDefault,\n onChange,\n onFocus: onFocusProp,\n onInputChange: onInputChangeProp,\n onBlur: onBlurProp,\n onKeyDown: onKeyDownProp,\n ...restProps\n}: ChipsSelectProps<Option>) => {\n const {\n // Связано с ChipsInputProps\n // option\n value,\n addOptionFromInput,\n addOption,\n removeOption,\n // input\n inputRef: inputRefHook,\n inputValue,\n clearInput,\n onInputChange,\n\n // Связано с CustomSelectDropdownProps\n options,\n opened,\n setOpened,\n focusedOption,\n focusedOptionIndex,\n setFocusedOption,\n setFocusedOptionIndex,\n } = useChipsSelect({\n // option\n value: valueProp,\n defaultValue,\n onChange,\n getOptionValue,\n getOptionLabel,\n getNewOptionData,\n\n // input\n inputValue: inputValueProp,\n defaultInputValue,\n onInputChange: onInputChangeProp,\n\n // dropdown\n options: optionsProp,\n emptyText,\n creatable,\n filterFn,\n selectedBehavior,\n\n // other\n disabled,\n });\n\n // Связано с ChipsInputProps\n const rootRef = useExternRef(getRootRef);\n const inputRef = useExternRef(getRef, inputRefHook);\n\n // Связано с CustomSelectDropdownProps\n const [dropdownVerticalPlacement, setDropdownVerticalPlacement] = React.useState<\n Extract<Placement, 'top' | 'bottom'> | undefined\n >(placementProp);\n const dropdownId = React.useId();\n const dropdownCurrentItemId =\n focusedOptionIndex !== null ? `${dropdownId}-${focusedOptionIndex}` : undefined;\n const dropdownScrollBoxRef = React.useRef<HTMLDivElement>(null);\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onFocusProp) {\n onFocusProp(event);\n }\n\n if (!readOnly) {\n setOpened(true);\n setFocusedOptionIndex(null);\n }\n };\n\n const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n if (onBlurProp) {\n onBlurProp(event);\n }\n\n // Не добавляем значение, если его нужно выбрать строго из списка\n if (!readOnly && !event.defaultPrevented && !creatable) {\n event.preventDefault();\n }\n };\n\n const chipsSelectOptions = React.useRef<HTMLElement[]>([]).current;\n\n const scrollToElement = (index: number, center = false) => {\n const dropdown = dropdownScrollBoxRef.current;\n const item = chipsSelectOptions[index];\n\n /* istanbul ignore if: невозможный кейс (в SSR вызова этой функции не будет) */\n if (!item || !dropdown) {\n return;\n }\n\n const dropdownHeight = dropdown.offsetHeight;\n const scrollTop = dropdown.scrollTop;\n const itemTop = item.offsetTop;\n const itemHeight = item.offsetHeight;\n\n /* istanbul ignore next: нет представления как воспроизвести */\n if (center) {\n dropdown.scrollTop = itemTop - dropdownHeight / 2 + itemHeight / 2;\n } else if (itemTop + itemHeight > dropdownHeight + scrollTop) {\n dropdown.scrollTop = itemTop - dropdownHeight + itemHeight;\n } else if (itemTop < scrollTop) {\n dropdown.scrollTop = itemTop;\n }\n };\n\n const focusOptionByIndex = (index: number, oldIndex: number | null) => {\n const length = options.length;\n\n if (index < 0) {\n index = length - 1;\n } else if (index >= length) {\n index = 0;\n }\n\n if (index === oldIndex) {\n /* istanbul ignore next: нет представления как воспроизвести */\n return;\n }\n\n const option = options[index];\n\n if (isNotServicePreset(option) && option.disabled) {\n return;\n }\n\n scrollToElement(index);\n setFocusedOptionIndex(index);\n };\n\n const focusOption = (nextIndex: number | null, type: FocusActionType) => {\n let index = nextIndex === null ? -1 : nextIndex;\n\n if (type === FOCUS_ACTION_NEXT) {\n const nextIndex = findIndexAfter(options, index);\n index = nextIndex === -1 ? findIndexAfter(options) : nextIndex; // Следующий за index или первый валидный до index\n } else if (type === FOCUS_ACTION_PREV) {\n const beforeIndex = findIndexBefore(options, index);\n index = beforeIndex === -1 ? findIndexBefore(options) : beforeIndex; // Предшествующий index или последний валидный после index\n }\n\n focusOptionByIndex(index, focusedOptionIndex);\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (onKeyDownProp) {\n onKeyDownProp(event);\n }\n\n if (event.defaultPrevented || readOnly) {\n return;\n }\n\n switch (event.key) {\n case Keys.ARROW_UP:\n case Keys.ARROW_DOWN:\n event.preventDefault();\n\n if (!opened) {\n setOpened(true);\n focusOption(null, FOCUS_ACTION_NEXT);\n } else {\n focusOption(\n focusedOptionIndex,\n event.key === Keys.ARROW_UP ? FOCUS_ACTION_PREV : FOCUS_ACTION_NEXT,\n );\n }\n break;\n case Keys.ENTER: {\n if (!opened) {\n break;\n }\n if (focusedOptionIndex != null) {\n const foundOption = options[focusedOptionIndex];\n if (foundOption && isNotServicePreset(foundOption)) {\n event.preventDefault();\n\n if (onChangeStart) {\n onChangeStart(event, foundOption);\n }\n\n addOption(foundOption);\n setFocusedOptionIndex(null);\n clearInput();\n if (closeAfterSelect) {\n setOpened(false);\n }\n\n break;\n }\n }\n\n if (!creatable) {\n event.preventDefault();\n }\n break;\n }\n case Keys.ESCAPE:\n case Keys.TAB:\n if (opened) {\n setOpened(false);\n }\n }\n };\n\n React.useEffect(() => {\n if (focusedOptionIndex === null) {\n setFocusedOption(null);\n } else {\n const foundFocusedOptionIndex = options[focusedOptionIndex];\n\n if (foundFocusedOptionIndex && isNotServicePreset(foundFocusedOptionIndex)) {\n setFocusedOption(foundFocusedOptionIndex);\n }\n }\n }, [options, focusedOptionIndex, setFocusedOption]);\n\n const onDropdownPlacementChange = React.useCallback((placement: Placement) => {\n /* istanbul ignore next: */\n if (placement.startsWith('top')) {\n setDropdownVerticalPlacement('top');\n } else if (placement.startsWith('bottom')) {\n setDropdownVerticalPlacement('bottom');\n }\n }, []);\n\n const onDropdownMouseLeave = React.useCallback(() => {\n setFocusedOptionIndex(null);\n }, [setFocusedOptionIndex]);\n\n const handleClickOutside = React.useCallback(() => {\n setOpened(false);\n }, [setOpened]);\n\n useGlobalOnClickOutside(\n handleClickOutside,\n opened ? rootRef : null,\n opened ? dropdownScrollBoxRef : null,\n );\n\n return (\n <>\n <ChipsInputBase\n {...restProps}\n disabled={disabled}\n readOnly={readOnly}\n // FormFieldProps\n id={labelledbyId}\n getRootRef={rootRef}\n className={classNames(\n styles['ChipsSelect'],\n opened &&\n dropdownVerticalPlacement &&\n stylesDropdownVerticalPlacement[dropdownVerticalPlacement],\n className,\n )}\n status={status}\n after={dropdownIconProp || <DropdownIcon opened={opened} />}\n // option\n value={value}\n onAddChipOption={addOptionFromInput}\n onRemoveChipOption={removeOption}\n renderChip={renderChip}\n // input\n getRef={inputRef}\n inputValue={inputValue}\n onInputChange={onInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n // a11y\n role=\"combobox\"\n aria-expanded={opened}\n aria-autocomplete=\"list\"\n aria-controls={opened ? dropdownId : undefined}\n aria-activedescendant={opened ? dropdownCurrentItemId : undefined}\n aria-haspopup=\"listbox\"\n />\n {opened && (\n <CustomSelectDropdown\n data-testid={dropdownTestId}\n targetRef={rootRef}\n placement={placementProp}\n scrollBoxRef={dropdownScrollBoxRef}\n onPlacementChange={onDropdownPlacementChange}\n onMouseLeave={onDropdownMouseLeave}\n fetching={fetching}\n autoWidth={dropdownAutoWidth}\n forcePortal={forceDropdownPortal}\n noMaxHeight={noMaxHeight}\n // a11y\n id={dropdownId}\n role=\"listbox\"\n aria-labelledby={labelledbyId}\n >\n {options.map((option, index) => {\n const dropdownItemId = `${dropdownId}-${index}`;\n\n if (isEmptyOptionPreset(option)) {\n return (\n <Footnote key=\"empty-text\" className={styles['ChipsSelect__empty']}>\n {option.placeholder}\n </Footnote>\n );\n }\n if (isCreateNewOptionPreset(option)) {\n return (\n <CustomSelectOption\n key=\"create-new-option\"\n id={dropdownItemId}\n hovered={focusedOptionIndex === index}\n onMouseDown={() => addOptionFromInput(inputValue)}\n onMouseEnter={() => setFocusedOptionIndex(index)}\n >\n {option.actionText}\n </CustomSelectOption>\n );\n }\n return (\n <React.Fragment key={`${typeof option.value}-${option.label}`}>\n {renderOption(\n {\n id: dropdownItemId,\n disabled: option.disabled,\n hovered: focusedOption\n ? getOptionValue(option) === getOptionValue(focusedOption)\n : false,\n children: option.label,\n selected: !!value.find(\n (selectedOption: Option) =>\n getOptionValue(selectedOption) === getOptionValue(option),\n ),\n getRootRef(node) {\n if (node) {\n chipsSelectOptions[index] = node;\n }\n },\n onMouseDown(event: React.MouseEvent<HTMLDivElement>) {\n if (option.disabled) {\n return;\n }\n if (onChangeStart) {\n onChangeStart(event, option);\n }\n\n if (!event.defaultPrevented) {\n closeAfterSelect && setOpened(false);\n addOption(option);\n clearInput();\n }\n },\n onMouseEnter() {\n setFocusedOptionIndex(index);\n },\n },\n option,\n )}\n </React.Fragment>\n );\n })}\n </CustomSelectDropdown>\n )}\n </>\n );\n};\n"],"names":["ChipsSelect","stylesDropdownVerticalPlacement","top","bottom","findIndexAfter","options","startIndex","length","findIndex","option","i","isNotServicePreset","disabled","findIndexBefore","endIndex","result","id","labelledbyId","getRootRef","className","status","icon","dropdownIconProp","onChangeStart","optionsProp","placement","placementProp","closeAfterSelect","selectedBehavior","DEFAULT_SELECTED_BEHAVIOR","emptyText","DEFAULT_EMPTY_TEXT","creatable","fetching","dropdownAutoWidth","forceDropdownPortal","noMaxHeight","filterFn","defaultFilterFn","dropdownTestId","getRef","value","valueProp","defaultValue","inputValue","inputValueProp","defaultInputValue","readOnly","getOptionValue","getOptionValueDefault","getOptionLabel","getOptionLabelDefault","getNewOptionData","getNewOptionDataDefault","renderChip","renderChipDefault","renderOption","renderOptionDefault","onChange","onFocus","onFocusProp","onInputChange","onInputChangeProp","onBlur","onBlurProp","onKeyDown","onKeyDownProp","restProps","addOptionFromInput","addOption","removeOption","inputRef","inputRefHook","clearInput","opened","setOpened","focusedOption","focusedOptionIndex","setFocusedOption","setFocusedOptionIndex","useChipsSelect","rootRef","useExternRef","dropdownVerticalPlacement","setDropdownVerticalPlacement","React","useState","dropdownId","useId","dropdownCurrentItemId","undefined","dropdownScrollBoxRef","useRef","handleFocus","event","handleBlur","defaultPrevented","preventDefault","chipsSelectOptions","current","scrollToElement","index","center","dropdown","item","dropdownHeight","offsetHeight","scrollTop","itemTop","offsetTop","itemHeight","focusOptionByIndex","oldIndex","focusOption","nextIndex","type","FOCUS_ACTION_NEXT","FOCUS_ACTION_PREV","beforeIndex","handleKeyDown","key","Keys","ARROW_UP","ARROW_DOWN","ENTER","foundOption","ESCAPE","TAB","useEffect","foundFocusedOptionIndex","onDropdownPlacementChange","useCallback","startsWith","onDropdownMouseLeave","handleClickOutside","useGlobalOnClickOutside","ChipsInputBase","classNames","after","DropdownIcon","onAddChipOption","onRemoveChipOption","role","aria-expanded","aria-autocomplete","aria-controls","aria-activedescendant","aria-haspopup","CustomSelectDropdown","data-testid","targetRef","scrollBoxRef","onPlacementChange","onMouseLeave","autoWidth","forcePortal","aria-labelledby","map","dropdownItemId","isEmptyOptionPreset","Footnote","placeholder","isCreateNewOptionPreset","CustomSelectOption","hovered","onMouseDown","onMouseEnter","actionText","Fragment","label","children","selected","find","selectedOption","node"],"mappings":"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"}
|
|
@@ -34,8 +34,8 @@ export interface CustomSelectOptionProps extends HTMLAttributesWithRootRef<HTMLD
|
|
|
34
34
|
/**
|
|
35
35
|
* Блокирует весь блок.
|
|
36
36
|
*
|
|
37
|
-
* > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select)
|
|
38
|
-
* > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) не
|
|
37
|
+
* > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select), [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) или [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect), то свойство явно должно выставляться только через структуру `options`.
|
|
38
|
+
* > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) и [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect) не будут знать об актуальном состоянии
|
|
39
39
|
* опции.
|
|
40
40
|
*/
|
|
41
41
|
disabled?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n ['regular']: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n *\n * > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select)
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/CustomSelectOption/CustomSelectOption.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Icon16Done } from '@vkontakte/icons';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport { Paragraph } from '../Typography/Paragraph/Paragraph';\nimport styles from './CustomSelectOption.module.css';\n\nconst sizeYClassNames = {\n none: styles['CustomSelectOption--sizeY-none'],\n ['regular']: styles['CustomSelectOption--sizeY-regular'],\n};\n\nexport interface CustomSelectOptionProps extends HTMLAttributesWithRootRef<HTMLDivElement> {\n /**\n * Добавляет описание под основным блоком.\n */\n description?: React.ReactNode;\n /**\n * Вставляет элемент в начало блока перед основным контентом.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n before?: React.ReactNode;\n /**\n * Вставляет элемент в конец блока после основного контента.\n * Например, можно передать компонент `Avatar`, `Icon<Name>` или другие изображения.\n */\n after?: React.ReactNode;\n /**\n * Позволяет создавать вложенность.\n */\n hierarchy?: number;\n /**\n * Включает состояние выбранного элемента списка.\n */\n selected?: boolean;\n /**\n * Включает состояние наведения.\n */\n hovered?: boolean;\n /**\n * Включает состояние фокуса.\n */\n focused?: boolean;\n /**\n * Блокирует весь блок.\n *\n * > ⚠️ Важно: если CustomSelectOption используется внутри [Select](https://vkcom.github.io/VKUI/#/Select), [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) или [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect), то свойство явно должно выставляться только через структуру `options`.\n * > Запрещается выставлять `disabled` проп опциям в обход `options`, иначе [CustomSelect](https://vkcom.github.io/VKUI/#/CustomSelect) и [ChipsSelect](https://vkcom.github.io/VKUI/#/ChipsSelect) не будут знать об актуальном состоянии\n * опции.\n */\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/CustomSelectOption\n */\nexport const CustomSelectOption = ({\n children,\n hierarchy = 0,\n hovered: hoveredProp,\n selected,\n before,\n after,\n description,\n disabled,\n style: styleProp,\n className,\n onClick,\n ...restProps\n}: CustomSelectOptionProps) => {\n const { sizeY = 'none' } = useAdaptivity();\n const style = React.useMemo(\n () =>\n hierarchy > 0\n ? {\n '--vkui_internal--custom_select_option_hierarchy_level': hierarchy,\n ...styleProp,\n }\n : styleProp,\n [hierarchy, styleProp],\n );\n const hovered = hoveredProp && !disabled ? true : false;\n\n return (\n <Paragraph\n {...restProps}\n onClick={disabled ? undefined : onClick}\n Component=\"div\"\n role=\"option\"\n aria-disabled={disabled}\n aria-selected={selected}\n data-hovered={hovered}\n className={classNames(\n styles['CustomSelectOption'],\n sizeY !== 'compact' && sizeYClassNames[sizeY],\n hovered && styles['CustomSelectOption--hover'],\n disabled && styles['CustomSelectOption--disabled'],\n hierarchy > 0 && styles['CustomSelectOption--hierarchy'],\n className,\n )}\n style={style}\n >\n {hasReactNode(before) && <div className={styles['CustomSelectOption__before']}>{before}</div>}\n <div className={styles['CustomSelectOption__main']}>\n <div className={styles['CustomSelectOption__children']}>{children}</div>\n {hasReactNode(description) && (\n <Footnote className={styles['CustomSelectOption__description']}>{description}</Footnote>\n )}\n </div>\n <div className={styles['CustomSelectOption__after']}>\n {hasReactNode(after) && <div>{after}</div>}\n {selected && <Icon16Done className={styles['CustomSelectOption__selectedIcon']} />}\n </div>\n </Paragraph>\n );\n};\n"],"names":["CustomSelectOption","sizeYClassNames","none","children","hierarchy","hovered","hoveredProp","selected","before","after","description","disabled","style","styleProp","className","onClick","restProps","sizeY","useAdaptivity","React","useMemo","Paragraph","undefined","Component","role","aria-disabled","aria-selected","data-hovered","classNames","hasReactNode","div","Footnote","Icon16Done"],"mappings":";;;;+BA0DaA;;;eAAAA;;;;;;;iEA1DU;uBACI;sBACc;+BACX;0BAEL;2BACC;AAG1B,MAAMC,kBAAkB;IACtBC,IAAI;IACJ,CAAC,UAAU;AACb;AA8CO,MAAMF,qBAAqB;QAAC,EACjCG,QAAQ,EACRC,YAAY,CAAC,EACbC,SAASC,WAAW,EACpBC,QAAQ,EACRC,MAAM,EACNC,KAAK,EACLC,WAAW,EACXC,QAAQ,EACRC,OAAOC,SAAS,EAChBC,SAAS,EACTC,OAAO,EAEiB,WADrBC;QAXHb;QACAC;QACAC;QACAE;QACAC;QACAC;QACAC;QACAC;QACAC;QACAE;QACAC;;IAGA,MAAM,EAAEE,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IACxC,MAAMN,QAAQO,OAAMC,OAAO,CACzB,IACEhB,YAAY,IACR;YACE,yDAAyDA;WACtDS,aAELA,WACN;QAACT;QAAWS;KAAU;IAExB,MAAMR,UAAUC,eAAe,CAACK,WAAW,OAAO;IAElD,qBACE,qBAACU,oBAAS,8CACJL;QACJD,SAASJ,WAAWW,YAAYP;QAChCQ,WAAU;QACVC,MAAK;QACLC,iBAAed;QACfe,iBAAenB;QACfoB,gBAActB;QACdS,WAAWc,IAAAA,gBAAU,4BAEnBX,UAAU,aAAahB,eAAe,CAACgB,MAAM,EAC7CZ,4CACAM,gDACAP,YAAY,0CACZU;QAEFF,OAAOA;QAENiB,IAAAA,kBAAY,EAACrB,yBAAW,qBAACsB;QAAIhB,SAAS;OAAyCN,uBAChF,qBAACsB;QAAIhB,SAAS;qBACZ,qBAACgB;QAAIhB,SAAS;OAA2CX,WACxD0B,IAAAA,kBAAY,EAACnB,8BACZ,qBAACqB,kBAAQ;QAACjB,SAAS;OAA8CJ,6BAGrE,qBAACoB;QAAIhB,SAAS;OACXe,IAAAA,kBAAY,EAACpB,wBAAU,qBAACqB,aAAKrB,QAC7BF,0BAAY,qBAACyB,iBAAU;QAAClB,SAAS;;AAI1C"}
|
|
@@ -20,12 +20,6 @@ export interface FormFieldProps {
|
|
|
20
20
|
* - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.
|
|
21
21
|
*/
|
|
22
22
|
after?: React.ReactNode;
|
|
23
|
-
/**
|
|
24
|
-
* Режим отображения.
|
|
25
|
-
*
|
|
26
|
-
* - `default` — показывает фон, обводку и, при наличии, текст-подсказку.
|
|
27
|
-
* - `plain` — показывает только текст-подсказку.
|
|
28
|
-
*/
|
|
29
23
|
mode?: 'default' | 'plain';
|
|
30
24
|
}
|
|
31
25
|
interface FormFieldOwnProps extends React.AllHTMLAttributes<HTMLElement>, HasRootRef<HTMLElement>, HasComponent, FormFieldProps {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FormField.d.ts","sourceRoot":"","sources":["../../../../src/components/FormField/FormField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAM/B,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAavD,MAAM,WAAW,cAAc;IAC7B,MAAM,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,OAAO,CAAC;IACvC;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB;;;;;;;OAOG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB
|
|
1
|
+
{"version":3,"file":"FormField.d.ts","sourceRoot":"","sources":["../../../../src/components/FormField/FormField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAM/B,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAavD,MAAM,WAAW,cAAc;IAC7B,MAAM,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,OAAO,CAAC;IACvC;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB;;;;;;;OAOG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,IAAI,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;CAC5B;AAED,UAAU,iBACR,SAAQ,KAAK,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAC1C,UAAU,CAAC,WAAW,CAAC,EACvB,YAAY,EACZ,cAAc;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;GAEG;AACH,eAAO,MAAM,SAAS,wGAWnB,iBAAiB,sBAgDnB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/FormField/FormField.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusVisibleClassName } from '../../hooks/useFocusVisibleClassName';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { HasComponent, HasRootRef } from '../../types';\nimport styles from './FormField.module.css';\n\nconst sizeYClassNames = {\n none: styles['FormField--sizeY-none'],\n ['compact']: styles['FormField--sizeY-compact'],\n};\n\nconst stylesStatus = {\n error: styles['FormField--status-error'],\n valid: styles['FormField--status-valid'],\n};\n\nexport interface FormFieldProps {\n status?: 'default' | 'error' | 'valid';\n /**\n * Добавляет иконку слева.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n before?: React.ReactNode;\n /**\n * Добавляет иконку справа.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n after?: React.ReactNode;\n
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/FormField/FormField.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { useFocusVisibleClassName } from '../../hooks/useFocusVisibleClassName';\nimport { useFocusWithin } from '../../hooks/useFocusWithin';\nimport { HasComponent, HasRootRef } from '../../types';\nimport styles from './FormField.module.css';\n\nconst sizeYClassNames = {\n none: styles['FormField--sizeY-none'],\n ['compact']: styles['FormField--sizeY-compact'],\n};\n\nconst stylesStatus = {\n error: styles['FormField--status-error'],\n valid: styles['FormField--status-valid'],\n};\n\nexport interface FormFieldProps {\n status?: 'default' | 'error' | 'valid';\n /**\n * Добавляет иконку слева.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n before?: React.ReactNode;\n /**\n * Добавляет иконку справа.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n after?: React.ReactNode;\n mode?: 'default' | 'plain';\n}\n\ninterface FormFieldOwnProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent,\n FormFieldProps {\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/FormField\n */\nexport const FormField = ({\n Component = 'span',\n status = 'default',\n children,\n getRootRef,\n before,\n after,\n disabled,\n mode = 'default',\n className,\n ...restProps\n}: FormFieldOwnProps) => {\n const elRef = useExternRef(getRootRef);\n const { sizeY = 'none' } = useAdaptivity();\n const [hover, setHover] = React.useState(false);\n\n const focusWithin = useFocusWithin(elRef);\n const focusVisibleClassNames = useFocusVisibleClassName({\n focusVisible: focusWithin,\n mode: styles['FormField--focus-visible'],\n });\n\n const handleMouseEnter = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(true);\n };\n\n const handleMouseLeave = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(false);\n };\n\n return (\n <Component\n {...restProps}\n ref={elRef}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n className={classNames(\n styles['FormField'],\n mode === 'default' && styles['FormField--mode-default'],\n status !== 'default' && stylesStatus[status],\n sizeY !== 'regular' && sizeYClassNames[sizeY],\n disabled && styles['FormField--disabled'],\n !disabled && hover && styles['FormField--hover'],\n focusVisibleClassNames,\n className,\n )}\n >\n {before && <span className={styles['FormField__before']}>{before}</span>}\n {children}\n {after && (\n <span className={classNames(styles['FormField__after'], 'vkuiInternalFormField__after')}>\n {after}\n </span>\n )}\n <span aria-hidden className={styles['FormField__border']} />\n </Component>\n );\n};\n"],"names":["FormField","sizeYClassNames","none","stylesStatus","error","valid","Component","status","children","getRootRef","before","after","disabled","mode","className","restProps","elRef","useExternRef","sizeY","useAdaptivity","hover","setHover","React","useState","focusWithin","useFocusWithin","focusVisibleClassNames","useFocusVisibleClassName","focusVisible","handleMouseEnter","e","stopPropagation","handleMouseLeave","ref","onMouseEnter","onMouseLeave","classNames","span","aria-hidden"],"mappings":";;;;+BAqDaA;;;eAAAA;;;;;;;iEArDU;sBACI;+BACG;8BACD;0CACY;gCACV;AAI/B,MAAMC,kBAAkB;IACtBC,IAAI;IACJ,CAAC,UAAU;AACb;AAEA,MAAMC,eAAe;IACnBC,KAAK;IACLC,KAAK;AACP;AAoCO,MAAML,YAAY;QAAC,EACxBM,YAAY,MAAM,EAClBC,SAAS,SAAS,EAClBC,QAAQ,EACRC,UAAU,EACVC,MAAM,EACNC,KAAK,EACLC,QAAQ,EACRC,OAAO,SAAS,EAChBC,SAAS,EAES,WADfC;QATHT;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;;IAGA,MAAME,QAAQC,IAAAA,0BAAY,EAACR;IAC3B,MAAM,EAAES,QAAQ,MAAM,EAAE,GAAGC,IAAAA,4BAAa;IACxC,MAAM,CAACC,OAAOC,SAAS,GAAGC,OAAMC,QAAQ,CAAC;IAEzC,MAAMC,cAAcC,IAAAA,8BAAc,EAACT;IACnC,MAAMU,yBAAyBC,IAAAA,kDAAwB,EAAC;QACtDC,cAAcJ;QACdX,IAAI;IACN;IAEA,MAAMgB,mBAAmB,CAACC;QACxBA,EAAEC,eAAe;QACjBV,SAAS;IACX;IAEA,MAAMW,mBAAmB,CAACF;QACxBA,EAAEC,eAAe;QACjBV,SAAS;IACX;IAEA,qBACE,qBAACf,uDACKS;QACJkB,KAAKjB;QACLkB,cAAcL;QACdM,cAAcH;QACdlB,WAAWsB,IAAAA,gBAAU,mBAEnBvB,SAAS,4CACTN,WAAW,aAAaJ,YAAY,CAACI,OAAO,EAC5CW,UAAU,aAAajB,eAAe,CAACiB,MAAM,EAC7CN,uCACA,CAACA,YAAYQ,iCACbM,wBACAZ;QAGDJ,wBAAU,qBAAC2B;QAAKvB,SAAS;OAAgCJ,SACzDF,UACAG,uBACC,qBAAC0B;QAAKvB,WAAWsB,IAAAA,gBAAU,0BAA6B;OACrDzB,sBAGL,qBAAC0B;QAAKC,eAAAA;QAAYxB,SAAS;;AAGjC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Group.d.ts","sourceRoot":"","sources":["../../../../src/components/Group/Group.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"Group.d.ts","sourceRoot":"","sources":["../../../../src/components/Group/Group.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAK/B,OAAO,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAsDxD,MAAM,WAAW,UAAW,SAAQ,yBAAyB,CAAC,WAAW,CAAC;IACxE,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC9B;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACrC;;;;;OAKG;IACH,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IACxB;;OAEG;IACH,OAAO,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC;CACrB;AAGD;;GAEG;AACH,eAAO,MAAM,KAAK,iHASf,UAAU,sBA2DZ,CAAC"}
|
|
@@ -15,7 +15,6 @@ const _object_without_properties = require("@swc/helpers/_/_object_without_prope
|
|
|
15
15
|
const _react = /*#__PURE__*/ _interop_require_wildcard._(require("react"));
|
|
16
16
|
const _vkjs = require("@vkontakte/vkjs");
|
|
17
17
|
const _useAdaptivity = require("../../hooks/useAdaptivity");
|
|
18
|
-
const _usePlatform = require("../../hooks/usePlatform");
|
|
19
18
|
const _warnOnce = require("../../lib/warnOnce");
|
|
20
19
|
const _AppRootContext = require("../AppRoot/AppRootContext");
|
|
21
20
|
const _ModalRootContext = require("../ModalRoot/ModalRootContext");
|
|
@@ -66,7 +65,6 @@ const Group = (_param)=>{
|
|
|
66
65
|
"tabIndex"
|
|
67
66
|
]);
|
|
68
67
|
const { isInsideModal } = _react.useContext(_ModalRootContext.ModalRootContext);
|
|
69
|
-
const platform = (0, _usePlatform.usePlatform)();
|
|
70
68
|
const { sizeX = 'none' } = (0, _useAdaptivity.useAdaptivity)();
|
|
71
69
|
const mode = useGroupMode(modeProps, sizeX, isInsideModal);
|
|
72
70
|
const isTabPanel = restProps.role === 'tabpanel';
|
|
@@ -78,7 +76,7 @@ const Group = (_param)=>{
|
|
|
78
76
|
Component: "section"
|
|
79
77
|
}, restProps), {
|
|
80
78
|
tabIndex: tabIndex,
|
|
81
|
-
baseClassName: (0, _vkjs.classNames)('vkuiInternalGroup', "vkuiGroup", isInsideModal && "vkuiGroup--inside-modal",
|
|
79
|
+
baseClassName: (0, _vkjs.classNames)('vkuiInternalGroup', "vkuiGroup", isInsideModal && "vkuiGroup--inside-modal", sizeX !== 'regular' && sizeXClassNames[sizeX], mode && stylesMode[mode], stylesPadding[padding])
|
|
82
80
|
}), (0, _vkjs.hasReactNode)(header) && /*#__PURE__*/ _react.createElement("div", {
|
|
83
81
|
className: "vkuiGroup__header"
|
|
84
82
|
}, header), children, (0, _vkjs.hasReactNode)(description) && /*#__PURE__*/ _react.createElement(_Footnote.Footnote, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/Group/Group.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport {
|
|
1
|
+
{"version":3,"sources":["../../../../src/components/Group/Group.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames, hasReactNode } from '@vkontakte/vkjs';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { SizeTypeValues } from '../../lib/adaptivity';\nimport { warnOnce } from '../../lib/warnOnce';\nimport { HTMLAttributesWithRootRef } from '../../types';\nimport { AppRootContext } from '../AppRoot/AppRootContext';\nimport { ModalRootContext } from '../ModalRoot/ModalRootContext';\nimport { RootComponent } from '../RootComponent/RootComponent';\nimport { Separator } from '../Separator/Separator';\nimport { Spacing } from '../Spacing/Spacing';\nimport { Footnote } from '../Typography/Footnote/Footnote';\nimport styles from './Group.module.css';\n\nconst sizeXClassNames = {\n none: classNames(styles['Group--sizeX-none'], 'vkuiInternalGroup--sizeX-none'),\n ['compact']: styles['Group--sizeX-compact'],\n};\n\nconst stylesMode = {\n none: classNames(styles['Group--mode-none'], 'vkuiInternalGroup--mode-none'),\n plain: classNames(styles['Group--mode-plain'], 'vkuiInternalGroup--mode-plain'),\n card: classNames(styles['Group--mode-card'], 'vkuiInternalGroup--mode-card'),\n};\n\nconst stylesPadding = {\n s: styles['Group--padding-s'],\n m: styles['Group--padding-m'],\n};\n\n/**\n * Вычисляем mode для Group.\n */\nfunction useGroupMode(\n forcedMode: GroupProps['mode'],\n sizeX: SizeTypeValues | 'none',\n isInsideModal: boolean,\n): 'plain' | 'card' | 'none' {\n const { layout } = React.useContext(AppRootContext);\n\n if (forcedMode) {\n return forcedMode;\n }\n\n if (isInsideModal) {\n return 'plain';\n }\n\n if (layout) {\n return layout;\n }\n\n if (sizeX !== 'none') {\n return sizeX === 'regular' ? 'card' : 'plain';\n }\n\n return 'none';\n}\n\nexport interface GroupProps extends HTMLAttributesWithRootRef<HTMLElement> {\n header?: React.ReactNode;\n description?: React.ReactNode;\n /**\n `show` - разделитель всегда показывается,\n `hide` - разделитель всегда спрятан,\n `auto` - разделитель рисуется автоматически между соседними группами.\n */\n separator?: 'show' | 'hide' | 'auto';\n /**\n * Режим отображения. Если установлен `card`, выглядит как карточка c\n * обводкой и внешними отступами. Если `plain` — без отступов и обводки.\n * По умолчанию режим отображения зависит от `sizeX` (`mode=card` при `sizeX=REGULAR` и `mode=plain` при `sizeX=COMPACT`)\n * В модальных окнах по умолчанию `plain`.\n */\n mode?: 'plain' | 'card';\n /**\n * Отвечает за отступы вокруг контента в режиме `card`.\n */\n padding?: 's' | 'm';\n}\n\nconst warn = warnOnce('Group');\n/**\n * @see https://vkcom.github.io/VKUI/#/Group\n */\nexport const Group = ({\n header,\n description,\n children,\n separator = 'auto',\n mode: modeProps,\n padding = 'm',\n tabIndex: tabIndexProp,\n ...restProps\n}: GroupProps) => {\n const { isInsideModal } = React.useContext(ModalRootContext);\n const { sizeX = 'none' } = useAdaptivity();\n\n const mode = useGroupMode(modeProps, sizeX, isInsideModal);\n\n const isTabPanel = restProps.role === 'tabpanel';\n\n if (\n process.env.NODE_ENV === 'development' &&\n isTabPanel &&\n (!restProps['aria-controls'] || !restProps['id'])\n ) {\n warn(\n 'При использовании роли \"tabpanel\" необходимо задать значение свойств \"aria-controls\" и \"id\"',\n );\n }\n\n const tabIndex = isTabPanel && tabIndexProp === undefined ? 0 : tabIndexProp;\n\n return (\n <>\n <RootComponent\n Component=\"section\"\n {...restProps}\n tabIndex={tabIndex}\n baseClassName={classNames(\n 'vkuiInternalGroup',\n styles['Group'],\n isInsideModal && styles['Group--inside-modal'],\n sizeX !== 'regular' && sizeXClassNames[sizeX],\n mode && stylesMode[mode],\n stylesPadding[padding],\n )}\n >\n {hasReactNode(header) && <div className={styles['Group__header']}>{header}</div>}\n {children}\n {hasReactNode(description) && (\n <Footnote className={styles['Group__description']}>{description}</Footnote>\n )}\n </RootComponent>\n\n {separator !== 'hide' && (\n <React.Fragment>\n <Spacing\n className={classNames(styles['Group__separator'], styles['Group__separator--spacing'])}\n size={16}\n />\n <Separator\n className={classNames(\n styles['Group__separator'],\n styles['Group__separator--separator'],\n separator === 'show' && styles['Group__separator--force'],\n )}\n />\n </React.Fragment>\n )}\n </>\n );\n};\n"],"names":["Group","sizeXClassNames","none","classNames","stylesMode","plain","card","stylesPadding","s","m","useGroupMode","forcedMode","sizeX","isInsideModal","layout","React","useContext","AppRootContext","warn","warnOnce","header","description","children","separator","mode","modeProps","padding","tabIndex","tabIndexProp","restProps","ModalRootContext","useAdaptivity","isTabPanel","role","process","env","NODE_ENV","undefined","RootComponent","Component","baseClassName","hasReactNode","div","className","Footnote","Fragment","Spacing","size","Separator"],"mappings":";;;;+BAqFaA;;;eAAAA;;;;;;;iEArFU;sBACkB;+BACX;0BAEL;gCAEM;kCACE;+BACH;2BACJ;yBACF;0BACC;AAGzB,MAAMC,kBAAkB;IACtBC,MAAMC,IAAAA,gBAAU,2BAA8B;IAC9C,CAAC,UAAU;AACb;AAEA,MAAMC,aAAa;IACjBF,MAAMC,IAAAA,gBAAU,0BAA6B;IAC7CE,OAAOF,IAAAA,gBAAU,2BAA8B;IAC/CG,MAAMH,IAAAA,gBAAU,0BAA6B;AAC/C;AAEA,MAAMI,gBAAgB;IACpBC,CAAC;IACDC,CAAC;AACH;AAEA;;CAEC,GACD,SAASC,aACPC,UAA8B,EAC9BC,KAA8B,EAC9BC,aAAsB;IAEtB,MAAM,EAAEC,MAAM,EAAE,GAAGC,OAAMC,UAAU,CAACC,8BAAc;IAElD,IAAIN,YAAY;QACd,OAAOA;IACT;IAEA,IAAIE,eAAe;QACjB,OAAO;IACT;IAEA,IAAIC,QAAQ;QACV,OAAOA;IACT;IAEA,IAAIF,UAAU,QAAQ;QACpB,OAAOA,UAAU,YAAY,SAAS;IACxC;IAEA,OAAO;AACT;AAwBA,MAAMM,OAAOC,IAAAA,kBAAQ,EAAC;AAIf,MAAMnB,QAAQ;QAAC,EACpBoB,MAAM,EACNC,WAAW,EACXC,QAAQ,EACRC,YAAY,MAAM,EAClBC,MAAMC,SAAS,EACfC,UAAU,GAAG,EACbC,UAAUC,YAAY,EAEX,WADRC;QAPHT;QACAC;QACAC;QACAC;QACAC;QACAE;QACAC;;IAGA,MAAM,EAAEd,aAAa,EAAE,GAAGE,OAAMC,UAAU,CAACc,kCAAgB;IAC3D,MAAM,EAAElB,QAAQ,MAAM,EAAE,GAAGmB,IAAAA,4BAAa;IAExC,MAAMP,OAAOd,aAAae,WAAWb,OAAOC;IAE5C,MAAMmB,aAAaH,UAAUI,IAAI,KAAK;IAEtC,IACEC,QAAQC,GAAG,CAACC,QAAQ,KAAK,iBACzBJ,cACC,CAAA,CAACH,SAAS,CAAC,gBAAgB,IAAI,CAACA,SAAS,CAAC,KAAK,AAAD,GAC/C;QACAX,KACE;IAEJ;IAEA,MAAMS,WAAWK,cAAcJ,iBAAiBS,YAAY,IAAIT;IAEhE,qBACE,0DACE,qBAACU,4BAAa;QACZC,WAAU;OACNV;QACJF,UAAUA;QACVa,eAAerC,IAAAA,gBAAU,EACvB,kCAEAU,4CACAD,UAAU,aAAaX,eAAe,CAACW,MAAM,EAC7CY,QAAQpB,UAAU,CAACoB,KAAK,EACxBjB,aAAa,CAACmB,QAAQ;QAGvBe,IAAAA,kBAAY,EAACrB,yBAAW,qBAACsB;QAAIC,SAAS;OAA4BvB,SAClEE,UACAmB,IAAAA,kBAAY,EAACpB,8BACZ,qBAACuB,kBAAQ;QAACD,SAAS;OAAiCtB,eAIvDE,cAAc,wBACb,qBAACR,OAAM8B,QAAQ,sBACb,qBAACC,gBAAO;QACNH,WAAWxC,IAAAA,gBAAU;QACrB4C,MAAM;sBAER,qBAACC,oBAAS;QACRL,WAAWxC,IAAAA,gBAAU,6DAGnBoB,cAAc;;AAO5B"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { HasRootRef } from '../../../types';
|
|
3
3
|
import type { ImageBaseExpectedIconProps } from '../types';
|
|
4
|
-
export interface ImageBaseBadgeProps extends
|
|
4
|
+
export interface ImageBaseBadgeProps extends React.AriaAttributes, HasRootRef<HTMLDivElement> {
|
|
5
5
|
/**
|
|
6
6
|
* Вид подложки под иконку.
|
|
7
7
|
*
|
|
@@ -21,6 +21,7 @@ export interface ImageBaseBadgeProps extends HTMLAttributesWithRootRef<HTMLDivEl
|
|
|
21
21
|
* > использовали иконку.
|
|
22
22
|
*/
|
|
23
23
|
children: React.ReactElement<ImageBaseExpectedIconProps>;
|
|
24
|
+
className?: string;
|
|
24
25
|
}
|
|
25
26
|
/**
|
|
26
27
|
* Бейдж в правом нижнем углу компонента.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ImageBaseBadge.d.ts","sourceRoot":"","sources":["../../../../../src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"ImageBaseBadge.d.ts","sourceRoot":"","sources":["../../../../../src/components/ImageBase/ImageBaseBadge/ImageBaseBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5C,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAC;AAS3D,MAAM,WAAW,mBAAoB,SAAQ,KAAK,CAAC,cAAc,EAAE,UAAU,CAAC,cAAc,CAAC;IAC3F;;;;;OAKG;IACH,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;IACjC;;;;;;;;;;OAUG;IACH,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAC,0BAA0B,CAAC,CAAC;IACzD,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;;;GAIG;AACH,eAAO,MAAM,cAAc,iCAA6C,mBAAmB,sBAe1F,CAAC"}
|