@prom-ui/core 2.5.0 → 3.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Avatar/cjs/index.development.js +8 -0
- package/Avatar/cjs/index.development.v2.js +8 -0
- package/Avatar/cjs/index.production.js +1 -1
- package/Avatar/cjs/index.production.v2.js +1 -1
- package/Avatar/index.d.ts +13 -5
- package/Avatar/package.json +1 -1
- package/Backdrop/cjs/index.development.js +5 -3
- package/Backdrop/cjs/index.development.v2.js +5 -3
- package/Backdrop/cjs/index.production.js +1 -1
- package/Backdrop/cjs/index.production.v2.js +1 -1
- package/Backdrop/index.d.ts +11 -9
- package/Backdrop/package.json +1 -1
- package/Badge/cjs/index.development.js +7 -1
- package/Badge/cjs/index.development.v2.js +7 -1
- package/Badge/cjs/index.production.js +1 -1
- package/Badge/cjs/index.production.v2.js +1 -1
- package/Badge/index.d.ts +17 -9
- package/Badge/package.json +1 -1
- package/Body/cjs/index.development.js +22 -0
- package/Body/cjs/index.development.v2.js +22 -0
- package/Body/index.d.ts +68 -0
- package/Body/package.json +1 -1
- package/BodyProvider/cjs/index.development.js +103 -151
- package/BodyProvider/cjs/index.development.v2.js +103 -151
- package/BodyProvider/cjs/index.production.js +1 -1
- package/BodyProvider/cjs/index.production.v2.js +1 -1
- package/BodyProvider/hooks/useSyncDomColorScheme.d.ts +10 -0
- package/BodyProvider/hooks/useSyncStoreProps.d.ts +13 -0
- package/BodyProvider/index.d.ts +17 -1
- package/BodyProvider/package.json +1 -1
- package/BodyProvider/slices/sliceColorScheme.d.ts +16 -0
- package/BodyProvider/slices/sliceTTag.d.ts +1 -1
- package/BodyProvider/store.d.ts +4 -2
- package/BodyScrollLock/cjs/index.development.js +7 -0
- package/BodyScrollLock/cjs/index.development.v2.js +7 -0
- package/BodyScrollLock/cjs/index.production.js +1 -1
- package/BodyScrollLock/cjs/index.production.v2.js +1 -1
- package/BodyScrollLock/index.d.ts +8 -0
- package/BodyScrollLock/package.json +1 -1
- package/Box/cjs/index.development.js +14 -3
- package/Box/cjs/index.development.v2.js +14 -3
- package/Box/index.d.ts +110 -3
- package/Box/package.json +1 -1
- package/Button/cjs/index.development.js +16 -0
- package/Button/cjs/index.development.v2.js +16 -0
- package/Button/cjs/index.production.js +1 -1
- package/Button/cjs/index.production.v2.js +1 -1
- package/Button/index.d.ts +87 -1
- package/Button/package.json +1 -1
- package/ButtonPageUp/cjs/index.development.js +8 -0
- package/ButtonPageUp/cjs/index.development.v2.js +8 -0
- package/ButtonPageUp/cjs/index.production.js +1 -1
- package/ButtonPageUp/cjs/index.production.v2.js +1 -1
- package/ButtonPageUp/index.d.ts +14 -5
- package/ButtonPageUp/package.json +1 -1
- package/Checkbox/cjs/index.development.js +6 -0
- package/Checkbox/cjs/index.development.v2.js +6 -0
- package/Checkbox/cjs/index.production.js +1 -1
- package/Checkbox/cjs/index.production.v2.js +1 -1
- package/Checkbox/index.d.ts +9 -0
- package/Checkbox/package.json +1 -1
- package/ColorScheme/cjs/index.development.js +14 -3
- package/ColorScheme/cjs/index.development.v2.js +14 -3
- package/ColorScheme/cjs/index.production.js +1 -1
- package/ColorScheme/cjs/index.production.v2.js +1 -1
- package/ColorScheme/index.d.ts +12 -2
- package/ColorScheme/package.json +1 -1
- package/ContextMenu/cjs/index.development.js +8 -0
- package/ContextMenu/cjs/index.development.v2.js +8 -0
- package/ContextMenu/cjs/index.production.js +1 -1
- package/ContextMenu/cjs/index.production.v2.js +1 -1
- package/ContextMenu/index.d.ts +14 -5
- package/ContextMenu/package.json +1 -1
- package/ErrorCatch/ErrorCatch.d.ts +9 -3
- package/ErrorCatch/cjs/index.development.js +6 -1
- package/ErrorCatch/cjs/index.development.v2.js +6 -1
- package/ErrorCatch/cjs/index.production.js +1 -1
- package/ErrorCatch/cjs/index.production.v2.js +1 -1
- package/ErrorCatch/package.json +1 -1
- package/Flex/cjs/index.development.js +30 -0
- package/Flex/cjs/index.development.v2.js +30 -0
- package/Flex/index.d.ts +86 -0
- package/Flex/package.json +1 -1
- package/Grid/cjs/index.development.js +30 -2
- package/Grid/cjs/index.development.v2.js +30 -2
- package/Grid/cjs/index.production.js +1 -1
- package/Grid/cjs/index.production.v2.js +1 -1
- package/Grid/cjs/style.development.css +1324 -4959
- package/Grid/cjs/style.development.v2.css +1324 -4959
- package/Grid/cjs/style.production.css +1 -1
- package/Grid/cjs/style.production.v2.css +1 -1
- package/Grid/index.d.ts +94 -9
- package/Grid/package.json +1 -1
- package/Icon/cjs/index.development.js +13 -0
- package/Icon/cjs/index.development.v2.js +13 -0
- package/Icon/index.d.ts +29 -2
- package/Icon/package.json +1 -1
- package/Image/cjs/index.development.js +16 -0
- package/Image/cjs/index.development.v2.js +16 -0
- package/Image/cjs/style.development.css +1 -2
- package/Image/cjs/style.development.v2.css +1 -2
- package/Image/cjs/style.production.css +1 -1
- package/Image/cjs/style.production.v2.css +1 -1
- package/Image/index.d.ts +74 -0
- package/Image/package.json +1 -1
- package/ImageEmoji/cjs/index.development.js +6 -0
- package/ImageEmoji/cjs/index.development.v2.js +6 -0
- package/ImageEmoji/cjs/index.production.js +1 -1
- package/ImageEmoji/cjs/index.production.v2.js +1 -1
- package/ImageEmoji/index.d.ts +8 -1
- package/ImageEmoji/package.json +1 -1
- package/Input/cjs/index.development.js +15 -0
- package/Input/cjs/index.development.v2.js +15 -0
- package/Input/index.d.ts +35 -0
- package/Input/package.json +1 -1
- package/InputField/cjs/index.development.js +7 -0
- package/InputField/cjs/index.development.v2.js +7 -0
- package/InputField/cjs/index.production.js +1 -1
- package/InputField/cjs/index.production.v2.js +1 -1
- package/InputField/index.d.ts +13 -4
- package/InputField/package.json +1 -1
- package/KeyPress/cjs/index.development.js +8 -0
- package/KeyPress/cjs/index.development.v2.js +8 -0
- package/KeyPress/cjs/index.production.js +1 -1
- package/KeyPress/cjs/index.production.v2.js +1 -1
- package/KeyPress/index.d.ts +11 -4
- package/KeyPress/package.json +1 -1
- package/Label/cjs/index.development.js +9 -1
- package/Label/cjs/index.development.v2.js +9 -1
- package/Label/index.d.ts +15 -2
- package/Label/package.json +1 -1
- package/Line/cjs/index.development.js +11 -0
- package/Line/cjs/index.development.v2.js +11 -0
- package/Line/index.d.ts +35 -0
- package/Line/package.json +1 -1
- package/Link/cjs/index.development.js +10 -4
- package/Link/cjs/index.development.v2.js +10 -4
- package/Link/cjs/style.development.css +1 -2
- package/Link/cjs/style.development.v2.css +1 -2
- package/Link/cjs/style.production.css +1 -1
- package/Link/cjs/style.production.v2.css +1 -1
- package/Link/index.d.ts +61 -3
- package/Link/package.json +1 -1
- package/List/cjs/index.development.js +22 -0
- package/List/cjs/index.development.v2.js +22 -0
- package/List/index.d.ts +64 -0
- package/List/package.json +1 -1
- package/Media/cjs/index.development.js +6 -1
- package/Media/cjs/index.development.v2.js +6 -1
- package/Media/cjs/index.production.js +1 -1
- package/Media/cjs/index.production.v2.js +1 -1
- package/Media/index.d.ts +8 -3
- package/Media/package.json +1 -1
- package/Modal/cjs/index.development.js +8 -0
- package/Modal/cjs/index.development.v2.js +8 -0
- package/Modal/cjs/index.production.js +1 -1
- package/Modal/cjs/index.production.v2.js +1 -1
- package/Modal/index.d.ts +16 -8
- package/Modal/package.json +1 -1
- package/OutsideClick/cjs/index.development.js +8 -0
- package/OutsideClick/cjs/index.development.v2.js +8 -0
- package/OutsideClick/cjs/index.production.js +1 -1
- package/OutsideClick/cjs/index.production.v2.js +1 -1
- package/OutsideClick/index.d.ts +10 -2
- package/OutsideClick/package.json +1 -1
- package/Overlay/cjs/index.development.js +7 -2
- package/Overlay/cjs/index.development.v2.js +7 -2
- package/Overlay/cjs/index.production.js +1 -1
- package/Overlay/cjs/index.production.v2.js +1 -1
- package/Overlay/index.d.ts +34 -29
- package/Overlay/package.json +1 -1
- package/PhotoGallery/cjs/index.development.js +22 -3
- package/PhotoGallery/cjs/index.development.v2.js +22 -3
- package/PhotoGallery/cjs/index.production.js +1 -1
- package/PhotoGallery/cjs/index.production.v2.js +1 -1
- package/PhotoGallery/cjs/style.development.css +34 -18
- package/PhotoGallery/cjs/style.development.v2.css +34 -18
- package/PhotoGallery/cjs/style.production.css +1 -1
- package/PhotoGallery/cjs/style.production.v2.css +1 -1
- package/PhotoGallery/index.d.ts +22 -7
- package/PhotoGallery/package.json +1 -1
- package/Picture/cjs/index.development.js +22 -0
- package/Picture/cjs/index.development.v2.js +22 -0
- package/Picture/cjs/style.development.css +1 -2
- package/Picture/cjs/style.development.v2.css +1 -2
- package/Picture/cjs/style.production.css +1 -1
- package/Picture/cjs/style.production.v2.css +1 -1
- package/Picture/index.d.ts +62 -0
- package/Picture/package.json +1 -1
- package/Portal/cjs/index.development.js +10 -0
- package/Portal/cjs/index.development.v2.js +10 -0
- package/Portal/cjs/index.production.js +1 -1
- package/Portal/cjs/index.production.v2.js +1 -1
- package/Portal/index.d.ts +12 -3
- package/Portal/package.json +1 -1
- package/Progress/cjs/index.development.js +5 -1
- package/Progress/cjs/index.development.v2.js +5 -1
- package/Progress/cjs/index.production.js +1 -1
- package/Progress/cjs/index.production.v2.js +1 -1
- package/Progress/index.d.ts +9 -1
- package/Progress/package.json +1 -1
- package/QRCode/cjs/index.development.js +6 -0
- package/QRCode/cjs/index.development.v2.js +6 -0
- package/QRCode/cjs/index.production.js +1 -1
- package/QRCode/cjs/index.production.v2.js +1 -1
- package/QRCode/index.d.ts +11 -5
- package/QRCode/package.json +1 -1
- package/Rating/cjs/index.development.js +8 -0
- package/Rating/cjs/index.development.v2.js +8 -0
- package/Rating/cjs/index.production.js +1 -1
- package/Rating/cjs/index.production.v2.js +1 -1
- package/Rating/index.d.ts +12 -4
- package/Rating/package.json +1 -1
- package/RatingSelect/cjs/index.development.js +7 -0
- package/RatingSelect/cjs/index.development.v2.js +7 -0
- package/RatingSelect/cjs/index.production.js +1 -1
- package/RatingSelect/cjs/index.production.v2.js +1 -1
- package/RatingSelect/index.d.ts +13 -6
- package/RatingSelect/package.json +1 -1
- package/Scroll/cjs/index.development.js +23 -0
- package/Scroll/cjs/index.development.v2.js +23 -0
- package/Scroll/index.d.ts +67 -7
- package/Scroll/package.json +1 -1
- package/ScrollControls/ScrollControlsButton.d.ts +2 -0
- package/ScrollControls/cjs/index.development.js +19 -3
- package/ScrollControls/cjs/index.development.v2.js +19 -3
- package/ScrollControls/cjs/index.production.js +1 -1
- package/ScrollControls/cjs/index.production.v2.js +1 -1
- package/ScrollControls/index.d.ts +21 -4
- package/ScrollControls/package.json +1 -1
- package/SimpleSlider/cjs/index.development.js +9 -0
- package/SimpleSlider/cjs/index.development.v2.js +9 -0
- package/SimpleSlider/cjs/index.production.js +1 -1
- package/SimpleSlider/cjs/index.production.v2.js +1 -1
- package/SimpleSlider/index.d.ts +27 -16
- package/SimpleSlider/package.json +1 -1
- package/Skeleton/cjs/index.development.js +11 -0
- package/Skeleton/cjs/index.development.v2.js +11 -0
- package/Skeleton/cjs/index.production.js +1 -1
- package/Skeleton/cjs/index.production.v2.js +1 -1
- package/Skeleton/index.d.ts +73 -12
- package/Skeleton/package.json +1 -1
- package/SnackBar/cjs/index.development.js +6 -1
- package/SnackBar/cjs/index.development.v2.js +6 -1
- package/SnackBar/cjs/index.production.js +1 -1
- package/SnackBar/cjs/index.production.v2.js +1 -1
- package/SnackBar/index.d.ts +22 -15
- package/SnackBar/package.json +1 -1
- package/Spinner/cjs/index.development.js +11 -0
- package/Spinner/cjs/index.development.v2.js +11 -0
- package/Spinner/cjs/index.production.js +1 -1
- package/Spinner/cjs/index.production.v2.js +1 -1
- package/Spinner/index.d.ts +39 -7
- package/Spinner/package.json +1 -1
- package/Text/cjs/index.development.js +16 -0
- package/Text/cjs/index.development.v2.js +16 -0
- package/Text/cjs/style.development.css +4 -8
- package/Text/cjs/style.development.v2.css +4 -8
- package/Text/cjs/style.production.css +1 -1
- package/Text/cjs/style.production.v2.css +1 -1
- package/Text/index.d.ts +83 -0
- package/Text/package.json +1 -1
- package/TextEmoji/cjs/index.development.js +7 -0
- package/TextEmoji/cjs/index.development.v2.js +7 -0
- package/TextEmoji/cjs/index.production.js +1 -1
- package/TextEmoji/cjs/index.production.v2.js +1 -1
- package/TextEmoji/index.d.ts +8 -0
- package/TextEmoji/package.json +1 -1
- package/Tooltip/cjs/index.development.js +8 -0
- package/Tooltip/cjs/index.development.v2.js +8 -0
- package/Tooltip/cjs/index.production.js +1 -1
- package/Tooltip/cjs/index.production.v2.js +1 -1
- package/Tooltip/index.d.ts +37 -30
- package/Tooltip/package.json +1 -1
- package/Tumbler/cjs/index.development.js +6 -0
- package/Tumbler/cjs/index.development.v2.js +6 -0
- package/Tumbler/cjs/index.production.js +1 -1
- package/Tumbler/cjs/index.production.v2.js +1 -1
- package/Tumbler/index.d.ts +8 -0
- package/Tumbler/package.json +1 -1
- package/Viewport/cjs/index.development.js +10 -0
- package/Viewport/cjs/index.development.v2.js +10 -0
- package/Viewport/cjs/index.production.js +1 -1
- package/Viewport/cjs/index.production.v2.js +1 -1
- package/Viewport/index.d.ts +15 -4
- package/Viewport/package.json +1 -1
- package/evokit/cjs/index.production.js +1 -1
- package/evokit/cjs/index.production.v2.js +1 -1
- package/evokit/package.json +1 -1
- package/package.json +3 -16
- package/useBrowserLayoutEffect/cjs/index.development.js +1 -1
- package/useBrowserLayoutEffect/cjs/index.development.v2.js +1 -1
- package/useBrowserLayoutEffect/index.d.ts +1 -1
- package/useBrowserLayoutEffect/package.json +1 -1
- package/useColorScheme/cjs/index.development.js +61 -0
- package/useColorScheme/cjs/index.development.v2.js +61 -0
- package/useColorScheme/cjs/index.production.js +1 -0
- package/useColorScheme/cjs/index.production.v2.js +1 -0
- package/useColorScheme/index.d.ts +31 -0
- package/useColorScheme/index.js +7 -0
- package/useColorScheme/index.v2.js +7 -0
- package/useColorScheme/package.json +9 -0
- package/useDebounce/cjs/index.development.js +2 -9
- package/useDebounce/cjs/index.development.v2.js +2 -9
- package/useDebounce/cjs/index.production.js +1 -1
- package/useDebounce/cjs/index.production.v2.js +1 -1
- package/useDebounce/index.d.ts +1 -1
- package/useDebounce/package.json +1 -1
- package/useForwardRef/cjs/index.development.js +1 -1
- package/useForwardRef/cjs/index.development.v2.js +1 -1
- package/useForwardRef/cjs/index.production.js +1 -1
- package/useForwardRef/cjs/index.production.v2.js +1 -1
- package/useForwardRef/index.d.ts +1 -1
- package/useForwardRef/package.json +1 -1
- package/useInView/package.json +1 -1
- package/useIsMounted/cjs/index.development.js +1 -1
- package/useIsMounted/cjs/index.development.v2.js +1 -1
- package/useIsMounted/cjs/index.production.js +1 -1
- package/useIsMounted/cjs/index.production.v2.js +1 -1
- package/useIsMounted/index.d.ts +1 -1
- package/useIsMounted/package.json +1 -1
- package/useKeyPress/cjs/index.development.js +1 -9
- package/useKeyPress/cjs/index.development.v2.js +1 -9
- package/useKeyPress/cjs/index.production.js +1 -1
- package/useKeyPress/cjs/index.production.v2.js +1 -1
- package/useKeyPress/index.d.ts +1 -1
- package/useKeyPress/package.json +1 -1
- package/useMedia/cjs/index.development.js +1 -1
- package/useMedia/cjs/index.development.v2.js +1 -1
- package/useMedia/index.d.ts +3 -3
- package/useMedia/package.json +1 -1
- package/useOutsideClick/cjs/index.development.js +1 -1
- package/useOutsideClick/cjs/index.development.v2.js +1 -1
- package/useOutsideClick/index.d.ts +1 -1
- package/useOutsideClick/package.json +1 -1
- package/usePortal/cjs/index.development.js +9 -21
- package/usePortal/cjs/index.development.v2.js +9 -21
- package/usePortal/cjs/index.production.js +1 -1
- package/usePortal/cjs/index.production.v2.js +1 -1
- package/usePortal/index.d.ts +5 -6
- package/usePortal/package.json +1 -1
- package/useScrollPosition/cjs/index.development.js +1 -1
- package/useScrollPosition/cjs/index.development.v2.js +1 -1
- package/useScrollPosition/index.d.ts +1 -1
- package/useScrollPosition/package.json +1 -1
- package/useScrollSync/cjs/index.development.js +210 -0
- package/useScrollSync/cjs/index.development.v2.js +210 -0
- package/useScrollSync/cjs/index.production.js +1 -0
- package/useScrollSync/cjs/index.production.v2.js +1 -0
- package/useScrollSync/index.d.ts +31 -0
- package/useScrollSync/index.js +7 -0
- package/useScrollSync/index.v2.js +7 -0
- package/useScrollSync/package.json +12 -0
- package/useSnackBar/cjs/index.development.js +1 -1
- package/useSnackBar/cjs/index.development.v2.js +1 -1
- package/useSnackBar/cjs/index.production.js +1 -1
- package/useSnackBar/cjs/index.production.v2.js +1 -1
- package/useSnackBar/index.d.ts +1 -1
- package/useSnackBar/package.json +1 -1
- package/base/colors-dark.css +0 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("@babel/runtime/helpers/extends"),t=require("@babel/runtime/helpers/objectWithoutProperties"),r=require("react"),o=require("react-transition-group"),a=require("clsx"),n=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),l=require("@prom-ui/core/Portal"),c=require("@prom-ui/core/Media"),d=require("@babel/runtime/helpers/taggedTemplateLiteral"),u=require("@prom-ui/core/Button"),s=require("@prom-ui/core/Icon"),p=require("@prom-ui/core/BodyProvider"),m=require("@prom-ui/icons/Close2"),f=require("@prom-ui/icons/ArrowBack"),v=require("@babel/runtime/helpers/slicedToArray"),_=require("@babel/runtime/helpers/defineProperty"),h=require("@prom-ui/core/ErrorCatch"),y=require("@prom-ui/core/Link"),E=require("@prom-ui/icons/colors/PromTroubleHappens"),b=require("@prom-ui/icons/colors/PromNoSignal"),C=require("react-easy-swipe");function g(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function x(e){if(e&&"object"==typeof e&&"default"in e)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("@babel/runtime/helpers/extends"),t=require("@babel/runtime/helpers/objectWithoutProperties"),r=require("react"),o=require("react-transition-group"),a=require("clsx"),n=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),l=require("@prom-ui/core/Portal"),c=require("@prom-ui/core/Media"),d=require("@babel/runtime/helpers/taggedTemplateLiteral"),u=require("@prom-ui/core/Button"),s=require("@prom-ui/core/Icon"),p=require("@prom-ui/core/BodyProvider"),m=require("@prom-ui/icons/Close2"),f=require("@prom-ui/icons/ArrowBack"),v=require("@babel/runtime/helpers/slicedToArray"),_=require("@babel/runtime/helpers/defineProperty"),h=require("@prom-ui/core/ErrorCatch"),y=require("@prom-ui/core/Link"),E=require("@prom-ui/icons/colors/PromTroubleHappens"),b=require("@prom-ui/icons/colors/PromNoSignal"),C=require("react-easy-swipe");function g(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function x(e){if(e&&"object"==typeof e&&"default"in e)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(r){if("default"!==r){var o=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,o.get?o:{enumerable:!0,get:function(){return e[r]}})}}),t.default=e,Object.freeze(t)}var q,B,N,O,k,P,S,w,R=g(e),T=g(t),z=x(r),I=g(a),L=g(d),A=g(v),j=g(_),M=g(C),D={root:"-yvLz",backdrop:"MKZgL",popup:"RJENA",popup_placement_top:"ERdxO",popup_placement_bottom:"MJb6v",popup_placement_right:"nL79b",popup_placement_left:"p-p5e",content:"uHLyZ",header:"ntf6X",header__grid:"-OCio",header__item:"gjOzy",header__title:"-s4aZ gjOzy",header__titleText:"zkpK2",header__action:"fzZrE gjOzy",header__actionButton:"CC-hv",header__actionIcon:"LoRyP",footer:"nE-cV",enter:"v7DoD",exit:"E0PkA",enterActive:"RFXzo",exitActive:"a2xd2",errorContainer:"_6Vqfn",errorContainerLoading:"_1NWwx",errorIcon:"B2x3n",errorTitle:"xzjW5",errorDescription:"_9ITQZ",errorWrapReloadButton:"TztMO",errorWrapCloseButton:"_6pk7M",errorCloseButtonLoading:"_4NTmf"},W=function(e){var t=e.isShowPrevButton,r=e.isShowCloseButton,o=e.children,a=e.title,n=e.onClose,i=e.onPrev,l=p.useBodyStoreTTag().t;return z.default.createElement("header",{className:D.header},void 0!==o?o:z.default.createElement("div",{className:D.header__grid},z.default.createElement("div",{className:D.header__action},t&&z.default.createElement(u.Button,{className:D.header__actionButton,"button-theme":"black-inherit",type:"button",onClick:i,"aria-label":l(q||(q=L.default(["Назад"]))),"data-qaid":"prev"},z.default.createElement(s.Icon,{"icon-as":f.SvgArrowBack,className:D.header__actionIcon}))),z.default.createElement("div",{className:D.header__title},"string"==typeof a?z.default.createElement("span",{className:D.header__titleText,"data-qaid":"title"},a):a),z.default.createElement("div",{className:D.header__action},r&&n&&z.default.createElement(u.Button,{className:D.header__actionButton,"button-theme":"black-inherit",type:"button",onClick:n,"aria-label":l(B||(B=L.default(["Закрыть"]))),"data-qaid":"close"},z.default.createElement(s.Icon,{"icon-as":m.SvgClose2,className:D.header__actionIcon})))))},H=function(e,t,r){return["top","bottom"].includes(e)?{height:t,maxHeight:r}:{width:t,maxWidth:r}},K=function(){var e;return Boolean(null===(e=navigator)||void 0===e?void 0:e.onLine)?"default":"offline"},Z=function(e){var t=e.onClickReload,r=e.onClickClose,o=e.errorType,a=void 0===o?"default":o,n=e.loading,i=void 0!==n&&n,l=p.useBodyStoreTTag().t,c={default:{icon:E.SvgPromTroubleHappens,title:l(N||(N=L.default(["Ой, кажется что-то пошло не так"]))),description:l(O||(O=L.default(["Мы уже разбираемся с этим"])))},offline:{icon:b.SvgPromNoSignal,title:l(k||(k=L.default(["Нет соединения"]))),description:l(P||(P=L.default(["Проверьте подключение к Интернету"])))}};return z.default.createElement("div",{className:I.default(D.errorContainer,j.default({},D.errorContainerLoading,i)),"data-qaid":"overlay_error_catch","data-testid":"overlay_error_catch"},z.default.createElement(s.Icon,{className:D.errorIcon,"icon-as":c[a].icon,"data-qaid":"overlay_error_catch_icon","data-testid":"overlay_error_catch_icon"}),z.default.createElement("div",{className:D.errorTitle,"data-qaid":"overlay_error_catch_title","data-testid":"overlay_error_catch_title"},c[a].title),z.default.createElement("div",{className:D.errorDescription,"data-qaid":"overlay_error_catch_description","data-testid":"overlay_error_catch_description"},c[a].description),z.default.createElement("div",{className:D.errorWrapReloadButton},z.default.createElement(u.Button,{"button-theme":"violet","button-padding-left":"4xl","button-padding-right":"4xl",type:"button",onClick:t,loading:i,"data-qaid":"overlay_error_catch_reload_button","data-testid":"overlay_error_catch_reload_button"},l(S||(S=L.default(["Попробовать еще раз"]))))),z.default.createElement("div",{className:D.errorWrapCloseButton},z.default.createElement(y.Link,{className:i?D.errorCloseButtonLoading:void 0,"link-as":"button","link-color":"blue-500",type:"button",onClick:r,"data-qaid":"overlay_error_catch_close_button","data-testid":"overlay_error_catch_close_button"},l(w||(w=L.default(["Закрыть"]))))))};Z.displayName="ErrorComponent";var X=function(e){var t=e.children,o=e.name,a=e.onClose,n=r.useState(!1),i=A.default(n,2),l=i[0],c=i[1],d=r.useState("default"),u=A.default(d,2),s=u[0],p=u[1];return r.useEffect(function(){l?setTimeout(function(){p(K()),c(!1)},600):p(K())},[l]),l?z.default.createElement(Z,{errorType:s,loading:!0}):z.default.createElement(h.ErrorCatch,{name:o,errorView:z.default.createElement(Z,{onClickClose:a,errorType:s,onClickReload:function(){return c(!0)}})},t)};X.displayName="OverlayErrCatch";var F=["-webkit","-moz","-ms","-o"],Q=["transform","transition"],V=function(e,t){if(e)for(var r in t){var o=-1!==Q.indexOf(r);if(t[r]){if(e.style.setProperty(r,t[r]),o)for(var a=0,n=F;a<n.length;a++){var i=n[a];e.style.setProperty("".concat(i,"-").concat(r),t[r])}}else if(e.style.removeProperty(r),o)for(var l=0,c=F;l<c.length;l++){var d=c[l];e.style.removeProperty("".concat(d,"-").concat(r))}}},J=function(e){var t=e.isActive,r=void 0===t||t,o=e.children,a=e.onClose,n=e.placement,i=e.rootRef,l=e.contentRef,c=z.useRef(null),d=z.useRef(!1),u=z.useRef(0);if(!r)return z.createElement(z.Fragment,null,o);return z.createElement(M.default,{onSwipeMove:function(e,t){var r,o,a,s=e.x,p=e.y,m=(null===(r=l.current)||void 0===r?void 0:r.scrollHeight)||0,f=(null===(o=l.current)||void 0===o?void 0:o.offsetHeight)||0,v=(null===(a=l.current)||void 0===a?void 0:a.scrollTop)||0,_=m-(v+f),h=null,y=!1,E=!1,b=Math.abs(s),C=Math.abs(p);"top"===n?(h="translateY(".concat(p>=0?0:p,"px)"),y=_<=1&&p<=0&&C>b,E=C>70):"bottom"===n?(h="translateY(".concat(p<=0?0:p,"px)"),y=v<=1&&p>=0&&C>b,E=C>70):"left"===n?(h="translateX(".concat(s>=0?0:s,"px)"),y=s<=0&&b>C,E=b>70):"right"===n&&(h="translateX(".concat(s<=0?0:s,"px)"),y=s>=0&&b>C,E=b>70),null===c.current&&(c.current=!!y),c.current&&(u.current||(u.current=(new Date).getTime()),!d.current&&E&&(d.current=!0),null==t||t.preventDefault(),V(i.current,{transform:h}),V(l.current,{"pointer-events":"none",overflow:"hidden"}))},onSwipeEnd:function(){if(c.current){V(i.current,{transition:"transform ".concat(225,"ms cubic-bezier(0, 0, 0.2, 1) 0ms"),transform:null}),V(l.current,{"pointer-events":null,overflow:null}),setTimeout(function(){V(i.current,{transition:null})},225);var e=(new Date).getTime()-u.current;d.current&&e<250&&a&&a({})}u.current=0,c.current=null,d.current=!1}},o)},Y=["children","onClose","onOpen","onPrev","onOpened","onClosed","isOpen","isBodyScrollLock","isShowCloseButton","isShowPrevButton","isCloseOnEscape","isCloseOnSwipe","isCloseOutsideClick","isAnimated","isRenderPortal","header","footer","padding","title","placement","size","maxSize","zIndex","contentRef","dataQaId","errCatchName"],G=function(e){var t=e.children,r=e.onClose,a=e.onOpen,d=e.onPrev,u=e.onOpened,s=e.onClosed,p=e.isOpen,m=e.isBodyScrollLock,f=void 0===m||m,v=e.isShowCloseButton,_=void 0===v||v,h=e.isShowPrevButton,y=void 0!==h&&h,E=e.isCloseOnEscape,b=void 0===E||E,C=e.isCloseOnSwipe,g=void 0===C||C,x=e.isCloseOutsideClick,q=void 0===x||x,B=e.isAnimated,N=void 0===B||B,O=e.isRenderPortal,k=void 0===O||O,P=e.header,S=e.footer,w=e.padding,L=void 0===w?"20px 20px 20px 20px":w,A=e.title,j=e.placement,M=void 0===j?"adaptive":j,K=e.size,Z=void 0===K?"adaptive":K,F=e.maxSize,Q=void 0===F?"90%":F,V=e.zIndex,G=void 0===V?5e3:V,U=e.contentRef,$=e.dataQaId,ee=e.errCatchName,te=void 0===ee?"OverlayErrCatch":ee,re=T.default(e,Y),oe=z.useRef(null),ae=z.useRef(null),ne=U||ae,ie=c.useMedia({minWidth:"medium"}),le=z.useRef(null),ce=M,de=Z;return"adaptive"===Z&&(de="top"===M||"bottom"===M?"auto":"adaptive"===M?ie?400:"auto":400),"adaptive"===M&&(ce=ie?"right":"bottom"),z.createElement(z.Fragment,null,z.createElement(n.Backdrop,{isOpen:p,isAnimated:N,zIndex:G,isRenderPortal:k,isBodyScrollLock:f}),z.createElement(o.CSSTransition,{nodeRef:le,in:p,timeout:N?225:0,classNames:D,unmountOnExit:!0,onEnter:a,onEntered:u,onExited:s},z.createElement(l.Portal,{isActive:k},z.createElement(J,{isActive:f&&g,rootRef:oe,contentRef:ne,placement:ce,onClose:r},z.createElement("div",R.default({ref:le,className:D.root,role:"presentation",style:{zIndex:G}},re),z.createElement(i.KeyPress,{isActive:b,code:"Escape",onKeyDown:r}),z.createElement("div",{className:D.backdrop,"aria-hidden":!0,onClick:function(e){q&&r&&r(e)}}),z.createElement("div",{ref:oe,className:I.default(D.popup,D["popup_placement_".concat(ce)]),"aria-modal":!0,role:"dialog",style:H(ce,de,Q),"data-qaid":$},z.createElement(W,{isShowCloseButton:_,isShowPrevButton:y,onClose:r,onPrev:d,title:A},P),z.createElement("footer",{className:D.footer},S),z.createElement("div",{className:D.content,ref:ne,style:{padding:L}},z.createElement(X,{onClose:r,name:te},t))))))))};G.displayName="Overlay",exports.Overlay=G,require("./style.production.v2.css");
|
package/Overlay/index.d.ts
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
export type OverlayProps = React.ComponentProps<'div'> & {
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
4
|
+
* Розташування
|
|
5
5
|
* <br>
|
|
6
6
|
* - `adaptive` = `isMinWidthMedium ? 'right' : 'bottom'`
|
|
7
7
|
* */
|
|
8
8
|
placement?: 'adaptive' | 'top' | 'right' | 'bottom' | 'left';
|
|
9
9
|
/**
|
|
10
|
-
* Ширина
|
|
10
|
+
* Ширина або висота залежно від **placement**
|
|
11
11
|
* <br>
|
|
12
|
-
* - `auto`
|
|
12
|
+
* - `auto` — розмір за контентом
|
|
13
13
|
* <br>
|
|
14
|
-
* - `adaptive`
|
|
14
|
+
* - `adaptive` — розмір відносно властивості **placement**:
|
|
15
15
|
* <br>
|
|
16
16
|
* **top | bottom** = `auto`
|
|
17
17
|
* <br>
|
|
@@ -20,57 +20,62 @@ export type OverlayProps = React.ComponentProps<'div'> & {
|
|
|
20
20
|
* **adaptive** = `isMinWidthMedium ? 400 : 'auto'`
|
|
21
21
|
* */
|
|
22
22
|
size?: string | number;
|
|
23
|
-
/**
|
|
23
|
+
/** Максимальна ширина або висота залежно від **placement** */
|
|
24
24
|
maxSize?: string | number;
|
|
25
|
-
/**
|
|
25
|
+
/** Стан — відкрито чи ні */
|
|
26
26
|
isOpen: boolean;
|
|
27
27
|
/** Заголовок */
|
|
28
28
|
title?: React.ReactNode;
|
|
29
|
-
/**
|
|
29
|
+
/** Відображення кнопки закриття (хрестик) */
|
|
30
30
|
isShowCloseButton?: boolean;
|
|
31
|
-
/**
|
|
31
|
+
/** Відображення кнопки назад (стрілка) */
|
|
32
32
|
isShowPrevButton?: boolean;
|
|
33
|
-
/**
|
|
33
|
+
/** Дозволяє закрити попап по клавіші `Escape` */
|
|
34
34
|
isCloseOnEscape?: boolean;
|
|
35
|
-
/**
|
|
35
|
+
/** Дозволяє закрити попап по свайпу, працює якщо `isBodyScrollLock={true}` */
|
|
36
36
|
isCloseOnSwipe?: boolean;
|
|
37
|
-
/**
|
|
37
|
+
/** Дозволяє закриття при кліку на вільний простір (затемнення документа) */
|
|
38
38
|
isCloseOutsideClick?: boolean;
|
|
39
|
-
/** Рендер
|
|
39
|
+
/** Рендер у кінець `<body>` */
|
|
40
40
|
isRenderPortal?: boolean;
|
|
41
|
-
/**
|
|
41
|
+
/** Вмикає/вимикає анімацію відкриття/приховання шторки */
|
|
42
42
|
isAnimated?: boolean;
|
|
43
|
-
/**
|
|
43
|
+
/** Забороняє прокрутку `<body>` */
|
|
44
44
|
isBodyScrollLock?: boolean;
|
|
45
|
-
/** React
|
|
45
|
+
/** Дочірні React-елементи */
|
|
46
46
|
children: React.ReactNode;
|
|
47
|
-
/** React
|
|
47
|
+
/** Дочірні React-елементи блоку заголовку */
|
|
48
48
|
header?: React.ReactNode;
|
|
49
|
-
/** React
|
|
49
|
+
/** Дочірні React-елементи блоку підвалу */
|
|
50
50
|
footer?: React.ReactNode;
|
|
51
|
-
/**
|
|
51
|
+
/** Спрацьовує, коли попап відкрито */
|
|
52
52
|
onOpen?: () => void;
|
|
53
|
-
/**
|
|
53
|
+
/** Обробник закриття попапу */
|
|
54
54
|
onClose: (e: any) => void;
|
|
55
|
-
/**
|
|
55
|
+
/** Спрацьовує, коли попап відкрито і анімацію завершено */
|
|
56
56
|
onOpened?: () => void;
|
|
57
|
-
/**
|
|
57
|
+
/** Спрацьовує, коли попап закрито і анімацію завершено */
|
|
58
58
|
onClosed?: () => void;
|
|
59
|
-
/**
|
|
59
|
+
/** Подія при натисканні кнопки назад */
|
|
60
60
|
onPrev?: (e: any) => void;
|
|
61
|
-
/**
|
|
61
|
+
/** Внутрішні відступи */
|
|
62
62
|
padding?: string | number;
|
|
63
|
-
/**
|
|
63
|
+
/** Розміщення по z-осі */
|
|
64
64
|
zIndex?: number;
|
|
65
|
-
/**
|
|
66
|
-
/** `ref` для блока с контентом */
|
|
65
|
+
/** `ref` для блоку з контентом */
|
|
67
66
|
contentRef?: React.RefObject<HTMLDivElement | null>;
|
|
67
|
+
/** HTML-атрибут `data-qaid` для автотестів */
|
|
68
68
|
dataQaId?: string;
|
|
69
|
-
/**
|
|
69
|
+
/** Назва компонента для зручного дебагу помилок */
|
|
70
70
|
errCatchName?: string;
|
|
71
71
|
};
|
|
72
72
|
/**
|
|
73
|
-
*
|
|
74
|
-
*
|
|
73
|
+
* Бокова шторка (drawer) або bottom sheet з backdrop, анімацією та підтримкою свайп-закриття.
|
|
74
|
+
* `placement='adaptive'` — на десктопі відкривається справа, на мобільному — знизу.
|
|
75
|
+
* @example
|
|
76
|
+
* import { Overlay } from '@prom-ui/core/Overlay'
|
|
77
|
+
* <Overlay isOpen={isOpen} onClose={() => setOpen(false)} title='Заголовок'>
|
|
78
|
+
* <p>Вміст шторки</p>
|
|
79
|
+
* </Overlay>
|
|
75
80
|
*/
|
|
76
81
|
export declare const Overlay: React.FC<OverlayProps>;
|
package/Overlay/package.json
CHANGED
|
@@ -11,6 +11,7 @@ var Portal = require('@prom-ui/core/Portal');
|
|
|
11
11
|
var ScrollControls = require('@prom-ui/core/ScrollControls');
|
|
12
12
|
var Icon = require('@prom-ui/core/Icon');
|
|
13
13
|
var Play = require('@prom-ui/icons/Play');
|
|
14
|
+
var StarFill = require('@prom-ui/icons/StarFill');
|
|
14
15
|
var _taggedTemplateLiteral = require('@babel/runtime/helpers/taggedTemplateLiteral');
|
|
15
16
|
var Button = require('@prom-ui/core/Button');
|
|
16
17
|
var BodyProvider = require('@prom-ui/core/BodyProvider');
|
|
@@ -923,7 +924,7 @@ var definePinchZoom = function definePinchZoom() {
|
|
|
923
924
|
};
|
|
924
925
|
var PinchZoom = definePinchZoom();
|
|
925
926
|
|
|
926
|
-
var css = {"scrolling":"PhotoGallery__scrolling___BeLzR","root":"PhotoGallery__root___nJWgH","layout":"PhotoGallery__layout___BDoOb","layoutHeader":"PhotoGallery__layoutHeader___iNVA1","slotLayoutHeader":"PhotoGallery__slotLayoutHeader___KxMxT","layoutContent":"PhotoGallery__layoutContent___C-jWr","layoutFooter":"PhotoGallery__layoutFooter___MQh-L","layoutSection":"PhotoGallery__layoutSection___3FXm5","layoutSectionContent":"PhotoGallery__layoutSectionContent___WPu-a","layoutSectionFooter":"PhotoGallery__layoutSectionFooter___G5FaN","layoutPreviews":"PhotoGallery__layoutPreviews___gQFQR","layoutAdditional":"PhotoGallery__layoutAdditional___pw0QV","header":"PhotoGallery__header___meCSL","headerTitle":"PhotoGallery__headerTitle___NpSWI","headerClose":"PhotoGallery__headerClose___-B9Zg","mainPhotoScrollControls":"PhotoGallery__mainPhotoScrollControls___ckcap","mainPhoto":"PhotoGallery__mainPhoto___-r4WP PhotoGallery__scrolling___BeLzR","mainPhotoItem":"PhotoGallery__mainPhotoItem___Q7wDI","mainPhotoImage":"PhotoGallery__mainPhotoImage___NrcBT","mainPhotoIframe":"PhotoGallery__mainPhotoIframe___kObZY","preview":"PhotoGallery__preview___86-3f PhotoGallery__scrolling___BeLzR","previewItem":"PhotoGallery__previewItem___gnB8m","previewButton":"PhotoGallery__previewButton___L4PR-","previewImage":"PhotoGallery__previewImage___8dsDI","videoPlayLabel":"PhotoGallery__videoPlayLabel___2kU58","videoPlayLabelIcon":"PhotoGallery__videoPlayLabelIcon___WR7T8","enter":"PhotoGallery__enter___sM8Qu","exit":"PhotoGallery__exit___veHZr","enterActive":"PhotoGallery__enterActive___VP4oy","exitActive":"PhotoGallery__exitActive___AMPJ3"};
|
|
927
|
+
var css = {"scrolling":"PhotoGallery__scrolling___BeLzR","root":"PhotoGallery__root___nJWgH","layout":"PhotoGallery__layout___BDoOb","layoutHeader":"PhotoGallery__layoutHeader___iNVA1","slotLayoutHeader":"PhotoGallery__slotLayoutHeader___KxMxT","layoutContent":"PhotoGallery__layoutContent___C-jWr","layoutFooter":"PhotoGallery__layoutFooter___MQh-L","layoutSection":"PhotoGallery__layoutSection___3FXm5","layoutSectionContent":"PhotoGallery__layoutSectionContent___WPu-a","layoutSectionFooter":"PhotoGallery__layoutSectionFooter___G5FaN","layoutPreviews":"PhotoGallery__layoutPreviews___gQFQR","layoutAdditional":"PhotoGallery__layoutAdditional___pw0QV","header":"PhotoGallery__header___meCSL","headerTitle":"PhotoGallery__headerTitle___NpSWI","headerClose":"PhotoGallery__headerClose___-B9Zg","mainPhotoScrollControls":"PhotoGallery__mainPhotoScrollControls___ckcap","mainPhoto":"PhotoGallery__mainPhoto___-r4WP PhotoGallery__scrolling___BeLzR","mainPhotoItem":"PhotoGallery__mainPhotoItem___Q7wDI","mainPhotoImage":"PhotoGallery__mainPhotoImage___NrcBT","mainPhotoIframe":"PhotoGallery__mainPhotoIframe___kObZY","preview":"PhotoGallery__preview___86-3f PhotoGallery__scrolling___BeLzR","previewItem":"PhotoGallery__previewItem___gnB8m","previewButton":"PhotoGallery__previewButton___L4PR-","previewImage":"PhotoGallery__previewImage___8dsDI","previewRating":"PhotoGallery__previewRating___GqvTR","previewRatingIcon":"PhotoGallery__previewRatingIcon___qPTNw","videoPlayLabel":"PhotoGallery__videoPlayLabel___2kU58","videoPlayLabelIcon":"PhotoGallery__videoPlayLabelIcon___WR7T8","enter":"PhotoGallery__enter___sM8Qu","exit":"PhotoGallery__exit___veHZr","enterActive":"PhotoGallery__enterActive___VP4oy","exitActive":"PhotoGallery__exitActive___AMPJ3"};
|
|
927
928
|
|
|
928
929
|
var MainPhotosImage = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref) {
|
|
929
930
|
var src = _ref.src,
|
|
@@ -1125,7 +1126,8 @@ var PreviewPhotos = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref
|
|
|
1125
1126
|
}
|
|
1126
1127
|
}, items.map(function (_ref2, index) {
|
|
1127
1128
|
var type = _ref2.type,
|
|
1128
|
-
src = _ref2.src
|
|
1129
|
+
src = _ref2.src,
|
|
1130
|
+
rating = _ref2.rating;
|
|
1129
1131
|
var isVideo = type === 'video';
|
|
1130
1132
|
var previewSrc = isVideo ? getVideoPreviewImage(src) : src;
|
|
1131
1133
|
var iteractionEventName = isVideo ? 'clickPreviewVideo' : 'clickPreviewImage';
|
|
@@ -1154,7 +1156,14 @@ var PreviewPhotos = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref
|
|
|
1154
1156
|
loading: "lazy",
|
|
1155
1157
|
"data-qaid": "photo_gallery_preview_image",
|
|
1156
1158
|
"data-testid": "photo_gallery_preview_image"
|
|
1157
|
-
}),
|
|
1159
|
+
}), rating ? /*#__PURE__*/React__namespace.createElement("div", {
|
|
1160
|
+
className: css.previewRating,
|
|
1161
|
+
"data-qaid": "photo_gallery_preview_rating",
|
|
1162
|
+
"data-testid": "photo_gallery_preview_rating"
|
|
1163
|
+
}, /*#__PURE__*/React__namespace.createElement(Icon.Icon, {
|
|
1164
|
+
className: css.previewRatingIcon,
|
|
1165
|
+
"icon-as": StarFill.SvgStarFill
|
|
1166
|
+
}), rating) : null, isVideo && /*#__PURE__*/React__namespace.createElement("div", {
|
|
1158
1167
|
className: css.videoPlayLabel,
|
|
1159
1168
|
"data-qaid": "photo_gallery_preview_play",
|
|
1160
1169
|
"data-testid": "photo_gallery_preview_play"
|
|
@@ -1229,6 +1238,16 @@ var SlotContainer = function SlotContainer(_ref) {
|
|
|
1229
1238
|
}));
|
|
1230
1239
|
};
|
|
1231
1240
|
|
|
1241
|
+
/**
|
|
1242
|
+
* Повноекранна галерея фото та відео з навігацією клавіатурою та смугою попередніх переглядів.
|
|
1243
|
+
* @example
|
|
1244
|
+
* import { PhotoGallery } from '@prom-ui/core/PhotoGallery'
|
|
1245
|
+
* <PhotoGallery
|
|
1246
|
+
* isOpen={isOpen}
|
|
1247
|
+
* items={[{ type: 'image', src: '/photo.jpg' }]}
|
|
1248
|
+
* onClose={(index) => setOpen(false)}
|
|
1249
|
+
* />
|
|
1250
|
+
*/
|
|
1232
1251
|
var PhotoGallery = function PhotoGallery(_ref) {
|
|
1233
1252
|
var isOpen = _ref.isOpen,
|
|
1234
1253
|
title = _ref.title,
|
|
@@ -11,6 +11,7 @@ var Portal = require('@prom-ui/core/Portal');
|
|
|
11
11
|
var ScrollControls = require('@prom-ui/core/ScrollControls');
|
|
12
12
|
var Icon = require('@prom-ui/core/Icon');
|
|
13
13
|
var Play = require('@prom-ui/icons/Play');
|
|
14
|
+
var StarFill = require('@prom-ui/icons/StarFill');
|
|
14
15
|
var _taggedTemplateLiteral = require('@babel/runtime/helpers/taggedTemplateLiteral');
|
|
15
16
|
var Button = require('@prom-ui/core/Button');
|
|
16
17
|
var BodyProvider = require('@prom-ui/core/BodyProvider');
|
|
@@ -923,7 +924,7 @@ var definePinchZoom = function definePinchZoom() {
|
|
|
923
924
|
};
|
|
924
925
|
var PinchZoom = definePinchZoom();
|
|
925
926
|
|
|
926
|
-
var css = {"scrolling":"PhotoGallery__scrolling___q1DKc","root":"PhotoGallery__root___KiBKq","layout":"PhotoGallery__layout___JBDok","layoutHeader":"PhotoGallery__layoutHeader___tVG4b","slotLayoutHeader":"PhotoGallery__slotLayoutHeader___8R2r5","layoutContent":"PhotoGallery__layoutContent___O43ff","layoutFooter":"PhotoGallery__layoutFooter___Gz4gH","layoutSection":"PhotoGallery__layoutSection___CvZb6","layoutSectionContent":"PhotoGallery__layoutSectionContent___2TSDW","layoutSectionFooter":"PhotoGallery__layoutSectionFooter___LTbHF","layoutPreviews":"PhotoGallery__layoutPreviews___-hzyv","layoutAdditional":"PhotoGallery__layoutAdditional___mR5-f","header":"PhotoGallery__header___xfAad","headerTitle":"PhotoGallery__headerTitle___QiOEy","headerClose":"PhotoGallery__headerClose___qdl3x","mainPhotoScrollControls":"PhotoGallery__mainPhotoScrollControls___PeY3Y","mainPhoto":"PhotoGallery__mainPhoto___QIMHy PhotoGallery__scrolling___q1DKc","mainPhotoItem":"PhotoGallery__mainPhotoItem___aZCyk","mainPhotoImage":"PhotoGallery__mainPhotoImage___2aEr5","mainPhotoIframe":"PhotoGallery__mainPhotoIframe___kThdT","preview":"PhotoGallery__preview___F-k0z PhotoGallery__scrolling___q1DKc","previewItem":"PhotoGallery__previewItem___jf683","previewButton":"PhotoGallery__previewButton___VAXOP","previewImage":"PhotoGallery__previewImage___Mx2Y-","videoPlayLabel":"PhotoGallery__videoPlayLabel___jQiDN","videoPlayLabelIcon":"PhotoGallery__videoPlayLabelIcon___wSdjd","enter":"PhotoGallery__enter___Lnosr","exit":"PhotoGallery__exit___NW-xY","enterActive":"PhotoGallery__enterActive___LrirU","exitActive":"PhotoGallery__exitActive___L6st-"};
|
|
927
|
+
var css = {"scrolling":"PhotoGallery__scrolling___q1DKc","root":"PhotoGallery__root___KiBKq","layout":"PhotoGallery__layout___JBDok","layoutHeader":"PhotoGallery__layoutHeader___tVG4b","slotLayoutHeader":"PhotoGallery__slotLayoutHeader___8R2r5","layoutContent":"PhotoGallery__layoutContent___O43ff","layoutFooter":"PhotoGallery__layoutFooter___Gz4gH","layoutSection":"PhotoGallery__layoutSection___CvZb6","layoutSectionContent":"PhotoGallery__layoutSectionContent___2TSDW","layoutSectionFooter":"PhotoGallery__layoutSectionFooter___LTbHF","layoutPreviews":"PhotoGallery__layoutPreviews___-hzyv","layoutAdditional":"PhotoGallery__layoutAdditional___mR5-f","header":"PhotoGallery__header___xfAad","headerTitle":"PhotoGallery__headerTitle___QiOEy","headerClose":"PhotoGallery__headerClose___qdl3x","mainPhotoScrollControls":"PhotoGallery__mainPhotoScrollControls___PeY3Y","mainPhoto":"PhotoGallery__mainPhoto___QIMHy PhotoGallery__scrolling___q1DKc","mainPhotoItem":"PhotoGallery__mainPhotoItem___aZCyk","mainPhotoImage":"PhotoGallery__mainPhotoImage___2aEr5","mainPhotoIframe":"PhotoGallery__mainPhotoIframe___kThdT","preview":"PhotoGallery__preview___F-k0z PhotoGallery__scrolling___q1DKc","previewItem":"PhotoGallery__previewItem___jf683","previewButton":"PhotoGallery__previewButton___VAXOP","previewImage":"PhotoGallery__previewImage___Mx2Y-","previewRating":"PhotoGallery__previewRating___6dvN5","previewRatingIcon":"PhotoGallery__previewRatingIcon___qXV70","videoPlayLabel":"PhotoGallery__videoPlayLabel___jQiDN","videoPlayLabelIcon":"PhotoGallery__videoPlayLabelIcon___wSdjd","enter":"PhotoGallery__enter___Lnosr","exit":"PhotoGallery__exit___NW-xY","enterActive":"PhotoGallery__enterActive___LrirU","exitActive":"PhotoGallery__exitActive___L6st-"};
|
|
927
928
|
|
|
928
929
|
var MainPhotosImage = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref) {
|
|
929
930
|
var src = _ref.src,
|
|
@@ -1125,7 +1126,8 @@ var PreviewPhotos = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref
|
|
|
1125
1126
|
}
|
|
1126
1127
|
}, items.map(function (_ref2, index) {
|
|
1127
1128
|
var type = _ref2.type,
|
|
1128
|
-
src = _ref2.src
|
|
1129
|
+
src = _ref2.src,
|
|
1130
|
+
rating = _ref2.rating;
|
|
1129
1131
|
var isVideo = type === 'video';
|
|
1130
1132
|
var previewSrc = isVideo ? getVideoPreviewImage(src) : src;
|
|
1131
1133
|
var iteractionEventName = isVideo ? 'clickPreviewVideo' : 'clickPreviewImage';
|
|
@@ -1154,7 +1156,14 @@ var PreviewPhotos = /*#__PURE__*/React__namespace.forwardRef(function (_ref, ref
|
|
|
1154
1156
|
loading: "lazy",
|
|
1155
1157
|
"data-qaid": "photo_gallery_preview_image",
|
|
1156
1158
|
"data-testid": "photo_gallery_preview_image"
|
|
1157
|
-
}),
|
|
1159
|
+
}), rating ? /*#__PURE__*/React__namespace.createElement("div", {
|
|
1160
|
+
className: css.previewRating,
|
|
1161
|
+
"data-qaid": "photo_gallery_preview_rating",
|
|
1162
|
+
"data-testid": "photo_gallery_preview_rating"
|
|
1163
|
+
}, /*#__PURE__*/React__namespace.createElement(Icon.Icon, {
|
|
1164
|
+
className: css.previewRatingIcon,
|
|
1165
|
+
"icon-as": StarFill.SvgStarFill
|
|
1166
|
+
}), rating) : null, isVideo && /*#__PURE__*/React__namespace.createElement("div", {
|
|
1158
1167
|
className: css.videoPlayLabel,
|
|
1159
1168
|
"data-qaid": "photo_gallery_preview_play",
|
|
1160
1169
|
"data-testid": "photo_gallery_preview_play"
|
|
@@ -1229,6 +1238,16 @@ var SlotContainer = function SlotContainer(_ref) {
|
|
|
1229
1238
|
}));
|
|
1230
1239
|
};
|
|
1231
1240
|
|
|
1241
|
+
/**
|
|
1242
|
+
* Повноекранна галерея фото та відео з навігацією клавіатурою та смугою попередніх переглядів.
|
|
1243
|
+
* @example
|
|
1244
|
+
* import { PhotoGallery } from '@prom-ui/core/PhotoGallery'
|
|
1245
|
+
* <PhotoGallery
|
|
1246
|
+
* isOpen={isOpen}
|
|
1247
|
+
* items={[{ type: 'image', src: '/photo.jpg' }]}
|
|
1248
|
+
* onClose={(index) => setOpen(false)}
|
|
1249
|
+
* />
|
|
1250
|
+
*/
|
|
1232
1251
|
var PhotoGallery = function PhotoGallery(_ref) {
|
|
1233
1252
|
var isOpen = _ref.isOpen,
|
|
1234
1253
|
title = _ref.title,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var t=require("@babel/runtime/helpers/slicedToArray"),e=require("react"),n=require("react-transition-group"),o=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),a=require("@prom-ui/core/Portal"),s=require("@prom-ui/core/ScrollControls"),r=require("@prom-ui/core/Icon"),l=require("@prom-ui/icons/Play"),c=require("@babel/runtime/helpers/taggedTemplateLiteral"),u=require("@prom-ui/core/Button"),h=require("@prom-ui/core/BodyProvider"),d=require("@prom-ui/icons/Close2"),f=require("@babel/runtime/helpers/extends"),m=require("clsx");function p(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}function g(t){if(t&&"object"==typeof t&&"default"in t)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,o.get?o:{enumerable:!0,get:function(){return t[n]}})}})),e.default=t,Object.freeze(e)}var v=p(t),y=g(e),b=p(c),x=p(f),E=p(m),w=new Map,I=function(t,e){var n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];if(e){w.has(e)&&(cancelAnimationFrame(w.get(e)),w.delete(e));var o=requestAnimationFrame((function(){var o=e.getBoundingClientRect(),i=t.getBoundingClientRect(),a=i.top+e.scrollTop-o.top-o.height/2+i.height/2,s=i.left+e.scrollLeft-o.left-o.width/2+i.width/2;s<0&&(s=0),a<0&&(a=0),e.scrollTo({behavior:n?"smooth":"instant",top:a,left:s})}));w.set(e,o)}},P=function(t){var e=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?v(?:i)?=|\&v(?:i)?=))([^#\&\?]*).*/.exec(t);return e&&e[1]},T=function(t){var e=P(t);return"https://img.youtube.com/vi/".concat(e,"/0.jpg")},z=function(){var t=function(t,e){this.el=t,this.zoomFactor=1,this.lastScale=1,this.offset={x:0,y:0},this.initialOffset={x:0,y:0},this.options=Object.assign({},this.defaults,e),this.setupMarkup(),this.bindEvents(),this.update(),this.isImageLoaded(this.el)&&(this.updateAspectRatio(),this.setupOffsets()),this.enable()},e=function(t,e){return t+e};t.prototype={defaults:{tapZoomFactor:2,zoomOutFactor:1.3,animationDuration:300,maxZoom:4,minZoom:.5,draggableUnzoomed:!0,lockDragAxis:!1,setOffsetsOnce:!1,use2d:!0,useMouseWheel:!1,verticalPadding:0,horizontalPadding:0,onZoomStart:null,onZoomEnd:null,onZoomUpdate:null,onDragStart:null,onDragEnd:null,onDragUpdate:null,onDoubleTap:null,onMouseWheel:null},handleDragStart:function(t){"function"==typeof this.options.onDragStart&&this.options.onDragStart(this,t),this.stopAnimation(),this.lastDragPosition=!1,this.hasInteraction=!0,this.handleDrag(t)},handleDrag:function(t){var e="touchmove"===t.type?this.getTouches(t)[0]:this.getPointer(t);this.drag(e,this.lastDragPosition),this.offset=this.sanitizeOffset(this.offset),this.lastDragPosition=e},handleDragEnd:function(){"function"==typeof this.options.onDragEnd&&this.options.onDragEnd(this,event),this.end()},handleZoomStart:function(t){"function"==typeof this.options.onZoomStart&&this.options.onZoomStart(this,t),this.stopAnimation(),this.lastScale=1,this.nthZoom=0,this.lastZoomCenter=!1,this.hasInteraction=!0},handleZoom:function(t,e){var n=this.getTouchCenter(this.getTouches(t)),o=e/this.lastScale;this.lastScale=e,this.nthZoom+=1,this.nthZoom>3&&(this.scale(o,n),this.drag(n,this.lastZoomCenter)),this.lastZoomCenter=n},handleZoomEnd:function(){"function"==typeof this.options.onZoomEnd&&this.options.onZoomEnd(this,event),this.end()},handleDoubleTap:function(t){var e=this.getTouches(t)[0],n=this.zoomFactor>1?1:this.options.tapZoomFactor,o=this.zoomFactor,i=function(t){this.scaleTo(o+t*(n-o),e)}.bind(this);this.hasInteraction||(this.isDoubleTap=!0,o>n&&(e=this.getCurrentZoomCenter()),this.animate(this.options.animationDuration,i,this.swing),"function"==typeof this.options.onDoubleTap&&this.options.onDoubleTap(this,t))},handleMouseWheel:function(t){var e=this.getPointer(t),n=Math.min(Math.max(this.options.minZoom,this.lastScale+-.01*t.deltaY),this.options.maxZoom),o=n/this.lastScale;this.scale(o,e),this.lastScale=n,this.update(),"function"==typeof this.options.onMouseWheel&&this.options.onMouseWheel(this,t)},computeInitialOffset:function(){this.initialOffset={x:-Math.abs(this.el.offsetWidth*this.getInitialZoomFactor()-this.container.offsetWidth)/2,y:-Math.abs(this.el.offsetHeight*this.getInitialZoomFactor()-this.container.offsetHeight)/2}},resetOffset:function(){this.offset.x=this.initialOffset.x,this.offset.y=this.initialOffset.y},isImageLoaded:function(t){return"IMG"===t.nodeName?t.complete&&0!==t.naturalHeight:Array.from(t.querySelectorAll("img")).every(this.isImageLoaded)},setupOffsets:function(){this.options.setOffsetsOnce&&this._isOffsetsSet||(this._isOffsetsSet=!0,this.computeInitialOffset(),this.resetOffset())},sanitizeOffset:function(t){var e=this.el.offsetWidth*this.getInitialZoomFactor()*this.zoomFactor,n=this.el.offsetHeight*this.getInitialZoomFactor()*this.zoomFactor,o=e-this.getContainerX()+this.options.horizontalPadding,i=n-this.getContainerY()+this.options.verticalPadding,a=Math.max(o,0),s=Math.max(i,0),r=Math.min(o,0)-this.options.horizontalPadding,l=Math.min(i,0)-this.options.verticalPadding;return{x:Math.min(Math.max(t.x,r),a),y:Math.min(Math.max(t.y,l),s)}},scaleTo:function(t,e){this.scale(t/this.zoomFactor,e)},scale:function(t,e){t=this.scaleZoomFactor(t),this.addOffset({x:(t-1)*(e.x+this.offset.x),y:(t-1)*(e.y+this.offset.y)}),"function"==typeof this.options.onZoomUpdate&&this.options.onZoomUpdate(this,event)},scaleZoomFactor:function(t){var e=this.zoomFactor;return this.zoomFactor*=t,this.zoomFactor=Math.min(this.options.maxZoom,Math.max(this.zoomFactor,this.options.minZoom)),this.zoomFactor/e},canDrag:function(){return this.options.draggableUnzoomed||!((t=this.zoomFactor)>(e=1)-.01&&t<e+.01);var t,e},drag:function(t,e){e&&(this.options.lockDragAxis?Math.abs(t.x-e.x)>Math.abs(t.y-e.y)?this.addOffset({x:-(t.x-e.x),y:0}):this.addOffset({y:-(t.y-e.y),x:0}):this.addOffset({y:-(t.y-e.y),x:-(t.x-e.x)}),"function"==typeof this.options.onDragUpdate&&this.options.onDragUpdate(this,event))},getTouchCenter:function(t){return this.getVectorAvg(t)},getVectorAvg:function(t){return{x:t.map((function(t){return t.x})).reduce(e)/t.length,y:t.map((function(t){return t.y})).reduce(e)/t.length}},addOffset:function(t){this.offset={x:this.offset.x+t.x,y:this.offset.y+t.y}},sanitize:function(){this.zoomFactor<this.options.zoomOutFactor?this.zoomOutAnimation():this.isInsaneOffset(this.offset)&&this.sanitizeOffsetAnimation()},isInsaneOffset:function(t){var e=this.sanitizeOffset(t);return e.x!==t.x||e.y!==t.y},sanitizeOffsetAnimation:function(){var t=this.sanitizeOffset(this.offset),e=this.offset.x,n=this.offset.y,o=function(o){this.offset.x=e+o*(t.x-e),this.offset.y=n+o*(t.y-n),this.update()}.bind(this);this.animate(this.options.animationDuration,o,this.swing)},zoomOutAnimation:function(){if(1!==this.zoomFactor){var t=this.zoomFactor,e=this.getCurrentZoomCenter(),n=function(n){this.scaleTo(t+n*(1-t),e)}.bind(this);this.animate(this.options.animationDuration,n,this.swing)}},updateAspectRatio:function(){this.unsetContainerY(),this.setContainerY(this.container.parentElement.offsetHeight)},getInitialZoomFactor:function(){var t=this.container.offsetWidth/this.el.offsetWidth,e=this.container.offsetHeight/this.el.offsetHeight;return Math.min(t,e)},getAspectRatio:function(){return this.el.offsetWidth/this.el.offsetHeight},getCurrentZoomCenter:function(){var t=this.offset.x-this.initialOffset.x,e=-1*this.offset.x-t/(1/this.zoomFactor-1),n=this.offset.y-this.initialOffset.y;return{x:e,y:-1*this.offset.y-n/(1/this.zoomFactor-1)}},getTouches:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return Array.prototype.slice.call(t.touches).map((function(t){return{x:t.pageX-a,y:t.pageY-i}}))},getPointer:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return{x:t.pageX-a,y:t.pageY-i}},animate:function(t,e,n,o){var i=(new Date).getTime(),a=function(){if(this.inAnimation){var s=(new Date).getTime()-i,r=s/t;s>=t?(e(1),o&&o(),this.update(),this.stopAnimation(),this.update()):(n&&(r=n(r)),e(r),this.update(),requestAnimationFrame(a))}}.bind(this);this.inAnimation=!0,requestAnimationFrame(a)},stopAnimation:function(){this.inAnimation=!1},swing:function(t){return-Math.cos(t*Math.PI)/2+.5},getContainerX:function(){return this.container.offsetWidth},getContainerY:function(){return this.container.offsetHeight},setContainerY:function(t){return this.container.style.height=t+"px"},unsetContainerY:function(){this.container.style.height=null},setupMarkup:function(){var t,e;this.container=(t='<div class="pinch-zoom-container" style="height: 100%;"></div>',(e=document.implementation.createHTMLDocument("")).body.innerHTML=t,Array.from(e.body.children)[0]),this.el.parentNode.insertBefore(this.container,this.el),this.container.appendChild(this.el),this.container.style.overflow="hidden",this.container.style.position="relative",this.el.style.webkitTransformOrigin="0% 0%",this.el.style.mozTransformOrigin="0% 0%",this.el.style.msTransformOrigin="0% 0%",this.el.style.oTransformOrigin="0% 0%",this.el.style.transformOrigin="0% 0%",this.el.style.position="absolute",this.el.style.backfaceVisibility="hidden",this.el.style.willChange="transform"},end:function(){this.hasInteraction=!1,this.sanitize(),this.update()},bindEvents:function(){var t=this;n(this.container,this),this.resizeHandler=this.update.bind(this),window.addEventListener("resize",this.resizeHandler),Array.from(this.el.querySelectorAll("img")).forEach((function(e){e.addEventListener("load",t.update.bind(t))})),"IMG"===this.el.nodeName&&this.el.addEventListener("load",this.update.bind(this))},update:function(t){t&&"resize"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),t&&"load"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),this.updatePlanned||(this.updatePlanned=!0,window.setTimeout(function(){this.updatePlanned=!1;var t=this.getInitialZoomFactor()*this.zoomFactor,e=-this.offset.x/t,n=-this.offset.y/t,o="scale3d("+t+", "+t+",1) translate3d("+e+"px,"+n+"px,0px)",i="scale("+t+", "+t+") translate("+e+"px,"+n+"px)",a=function(){this.clone&&(this.clone.parentNode.removeChild(this.clone),delete this.clone)}.bind(this);!this.options.use2d||this.hasInteraction||this.inAnimation?(this.is3d=!0,a(),this.el.style.webkitTransform=o,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=o):(this.is3d&&(this.clone=this.el.cloneNode(!0),this.clone.style.pointerEvents="none",this.container.appendChild(this.clone),window.setTimeout(a,200)),this.el.style.webkitTransform=i,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=i,this.is3d=!1)}.bind(this),0))},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},destroy:function(){window.removeEventListener("resize",this.resizeHandler),this.container&&(this.container.remove(),this.container=null)},reset:function(){this.zoomOutAnimation()}};var n=function(t,e){var n=null,o=0,i=null,a=null,s=function(t,o){if(n!==t){if(n&&!t)switch(n){case"zoom":e.handleZoomEnd(o);break;case"drag":e.handleDragEnd(o)}switch(t){case"zoom":e.handleZoomStart(o);break;case"drag":e.handleDragStart(o)}}n=t},r=function(t){2===o?s("zoom"):1===o&&e.canDrag()?s("drag",t):s(null,t)},l=function(t){return Array.from(t).map((function(t){return{x:t.pageX,y:t.pageY}}))},c=function(t,e){var n,o;return n=t.x-e.x,o=t.y-e.y,Math.sqrt(n*n+o*o)},u=function(t){t.stopPropagation(),t.preventDefault()},h=!0;t.addEventListener("touchstart",(function(t){e.enabled&&(h=!0,o=t.touches.length,function(t){var a=(new Date).getTime();if(o>1&&(i=null),a-i<300)switch(u(t),e.handleDoubleTap(t),n){case"zoom":e.handleZoomEnd(t);break;case"drag":e.handleDragEnd(t)}else e.isDoubleTap=!1;1===o&&(i=a)}(t))}),{passive:!1}),t.addEventListener("touchmove",(function(t){if(e.enabled&&!e.isDoubleTap){if(h)r(t),n&&u(t),a=l(t.touches);else{switch(n){case"zoom":2==a.length&&2==t.touches.length&&e.handleZoom(t,function(t,e){var n=c(t[0],t[1]);return c(e[0],e[1])/n}(a,l(t.touches)));break;case"drag":e.handleDrag(t)}n&&(u(t),e.update())}h=!1}}),{passive:!1}),t.addEventListener("touchend",(function(t){e.enabled&&(o=t.touches.length,r(t))})),e.options.useMouseWheel&&(t.addEventListener("mousewheel",(function(t){e.enabled&&(u(t),e.handleMouseWheel(t))})),t.addEventListener("mousedown",(function(t){e.enabled&&(h=!0,o=1)}),{passive:!0}),t.addEventListener("mousemove",(function(t){e.enabled&&(h?(r(t),n&&u(t)):("drag"===n&&e.handleDrag(t),n&&(u(t),e.update())),h=!1)}),{passive:!1}),t.addEventListener("mouseup",(function(t){e.enabled&&(o=0,r(t))}),{passive:!0}))};return t}(),C={scrolling:"BeLzR",root:"nJWgH",layout:"BDoOb",layoutHeader:"iNVA1",slotLayoutHeader:"KxMxT",layoutContent:"C-jWr",layoutFooter:"MQh-L",layoutSection:"_3FXm5",layoutSectionContent:"WPu-a",layoutSectionFooter:"G5FaN",layoutPreviews:"gQFQR",layoutAdditional:"pw0QV",header:"meCSL",headerTitle:"NpSWI",headerClose:"-B9Zg",mainPhotoScrollControls:"ckcap",mainPhoto:"-r4WP BeLzR",mainPhotoItem:"Q7wDI",mainPhotoImage:"NrcBT",mainPhotoIframe:"kObZY",preview:"_86-3f BeLzR",previewItem:"gnB8m",previewButton:"L4PR-",previewImage:"_8dsDI",videoPlayLabel:"_2kU58",videoPlayLabelIcon:"WR7T8",enter:"sM8Qu",exit:"veHZr",enterActive:"VP4oy",exitActive:"AMPJ3"},_=y.forwardRef((function(t,e){var n=t.src,o=t.videoSrc,i=t.triggerInteraction,a=y.useRef(null),s=y.useRef(null),r=y.useRef(null),l=!!o,c=function(){var t,e;null===(t=s.current)||void 0===t||t.reset(),null===(e=a.current)||void 0===e||null===(e=e.contentWindow)||void 0===e||e.postMessage('{"event":"command","func":"pauseVideo","args":""}',"*")};return y.useEffect((function(){return requestAnimationFrame((function(){r.current&&!l&&(s.current=new z(r.current,{draggableUnzoomed:!1,animationDuration:200,setOffsetsOnce:!1,onDoubleTap:function(t){1===(null==t?void 0:t.zoomFactor)&&i("maybeZoomImage")}}))})),function(){var t;null===(t=s.current)||void 0===t||t.destroy()}}),[o]),y.useEffect((function(){var t=function(){l&&document.activeElement&&"iframe"===document.activeElement.nodeName.toLowerCase()&&a.current&&a.current===document.activeElement&&i("maybePlayVideo")};return window.addEventListener("blur",t),function(){window.removeEventListener("blur",t)}}),[o]),y.useImperativeHandle(e,(function(){return{reset:c}}),[]),l?y.createElement("iframe",{ref:a,className:C.mainPhotoIframe,src:o,width:"100%",height:"100%",allowFullScreen:!0,title:"",loading:"lazy","data-qaid":"photo_gallery_main_video","data-testid":"photo_gallery_main_video"}):y.createElement("img",{ref:r,className:C.mainPhotoImage,src:n,width:"100%",height:"100%",alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_main_image","data-testid":"photo_gallery_main_image"})}));_.displayName="MainPhotosImage";var O=y.forwardRef((function(t,e){var n=t.items,o=t.onChange,i=t.triggerInteraction,a=y.useRef(null),r=y.useRef([]),l=y.useRef(0),c=y.useRef(null),u=function(){r.current.forEach((function(t){null==t||t.reset()}))},h=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=c.current)||void 0===e?void 0:e.children[t];u(),o&&I(o,c.current,n)};y.useImperativeHandle(e,(function(){return{scrollToIndex:h}}),[]);return y.createElement(s.ScrollControls,{ref:c,className:C.mainPhotoScrollControls,showOnHover:!0,hideOnDisabled:!0,onClickPrev:function(){return i("clickPrevButton")},onClickNext:function(){return i("clickNextButton")}},y.createElement("div",{className:C.mainPhoto,onScroll:function(){if(c.current){var t=function(t,e){var n=t.scrollLeft/t.scrollWidth*e;return Math.round(n)}(c.current,n.length);l.current!==t&&(l.current=t,o(t),u())}},onTouchStart:function(t){var e=t.changedTouches[0].screenX;a.current=e},onTouchEnd:function(t){var e=t.changedTouches[0].screenX;a.current&&(a.current>e?i("maybeSwipeLeft"):a.current<e&&i("maybeSwipeRight"),a.current=null)}},n.map((function(t,e){var n,o=t.type,a=t.src,s="video"===o,l=s?T(a):a,c=s?(n=P(a),"https://youtube.com/embed/".concat(n,"?enablejsapi=1&rel=0")):void 0;return y.createElement("div",{key:e,className:C.mainPhotoItem,"data-qaid":"photo_gallery_main_item","data-testid":"photo_gallery_main_item"},y.createElement(_,{ref:function(t){r.current[e]=t},src:l,videoSrc:c,triggerInteraction:i}))}))))}));O.displayName="MainPhotos";var L,D=y.forwardRef((function(t,e){var n=t.items,o=t.selectedIndex,i=t.onChange,a=t.triggerInteraction,s=y.useRef(null),c=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=s.current)||void 0===e?void 0:e.children[t];o&&I(o,s.current,n)};y.useImperativeHandle(e,(function(){return{scrollToIndex:c}}),[]);return y.createElement("div",{ref:s,className:C.preview,onScroll:function(){a("scrollPreviews")}},n.map((function(t,e){var n=t.type,s=t.src,c="video"===n,u=c?T(s):s,h=c?"clickPreviewVideo":"clickPreviewImage";return y.createElement("div",{key:e,className:C.previewItem,"data-qaid":"photo_gallery_preview_item","data-testid":"photo_gallery_preview_item"},y.createElement("button",{className:C.previewButton,type:"button",onClick:function(){a(h),function(t){i(t)}(e)},disabled:o===e,"data-qaid":"photo_gallery_preview_button","data-testid":"photo_gallery_preview_button"},y.createElement("img",{className:C.previewImage,src:u,width:56,height:56,alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_preview_image","data-testid":"photo_gallery_preview_image"}),c&&y.createElement("div",{className:C.videoPlayLabel,"data-qaid":"photo_gallery_preview_play","data-testid":"photo_gallery_preview_play"},y.createElement(r.Icon,{className:C.videoPlayLabelIcon,"icon-as":l.SvgPlay}))))})))}));D.displayName="PreviewPhotos";var S=function(t){var e=t.title,n=t.onClose,o=t.selectedIndex,i=t.itemsLength,a=t.triggerInteraction,s=o+1,l=(0,h.useBodyStoreTTag().t)(L||(L=b.default(["Фото "," из ",""])),s,i);return y.createElement("div",{className:C.header},y.createElement("div",{className:C.headerTitle,"data-qaid":"photo_gallery_title","data-testid":"photo_gallery_title"},e||l),y.createElement("div",{className:C.headerClose},y.createElement(u.Button,{"button-padding":"xxs","button-theme":"black-inherit",type:"button",onClick:function(){a("clickCloseButton"),n()},"data-qaid":"photo_gallery_close_button","data-testid":"photo_gallery_close_button"},y.createElement(r.Icon,{"icon-as":d.SvgClose2,style:{width:24,height:24}}))))},F=function(t){var e,n=t.selectedIndex,o=t.onClose,i=t.className,a=t.slotProps,s=t.itemsLength,r=y.useRef(null),l=a.component;return y.useEffect((function(){var t;null===(t=r.current)||void 0===t||t.scrollTo({top:0})}),[n]),y.createElement("div",x.default({},a.props,{ref:r,className:E.default(i,null===(e=a.props)||void 0===e?void 0:e.className)}),y.createElement(l,{selectedIndex:n,itemsLength:s,onClose:o}))},M=function(t){var e=t.isOpen,s=t.title,r=t.visibleIndex,l=void 0===r?0:r,c=t.items,u=t.zIndex,h=void 0===u?5e3:u,d=t.onClose,f=t.onChange,m=t.onInteraction,p=t.slotHeader,g=t.slotAside,b=t.slotFooter,x=t.slotMainPhotoFooter,E=y.useRef(!0),w=y.useRef(null),I=y.useRef(null),P=y.useState(l),T=v.default(P,2),z=T[0],_=T[1],L=y.useRef(null),M=function(t){"function"==typeof m&&m(t)};y.useEffect((function(){e&&"function"==typeof f&&f(z)}),[z]),y.useEffect((function(){var t,n;e&&(_(l),null===(t=I.current)||void 0===t||t.scrollToIndex(l,!1),null===(n=w.current)||void 0===n||n.scrollToIndex(l,!1))}),[e]),y.useEffect((function(){var t;if(!e)return function(){};var n=null,o=function(){n&&clearTimeout(n)},i=function(){o(),n=setTimeout((function(){var t,e;null===(t=I.current)||void 0===t||t.scrollToIndex(z,!1),null===(e=w.current)||void 0===e||e.scrollToIndex(z,!1)}),100)};return window.addEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.addEventListener("change",i),function(){var t;o(),window.removeEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.removeEventListener("change",i)}}),[e,z]);var N=function(t){var e,n;E.current=!1,_(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t),null===(n=w.current)||void 0===n||n.scrollToIndex(t)},Z=function(){d(z)};return y.createElement(y.Fragment,null,y.createElement(o.Backdrop,{isOpen:e,onClick:Z,zIndex:h,isBodyScrollLock:!0}),y.createElement(n.CSSTransition,{nodeRef:L,in:e,timeout:240,classNames:C,unmountOnExit:!0,onEntered:function(){return M("opened")},onExited:function(){return M("closed")}},y.createElement(a.Portal,null,y.createElement("div",{ref:L,className:C.root,"data-qaid":"photo_gallery","data-testid":"photo_gallery",style:{zIndex:h}},y.createElement(i.KeyPress,{code:"Escape",onKeyUp:function(){M("keyPressClose"),Z()}}),y.createElement(i.KeyPress,{code:"ArrowLeft",onKeyUp:function(){0!==z&&(M("keyPressPrev"),N(z-1))}}),y.createElement(i.KeyPress,{code:"ArrowRight",onKeyUp:function(){z!==c.length-1&&(M("keyPressNext"),N(z+1))}}),y.createElement("div",{className:C.layout},null!=p&&p.component?y.createElement(F,{className:C.slotLayoutHeader,selectedIndex:z,itemsLength:c.length,onClose:Z,slotProps:p}):y.createElement("header",{className:C.layoutHeader},y.createElement(S,{title:s,selectedIndex:z,itemsLength:c.length,onClose:Z,triggerInteraction:M})),y.createElement("div",{className:C.layoutContent},y.createElement("section",{className:C.layoutSection},y.createElement("div",{className:C.layoutSectionContent},y.createElement(O,{ref:w,items:c,onChange:function(t){var e;E.current&&(_(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t));E.current||z!==t||(E.current=!0)},triggerInteraction:M})),!(null==x||!x.component)&&y.createElement(F,{className:C.layoutSectionFooter,selectedIndex:z,itemsLength:c.length,onClose:Z,slotProps:x})),c.length>1&&y.createElement("aside",{className:C.layoutPreviews},y.createElement(D,{ref:I,items:c,selectedIndex:z,onChange:N,triggerInteraction:M})),!(null==g||!g.component)&&y.createElement(F,{className:C.layoutAdditional,selectedIndex:z,itemsLength:c.length,onClose:Z,slotProps:g})),!(null==b||!b.component)&&y.createElement(F,{className:C.layoutFooter,selectedIndex:z,itemsLength:c.length,onClose:Z,slotProps:b}))))))};M.displayName="PhotoGallery",exports.PhotoGallery=M,require("./style.production.css");
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("@babel/runtime/helpers/slicedToArray"),t=require("react"),n=require("react-transition-group"),o=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),a=require("@prom-ui/core/Portal"),s=require("@prom-ui/core/ScrollControls"),r=require("@prom-ui/core/Icon"),l=require("@prom-ui/icons/Play"),c=require("@prom-ui/icons/StarFill"),u=require("@babel/runtime/helpers/taggedTemplateLiteral"),h=require("@prom-ui/core/Button"),d=require("@prom-ui/core/BodyProvider"),f=require("@prom-ui/icons/Close2"),m=require("@babel/runtime/helpers/extends"),p=require("clsx");function g(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function v(e){if(e&&"object"==typeof e&&"default"in e)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,o.get?o:{enumerable:!0,get:function(){return e[n]}})}}),t.default=e,Object.freeze(t)}var y=g(e),b=v(t),E=g(u),x=g(m),w=g(p),I=new Map,P=function(e,t){var n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];if(t){I.has(t)&&(cancelAnimationFrame(I.get(t)),I.delete(t));var o=requestAnimationFrame(function(){var o=t.getBoundingClientRect(),i=e.getBoundingClientRect(),a=i.top+t.scrollTop-o.top-o.height/2+i.height/2,s=i.left+t.scrollLeft-o.left-o.width/2+i.width/2;s<0&&(s=0),a<0&&(a=0),t.scrollTo({behavior:n?"smooth":"instant",top:a,left:s})});I.set(t,o)}},T=function(e){var t=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?v(?:i)?=|\&v(?:i)?=))([^#\&\?]*).*/.exec(e);return t&&t[1]},_=function(e){var t=T(e);return"https://img.youtube.com/vi/".concat(t,"/0.jpg")},z=function(){var e=function(e,t){this.el=e,this.zoomFactor=1,this.lastScale=1,this.offset={x:0,y:0},this.initialOffset={x:0,y:0},this.options=Object.assign({},this.defaults,t),this.setupMarkup(),this.bindEvents(),this.update(),this.isImageLoaded(this.el)&&(this.updateAspectRatio(),this.setupOffsets()),this.enable()},t=function(e,t){return e+t};e.prototype={defaults:{tapZoomFactor:2,zoomOutFactor:1.3,animationDuration:300,maxZoom:4,minZoom:.5,draggableUnzoomed:!0,lockDragAxis:!1,setOffsetsOnce:!1,use2d:!0,useMouseWheel:!1,verticalPadding:0,horizontalPadding:0,onZoomStart:null,onZoomEnd:null,onZoomUpdate:null,onDragStart:null,onDragEnd:null,onDragUpdate:null,onDoubleTap:null,onMouseWheel:null},handleDragStart:function(e){"function"==typeof this.options.onDragStart&&this.options.onDragStart(this,e),this.stopAnimation(),this.lastDragPosition=!1,this.hasInteraction=!0,this.handleDrag(e)},handleDrag:function(e){var t="touchmove"===e.type?this.getTouches(e)[0]:this.getPointer(e);this.drag(t,this.lastDragPosition),this.offset=this.sanitizeOffset(this.offset),this.lastDragPosition=t},handleDragEnd:function(){"function"==typeof this.options.onDragEnd&&this.options.onDragEnd(this,event),this.end()},handleZoomStart:function(e){"function"==typeof this.options.onZoomStart&&this.options.onZoomStart(this,e),this.stopAnimation(),this.lastScale=1,this.nthZoom=0,this.lastZoomCenter=!1,this.hasInteraction=!0},handleZoom:function(e,t){var n=this.getTouchCenter(this.getTouches(e)),o=t/this.lastScale;this.lastScale=t,this.nthZoom+=1,this.nthZoom>3&&(this.scale(o,n),this.drag(n,this.lastZoomCenter)),this.lastZoomCenter=n},handleZoomEnd:function(){"function"==typeof this.options.onZoomEnd&&this.options.onZoomEnd(this,event),this.end()},handleDoubleTap:function(e){var t=this.getTouches(e)[0],n=this.zoomFactor>1?1:this.options.tapZoomFactor,o=this.zoomFactor,i=function(e){this.scaleTo(o+e*(n-o),t)}.bind(this);this.hasInteraction||(this.isDoubleTap=!0,o>n&&(t=this.getCurrentZoomCenter()),this.animate(this.options.animationDuration,i,this.swing),"function"==typeof this.options.onDoubleTap&&this.options.onDoubleTap(this,e))},handleMouseWheel:function(e){var t=this.getPointer(e),n=Math.min(Math.max(this.options.minZoom,this.lastScale+-.01*e.deltaY),this.options.maxZoom),o=n/this.lastScale;this.scale(o,t),this.lastScale=n,this.update(),"function"==typeof this.options.onMouseWheel&&this.options.onMouseWheel(this,e)},computeInitialOffset:function(){this.initialOffset={x:-Math.abs(this.el.offsetWidth*this.getInitialZoomFactor()-this.container.offsetWidth)/2,y:-Math.abs(this.el.offsetHeight*this.getInitialZoomFactor()-this.container.offsetHeight)/2}},resetOffset:function(){this.offset.x=this.initialOffset.x,this.offset.y=this.initialOffset.y},isImageLoaded:function(e){return"IMG"===e.nodeName?e.complete&&0!==e.naturalHeight:Array.from(e.querySelectorAll("img")).every(this.isImageLoaded)},setupOffsets:function(){this.options.setOffsetsOnce&&this._isOffsetsSet||(this._isOffsetsSet=!0,this.computeInitialOffset(),this.resetOffset())},sanitizeOffset:function(e){var t=this.el.offsetWidth*this.getInitialZoomFactor()*this.zoomFactor,n=this.el.offsetHeight*this.getInitialZoomFactor()*this.zoomFactor,o=t-this.getContainerX()+this.options.horizontalPadding,i=n-this.getContainerY()+this.options.verticalPadding,a=Math.max(o,0),s=Math.max(i,0),r=Math.min(o,0)-this.options.horizontalPadding,l=Math.min(i,0)-this.options.verticalPadding;return{x:Math.min(Math.max(e.x,r),a),y:Math.min(Math.max(e.y,l),s)}},scaleTo:function(e,t){this.scale(e/this.zoomFactor,t)},scale:function(e,t){e=this.scaleZoomFactor(e),this.addOffset({x:(e-1)*(t.x+this.offset.x),y:(e-1)*(t.y+this.offset.y)}),"function"==typeof this.options.onZoomUpdate&&this.options.onZoomUpdate(this,event)},scaleZoomFactor:function(e){var t=this.zoomFactor;return this.zoomFactor*=e,this.zoomFactor=Math.min(this.options.maxZoom,Math.max(this.zoomFactor,this.options.minZoom)),this.zoomFactor/t},canDrag:function(){return this.options.draggableUnzoomed||!((e=this.zoomFactor)>(t=1)-.01&&e<t+.01);var e,t},drag:function(e,t){t&&(this.options.lockDragAxis?Math.abs(e.x-t.x)>Math.abs(e.y-t.y)?this.addOffset({x:-(e.x-t.x),y:0}):this.addOffset({y:-(e.y-t.y),x:0}):this.addOffset({y:-(e.y-t.y),x:-(e.x-t.x)}),"function"==typeof this.options.onDragUpdate&&this.options.onDragUpdate(this,event))},getTouchCenter:function(e){return this.getVectorAvg(e)},getVectorAvg:function(e){return{x:e.map(function(e){return e.x}).reduce(t)/e.length,y:e.map(function(e){return e.y}).reduce(t)/e.length}},addOffset:function(e){this.offset={x:this.offset.x+e.x,y:this.offset.y+e.y}},sanitize:function(){this.zoomFactor<this.options.zoomOutFactor?this.zoomOutAnimation():this.isInsaneOffset(this.offset)&&this.sanitizeOffsetAnimation()},isInsaneOffset:function(e){var t=this.sanitizeOffset(e);return t.x!==e.x||t.y!==e.y},sanitizeOffsetAnimation:function(){var e=this.sanitizeOffset(this.offset),t=this.offset.x,n=this.offset.y,o=function(o){this.offset.x=t+o*(e.x-t),this.offset.y=n+o*(e.y-n),this.update()}.bind(this);this.animate(this.options.animationDuration,o,this.swing)},zoomOutAnimation:function(){if(1!==this.zoomFactor){var e=this.zoomFactor,t=this.getCurrentZoomCenter(),n=function(n){this.scaleTo(e+n*(1-e),t)}.bind(this);this.animate(this.options.animationDuration,n,this.swing)}},updateAspectRatio:function(){this.unsetContainerY(),this.setContainerY(this.container.parentElement.offsetHeight)},getInitialZoomFactor:function(){var e=this.container.offsetWidth/this.el.offsetWidth,t=this.container.offsetHeight/this.el.offsetHeight;return Math.min(e,t)},getAspectRatio:function(){return this.el.offsetWidth/this.el.offsetHeight},getCurrentZoomCenter:function(){var e=this.offset.x-this.initialOffset.x,t=-1*this.offset.x-e/(1/this.zoomFactor-1),n=this.offset.y-this.initialOffset.y;return{x:t,y:-1*this.offset.y-n/(1/this.zoomFactor-1)}},getTouches:function(e){var t=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=t.top+n,a=t.left+o;return Array.prototype.slice.call(e.touches).map(function(e){return{x:e.pageX-a,y:e.pageY-i}})},getPointer:function(e){var t=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=t.top+n,a=t.left+o;return{x:e.pageX-a,y:e.pageY-i}},animate:function(e,t,n,o){var i=(new Date).getTime(),a=function(){if(this.inAnimation){var s=(new Date).getTime()-i,r=s/e;s>=e?(t(1),o&&o(),this.update(),this.stopAnimation(),this.update()):(n&&(r=n(r)),t(r),this.update(),requestAnimationFrame(a))}}.bind(this);this.inAnimation=!0,requestAnimationFrame(a)},stopAnimation:function(){this.inAnimation=!1},swing:function(e){return-Math.cos(e*Math.PI)/2+.5},getContainerX:function(){return this.container.offsetWidth},getContainerY:function(){return this.container.offsetHeight},setContainerY:function(e){return this.container.style.height=e+"px"},unsetContainerY:function(){this.container.style.height=null},setupMarkup:function(){var e,t;this.container=(e='<div class="pinch-zoom-container" style="height: 100%;"></div>',(t=document.implementation.createHTMLDocument("")).body.innerHTML=e,Array.from(t.body.children)[0]),this.el.parentNode.insertBefore(this.container,this.el),this.container.appendChild(this.el),this.container.style.overflow="hidden",this.container.style.position="relative",this.el.style.webkitTransformOrigin="0% 0%",this.el.style.mozTransformOrigin="0% 0%",this.el.style.msTransformOrigin="0% 0%",this.el.style.oTransformOrigin="0% 0%",this.el.style.transformOrigin="0% 0%",this.el.style.position="absolute",this.el.style.backfaceVisibility="hidden",this.el.style.willChange="transform"},end:function(){this.hasInteraction=!1,this.sanitize(),this.update()},bindEvents:function(){var e=this;n(this.container,this),this.resizeHandler=this.update.bind(this),window.addEventListener("resize",this.resizeHandler),Array.from(this.el.querySelectorAll("img")).forEach(function(t){t.addEventListener("load",e.update.bind(e))}),"IMG"===this.el.nodeName&&this.el.addEventListener("load",this.update.bind(this))},update:function(e){e&&"resize"===e.type&&(this.updateAspectRatio(),this.setupOffsets()),e&&"load"===e.type&&(this.updateAspectRatio(),this.setupOffsets()),this.updatePlanned||(this.updatePlanned=!0,window.setTimeout(function(){this.updatePlanned=!1;var e=this.getInitialZoomFactor()*this.zoomFactor,t=-this.offset.x/e,n=-this.offset.y/e,o="scale3d("+e+", "+e+",1) translate3d("+t+"px,"+n+"px,0px)",i="scale("+e+", "+e+") translate("+t+"px,"+n+"px)",a=function(){this.clone&&(this.clone.parentNode.removeChild(this.clone),delete this.clone)}.bind(this);!this.options.use2d||this.hasInteraction||this.inAnimation?(this.is3d=!0,a(),this.el.style.webkitTransform=o,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=o):(this.is3d&&(this.clone=this.el.cloneNode(!0),this.clone.style.pointerEvents="none",this.container.appendChild(this.clone),window.setTimeout(a,200)),this.el.style.webkitTransform=i,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=i,this.is3d=!1)}.bind(this),0))},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},destroy:function(){window.removeEventListener("resize",this.resizeHandler),this.container&&(this.container.remove(),this.container=null)},reset:function(){this.zoomOutAnimation()}};var n=function(e,t){var n=null,o=0,i=null,a=null,s=function(e,o){if(n!==e){if(n&&!e)switch(n){case"zoom":t.handleZoomEnd(o);break;case"drag":t.handleDragEnd(o)}switch(e){case"zoom":t.handleZoomStart(o);break;case"drag":t.handleDragStart(o)}}n=e},r=function(e){2===o?s("zoom"):1===o&&t.canDrag()?s("drag",e):s(null,e)},l=function(e){return Array.from(e).map(function(e){return{x:e.pageX,y:e.pageY}})},c=function(e,t){var n,o;return n=e.x-t.x,o=e.y-t.y,Math.sqrt(n*n+o*o)},u=function(e){e.stopPropagation(),e.preventDefault()},h=!0;e.addEventListener("touchstart",function(e){t.enabled&&(h=!0,o=e.touches.length,function(e){var a=(new Date).getTime();if(o>1&&(i=null),a-i<300)switch(u(e),t.handleDoubleTap(e),n){case"zoom":t.handleZoomEnd(e);break;case"drag":t.handleDragEnd(e)}else t.isDoubleTap=!1;1===o&&(i=a)}(e))},{passive:!1}),e.addEventListener("touchmove",function(e){if(t.enabled&&!t.isDoubleTap){if(h)r(e),n&&u(e),a=l(e.touches);else{switch(n){case"zoom":2==a.length&&2==e.touches.length&&t.handleZoom(e,function(e,t){var n=c(e[0],e[1]);return c(t[0],t[1])/n}(a,l(e.touches)));break;case"drag":t.handleDrag(e)}n&&(u(e),t.update())}h=!1}},{passive:!1}),e.addEventListener("touchend",function(e){t.enabled&&(o=e.touches.length,r(e))}),t.options.useMouseWheel&&(e.addEventListener("mousewheel",function(e){t.enabled&&(u(e),t.handleMouseWheel(e))}),e.addEventListener("mousedown",function(e){t.enabled&&(h=!0,o=1)},{passive:!0}),e.addEventListener("mousemove",function(e){t.enabled&&(h?(r(e),n&&u(e)):("drag"===n&&t.handleDrag(e),n&&(u(e),t.update())),h=!1)},{passive:!1}),e.addEventListener("mouseup",function(e){t.enabled&&(o=0,r(e))},{passive:!0}))};return e}(),C={scrolling:"BeLzR",root:"nJWgH",layout:"BDoOb",layoutHeader:"iNVA1",slotLayoutHeader:"KxMxT",layoutContent:"C-jWr",layoutFooter:"MQh-L",layoutSection:"_3FXm5",layoutSectionContent:"WPu-a",layoutSectionFooter:"G5FaN",layoutPreviews:"gQFQR",layoutAdditional:"pw0QV",header:"meCSL",headerTitle:"NpSWI",headerClose:"-B9Zg",mainPhotoScrollControls:"ckcap",mainPhoto:"-r4WP BeLzR",mainPhotoItem:"Q7wDI",mainPhotoImage:"NrcBT",mainPhotoIframe:"kObZY",preview:"_86-3f BeLzR",previewItem:"gnB8m",previewButton:"L4PR-",previewImage:"_8dsDI",previewRating:"GqvTR",previewRatingIcon:"qPTNw",videoPlayLabel:"_2kU58",videoPlayLabelIcon:"WR7T8",enter:"sM8Qu",exit:"veHZr",enterActive:"VP4oy",exitActive:"AMPJ3"},O=b.forwardRef(function(e,t){var n=e.src,o=e.videoSrc,i=e.triggerInteraction,a=b.useRef(null),s=b.useRef(null),r=b.useRef(null),l=!!o,c=function(){var e,t;null===(e=s.current)||void 0===e||e.reset(),null===(t=a.current)||void 0===t||null===(t=t.contentWindow)||void 0===t||t.postMessage('{"event":"command","func":"pauseVideo","args":""}',"*")};return b.useEffect(function(){return requestAnimationFrame(function(){r.current&&!l&&(s.current=new z(r.current,{draggableUnzoomed:!1,animationDuration:200,setOffsetsOnce:!1,onDoubleTap:function(e){1===(null==e?void 0:e.zoomFactor)&&i("maybeZoomImage")}}))}),function(){var e;null===(e=s.current)||void 0===e||e.destroy()}},[o]),b.useEffect(function(){var e=function(){l&&document.activeElement&&"iframe"===document.activeElement.nodeName.toLowerCase()&&a.current&&a.current===document.activeElement&&i("maybePlayVideo")};return window.addEventListener("blur",e),function(){window.removeEventListener("blur",e)}},[o]),b.useImperativeHandle(t,function(){return{reset:c}},[]),l?b.createElement("iframe",{ref:a,className:C.mainPhotoIframe,src:o,width:"100%",height:"100%",allowFullScreen:!0,title:"",loading:"lazy","data-qaid":"photo_gallery_main_video","data-testid":"photo_gallery_main_video"}):b.createElement("img",{ref:r,className:C.mainPhotoImage,src:n,width:"100%",height:"100%",alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_main_image","data-testid":"photo_gallery_main_image"})});O.displayName="MainPhotosImage";var L=b.forwardRef(function(e,t){var n=e.items,o=e.onChange,i=e.triggerInteraction,a=b.useRef(null),r=b.useRef([]),l=b.useRef(0),c=b.useRef(null),u=function(){r.current.forEach(function(e){null==e||e.reset()})},h=function(e){var t,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(t=c.current)||void 0===t?void 0:t.children[e];u(),o&&P(o,c.current,n)};b.useImperativeHandle(t,function(){return{scrollToIndex:h}},[]);return b.createElement(s.ScrollControls,{ref:c,className:C.mainPhotoScrollControls,showOnHover:!0,hideOnDisabled:!0,onClickPrev:function(){return i("clickPrevButton")},onClickNext:function(){return i("clickNextButton")}},b.createElement("div",{className:C.mainPhoto,onScroll:function(){if(c.current){var e=function(e,t){var n=e.scrollLeft/e.scrollWidth*t;return Math.round(n)}(c.current,n.length);l.current!==e&&(l.current=e,o(e),u())}},onTouchStart:function(e){var t=e.changedTouches[0].screenX;a.current=t},onTouchEnd:function(e){var t=e.changedTouches[0].screenX;a.current&&(a.current>t?i("maybeSwipeLeft"):a.current<t&&i("maybeSwipeRight"),a.current=null)}},n.map(function(e,t){var n,o=e.type,a=e.src,s="video"===o,l=s?_(a):a,c=s?(n=T(a),"https://youtube.com/embed/".concat(n,"?enablejsapi=1&rel=0")):void 0;return b.createElement("div",{key:t,className:C.mainPhotoItem,"data-qaid":"photo_gallery_main_item","data-testid":"photo_gallery_main_item"},b.createElement(O,{ref:function(e){r.current[t]=e},src:l,videoSrc:c,triggerInteraction:i}))})))});L.displayName="MainPhotos";var S,D=b.forwardRef(function(e,t){var n=e.items,o=e.selectedIndex,i=e.onChange,a=e.triggerInteraction,s=b.useRef(null),u=function(e){var t,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(t=s.current)||void 0===t?void 0:t.children[e];o&&P(o,s.current,n)};b.useImperativeHandle(t,function(){return{scrollToIndex:u}},[]);return b.createElement("div",{ref:s,className:C.preview,onScroll:function(){a("scrollPreviews")}},n.map(function(e,t){var n=e.type,s=e.src,u=e.rating,h="video"===n,d=h?_(s):s,f=h?"clickPreviewVideo":"clickPreviewImage";return b.createElement("div",{key:t,className:C.previewItem,"data-qaid":"photo_gallery_preview_item","data-testid":"photo_gallery_preview_item"},b.createElement("button",{className:C.previewButton,type:"button",onClick:function(){a(f),function(e){i(e)}(t)},disabled:o===t,"data-qaid":"photo_gallery_preview_button","data-testid":"photo_gallery_preview_button"},b.createElement("img",{className:C.previewImage,src:d,width:56,height:56,alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_preview_image","data-testid":"photo_gallery_preview_image"}),u?b.createElement("div",{className:C.previewRating,"data-qaid":"photo_gallery_preview_rating","data-testid":"photo_gallery_preview_rating"},b.createElement(r.Icon,{className:C.previewRatingIcon,"icon-as":c.SvgStarFill}),u):null,h&&b.createElement("div",{className:C.videoPlayLabel,"data-qaid":"photo_gallery_preview_play","data-testid":"photo_gallery_preview_play"},b.createElement(r.Icon,{className:C.videoPlayLabelIcon,"icon-as":l.SvgPlay}))))}))});D.displayName="PreviewPhotos";var F=function(e){var t=e.title,n=e.onClose,o=e.selectedIndex,i=e.itemsLength,a=e.triggerInteraction,s=o+1,l=(0,d.useBodyStoreTTag().t)(S||(S=E.default(["Фото "," из ",""])),s,i);return b.createElement("div",{className:C.header},b.createElement("div",{className:C.headerTitle,"data-qaid":"photo_gallery_title","data-testid":"photo_gallery_title"},t||l),b.createElement("div",{className:C.headerClose},b.createElement(h.Button,{"button-padding":"xxs","button-theme":"black-inherit",type:"button",onClick:function(){a("clickCloseButton"),n()},"data-qaid":"photo_gallery_close_button","data-testid":"photo_gallery_close_button"},b.createElement(r.Icon,{"icon-as":f.SvgClose2,style:{width:24,height:24}}))))},N=function(e){var t,n=e.selectedIndex,o=e.onClose,i=e.className,a=e.slotProps,s=e.itemsLength,r=b.useRef(null),l=a.component;return b.useEffect(function(){var e;null===(e=r.current)||void 0===e||e.scrollTo({top:0})},[n]),b.createElement("div",x.default({},a.props,{ref:r,className:w.default(i,null===(t=a.props)||void 0===t?void 0:t.className)}),b.createElement(l,{selectedIndex:n,itemsLength:s,onClose:o}))},M=function(e){var t=e.isOpen,s=e.title,r=e.visibleIndex,l=void 0===r?0:r,c=e.items,u=e.zIndex,h=void 0===u?5e3:u,d=e.onClose,f=e.onChange,m=e.onInteraction,p=e.slotHeader,g=e.slotAside,v=e.slotFooter,E=e.slotMainPhotoFooter,x=b.useRef(!0),w=b.useRef(null),I=b.useRef(null),P=b.useState(l),T=y.default(P,2),_=T[0],z=T[1],O=b.useRef(null),S=function(e){"function"==typeof m&&m(e)};b.useEffect(function(){t&&"function"==typeof f&&f(_)},[_]),b.useEffect(function(){var e,n;t&&(z(l),null===(e=I.current)||void 0===e||e.scrollToIndex(l,!1),null===(n=w.current)||void 0===n||n.scrollToIndex(l,!1))},[t]),b.useEffect(function(){var e;if(!t)return function(){};var n=null,o=function(){n&&clearTimeout(n)},i=function(){o(),n=setTimeout(function(){var e,t;null===(e=I.current)||void 0===e||e.scrollToIndex(_,!1),null===(t=w.current)||void 0===t||t.scrollToIndex(_,!1)},100)};return window.addEventListener("resize",i),null===(e=window)||void 0===e||null===(e=e.matchMedia("(orientation: portrait)"))||void 0===e||e.addEventListener("change",i),function(){var e;o(),window.removeEventListener("resize",i),null===(e=window)||void 0===e||null===(e=e.matchMedia("(orientation: portrait)"))||void 0===e||e.removeEventListener("change",i)}},[t,_]);var M=function(e){var t,n;x.current=!1,z(e),null===(t=I.current)||void 0===t||t.scrollToIndex(e),null===(n=w.current)||void 0===n||n.scrollToIndex(e)},Z=function(){d(_)};return b.createElement(b.Fragment,null,b.createElement(o.Backdrop,{isOpen:t,onClick:Z,zIndex:h,isBodyScrollLock:!0}),b.createElement(n.CSSTransition,{nodeRef:O,in:t,timeout:240,classNames:C,unmountOnExit:!0,onEntered:function(){return S("opened")},onExited:function(){return S("closed")}},b.createElement(a.Portal,null,b.createElement("div",{ref:O,className:C.root,"data-qaid":"photo_gallery","data-testid":"photo_gallery",style:{zIndex:h}},b.createElement(i.KeyPress,{code:"Escape",onKeyUp:function(){S("keyPressClose"),Z()}}),b.createElement(i.KeyPress,{code:"ArrowLeft",onKeyUp:function(){0!==_&&(S("keyPressPrev"),M(_-1))}}),b.createElement(i.KeyPress,{code:"ArrowRight",onKeyUp:function(){_!==c.length-1&&(S("keyPressNext"),M(_+1))}}),b.createElement("div",{className:C.layout},null!=p&&p.component?b.createElement(N,{className:C.slotLayoutHeader,selectedIndex:_,itemsLength:c.length,onClose:Z,slotProps:p}):b.createElement("header",{className:C.layoutHeader},b.createElement(F,{title:s,selectedIndex:_,itemsLength:c.length,onClose:Z,triggerInteraction:S})),b.createElement("div",{className:C.layoutContent},b.createElement("section",{className:C.layoutSection},b.createElement("div",{className:C.layoutSectionContent},b.createElement(L,{ref:w,items:c,onChange:function(e){var t;x.current&&(z(e),null===(t=I.current)||void 0===t||t.scrollToIndex(e));x.current||_!==e||(x.current=!0)},triggerInteraction:S})),!(null==E||!E.component)&&b.createElement(N,{className:C.layoutSectionFooter,selectedIndex:_,itemsLength:c.length,onClose:Z,slotProps:E})),c.length>1&&b.createElement("aside",{className:C.layoutPreviews},b.createElement(D,{ref:I,items:c,selectedIndex:_,onChange:M,triggerInteraction:S})),!(null==g||!g.component)&&b.createElement(N,{className:C.layoutAdditional,selectedIndex:_,itemsLength:c.length,onClose:Z,slotProps:g})),!(null==v||!v.component)&&b.createElement(N,{className:C.layoutFooter,selectedIndex:_,itemsLength:c.length,onClose:Z,slotProps:v}))))))};M.displayName="PhotoGallery",exports.PhotoGallery=M,require("./style.production.css");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var t=require("@babel/runtime/helpers/slicedToArray"),e=require("react"),n=require("react-transition-group"),o=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),a=require("@prom-ui/core/Portal"),s=require("@prom-ui/core/ScrollControls"),r=require("@prom-ui/core/Icon"),l=require("@prom-ui/icons/Play"),c=require("@babel/runtime/helpers/taggedTemplateLiteral"),u=require("@prom-ui/core/Button"),h=require("@prom-ui/core/BodyProvider"),d=require("@prom-ui/icons/Close2"),f=require("@babel/runtime/helpers/extends"),m=require("clsx");function p(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}function g(t){if(t&&"object"==typeof t&&"default"in t)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,o.get?o:{enumerable:!0,get:function(){return t[n]}})}})),e.default=t,Object.freeze(e)}var v=p(t),y=g(e),b=p(c),x=p(f),E=p(m),w=new Map,I=function(t,e){var n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];if(e){w.has(e)&&(cancelAnimationFrame(w.get(e)),w.delete(e));var o=requestAnimationFrame((function(){var o=e.getBoundingClientRect(),i=t.getBoundingClientRect(),a=i.top+e.scrollTop-o.top-o.height/2+i.height/2,s=i.left+e.scrollLeft-o.left-o.width/2+i.width/2;s<0&&(s=0),a<0&&(a=0),e.scrollTo({behavior:n?"smooth":"instant",top:a,left:s})}));w.set(e,o)}},T=function(t){var e=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?v(?:i)?=|\&v(?:i)?=))([^#\&\?]*).*/.exec(t);return e&&e[1]},P=function(t){var e=T(t);return"https://img.youtube.com/vi/".concat(e,"/0.jpg")},z=function(){var t=function(t,e){this.el=t,this.zoomFactor=1,this.lastScale=1,this.offset={x:0,y:0},this.initialOffset={x:0,y:0},this.options=Object.assign({},this.defaults,e),this.setupMarkup(),this.bindEvents(),this.update(),this.isImageLoaded(this.el)&&(this.updateAspectRatio(),this.setupOffsets()),this.enable()},e=function(t,e){return t+e};t.prototype={defaults:{tapZoomFactor:2,zoomOutFactor:1.3,animationDuration:300,maxZoom:4,minZoom:.5,draggableUnzoomed:!0,lockDragAxis:!1,setOffsetsOnce:!1,use2d:!0,useMouseWheel:!1,verticalPadding:0,horizontalPadding:0,onZoomStart:null,onZoomEnd:null,onZoomUpdate:null,onDragStart:null,onDragEnd:null,onDragUpdate:null,onDoubleTap:null,onMouseWheel:null},handleDragStart:function(t){"function"==typeof this.options.onDragStart&&this.options.onDragStart(this,t),this.stopAnimation(),this.lastDragPosition=!1,this.hasInteraction=!0,this.handleDrag(t)},handleDrag:function(t){var e="touchmove"===t.type?this.getTouches(t)[0]:this.getPointer(t);this.drag(e,this.lastDragPosition),this.offset=this.sanitizeOffset(this.offset),this.lastDragPosition=e},handleDragEnd:function(){"function"==typeof this.options.onDragEnd&&this.options.onDragEnd(this,event),this.end()},handleZoomStart:function(t){"function"==typeof this.options.onZoomStart&&this.options.onZoomStart(this,t),this.stopAnimation(),this.lastScale=1,this.nthZoom=0,this.lastZoomCenter=!1,this.hasInteraction=!0},handleZoom:function(t,e){var n=this.getTouchCenter(this.getTouches(t)),o=e/this.lastScale;this.lastScale=e,this.nthZoom+=1,this.nthZoom>3&&(this.scale(o,n),this.drag(n,this.lastZoomCenter)),this.lastZoomCenter=n},handleZoomEnd:function(){"function"==typeof this.options.onZoomEnd&&this.options.onZoomEnd(this,event),this.end()},handleDoubleTap:function(t){var e=this.getTouches(t)[0],n=this.zoomFactor>1?1:this.options.tapZoomFactor,o=this.zoomFactor,i=function(t){this.scaleTo(o+t*(n-o),e)}.bind(this);this.hasInteraction||(this.isDoubleTap=!0,o>n&&(e=this.getCurrentZoomCenter()),this.animate(this.options.animationDuration,i,this.swing),"function"==typeof this.options.onDoubleTap&&this.options.onDoubleTap(this,t))},handleMouseWheel:function(t){var e=this.getPointer(t),n=Math.min(Math.max(this.options.minZoom,this.lastScale+-.01*t.deltaY),this.options.maxZoom),o=n/this.lastScale;this.scale(o,e),this.lastScale=n,this.update(),"function"==typeof this.options.onMouseWheel&&this.options.onMouseWheel(this,t)},computeInitialOffset:function(){this.initialOffset={x:-Math.abs(this.el.offsetWidth*this.getInitialZoomFactor()-this.container.offsetWidth)/2,y:-Math.abs(this.el.offsetHeight*this.getInitialZoomFactor()-this.container.offsetHeight)/2}},resetOffset:function(){this.offset.x=this.initialOffset.x,this.offset.y=this.initialOffset.y},isImageLoaded:function(t){return"IMG"===t.nodeName?t.complete&&0!==t.naturalHeight:Array.from(t.querySelectorAll("img")).every(this.isImageLoaded)},setupOffsets:function(){this.options.setOffsetsOnce&&this._isOffsetsSet||(this._isOffsetsSet=!0,this.computeInitialOffset(),this.resetOffset())},sanitizeOffset:function(t){var e=this.el.offsetWidth*this.getInitialZoomFactor()*this.zoomFactor,n=this.el.offsetHeight*this.getInitialZoomFactor()*this.zoomFactor,o=e-this.getContainerX()+this.options.horizontalPadding,i=n-this.getContainerY()+this.options.verticalPadding,a=Math.max(o,0),s=Math.max(i,0),r=Math.min(o,0)-this.options.horizontalPadding,l=Math.min(i,0)-this.options.verticalPadding;return{x:Math.min(Math.max(t.x,r),a),y:Math.min(Math.max(t.y,l),s)}},scaleTo:function(t,e){this.scale(t/this.zoomFactor,e)},scale:function(t,e){t=this.scaleZoomFactor(t),this.addOffset({x:(t-1)*(e.x+this.offset.x),y:(t-1)*(e.y+this.offset.y)}),"function"==typeof this.options.onZoomUpdate&&this.options.onZoomUpdate(this,event)},scaleZoomFactor:function(t){var e=this.zoomFactor;return this.zoomFactor*=t,this.zoomFactor=Math.min(this.options.maxZoom,Math.max(this.zoomFactor,this.options.minZoom)),this.zoomFactor/e},canDrag:function(){return this.options.draggableUnzoomed||!((t=this.zoomFactor)>(e=1)-.01&&t<e+.01);var t,e},drag:function(t,e){e&&(this.options.lockDragAxis?Math.abs(t.x-e.x)>Math.abs(t.y-e.y)?this.addOffset({x:-(t.x-e.x),y:0}):this.addOffset({y:-(t.y-e.y),x:0}):this.addOffset({y:-(t.y-e.y),x:-(t.x-e.x)}),"function"==typeof this.options.onDragUpdate&&this.options.onDragUpdate(this,event))},getTouchCenter:function(t){return this.getVectorAvg(t)},getVectorAvg:function(t){return{x:t.map((function(t){return t.x})).reduce(e)/t.length,y:t.map((function(t){return t.y})).reduce(e)/t.length}},addOffset:function(t){this.offset={x:this.offset.x+t.x,y:this.offset.y+t.y}},sanitize:function(){this.zoomFactor<this.options.zoomOutFactor?this.zoomOutAnimation():this.isInsaneOffset(this.offset)&&this.sanitizeOffsetAnimation()},isInsaneOffset:function(t){var e=this.sanitizeOffset(t);return e.x!==t.x||e.y!==t.y},sanitizeOffsetAnimation:function(){var t=this.sanitizeOffset(this.offset),e=this.offset.x,n=this.offset.y,o=function(o){this.offset.x=e+o*(t.x-e),this.offset.y=n+o*(t.y-n),this.update()}.bind(this);this.animate(this.options.animationDuration,o,this.swing)},zoomOutAnimation:function(){if(1!==this.zoomFactor){var t=this.zoomFactor,e=this.getCurrentZoomCenter(),n=function(n){this.scaleTo(t+n*(1-t),e)}.bind(this);this.animate(this.options.animationDuration,n,this.swing)}},updateAspectRatio:function(){this.unsetContainerY(),this.setContainerY(this.container.parentElement.offsetHeight)},getInitialZoomFactor:function(){var t=this.container.offsetWidth/this.el.offsetWidth,e=this.container.offsetHeight/this.el.offsetHeight;return Math.min(t,e)},getAspectRatio:function(){return this.el.offsetWidth/this.el.offsetHeight},getCurrentZoomCenter:function(){var t=this.offset.x-this.initialOffset.x,e=-1*this.offset.x-t/(1/this.zoomFactor-1),n=this.offset.y-this.initialOffset.y;return{x:e,y:-1*this.offset.y-n/(1/this.zoomFactor-1)}},getTouches:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return Array.prototype.slice.call(t.touches).map((function(t){return{x:t.pageX-a,y:t.pageY-i}}))},getPointer:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return{x:t.pageX-a,y:t.pageY-i}},animate:function(t,e,n,o){var i=(new Date).getTime(),a=function(){if(this.inAnimation){var s=(new Date).getTime()-i,r=s/t;s>=t?(e(1),o&&o(),this.update(),this.stopAnimation(),this.update()):(n&&(r=n(r)),e(r),this.update(),requestAnimationFrame(a))}}.bind(this);this.inAnimation=!0,requestAnimationFrame(a)},stopAnimation:function(){this.inAnimation=!1},swing:function(t){return-Math.cos(t*Math.PI)/2+.5},getContainerX:function(){return this.container.offsetWidth},getContainerY:function(){return this.container.offsetHeight},setContainerY:function(t){return this.container.style.height=t+"px"},unsetContainerY:function(){this.container.style.height=null},setupMarkup:function(){var t,e;this.container=(t='<div class="pinch-zoom-container" style="height: 100%;"></div>',(e=document.implementation.createHTMLDocument("")).body.innerHTML=t,Array.from(e.body.children)[0]),this.el.parentNode.insertBefore(this.container,this.el),this.container.appendChild(this.el),this.container.style.overflow="hidden",this.container.style.position="relative",this.el.style.webkitTransformOrigin="0% 0%",this.el.style.mozTransformOrigin="0% 0%",this.el.style.msTransformOrigin="0% 0%",this.el.style.oTransformOrigin="0% 0%",this.el.style.transformOrigin="0% 0%",this.el.style.position="absolute",this.el.style.backfaceVisibility="hidden",this.el.style.willChange="transform"},end:function(){this.hasInteraction=!1,this.sanitize(),this.update()},bindEvents:function(){var t=this;n(this.container,this),this.resizeHandler=this.update.bind(this),window.addEventListener("resize",this.resizeHandler),Array.from(this.el.querySelectorAll("img")).forEach((function(e){e.addEventListener("load",t.update.bind(t))})),"IMG"===this.el.nodeName&&this.el.addEventListener("load",this.update.bind(this))},update:function(t){t&&"resize"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),t&&"load"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),this.updatePlanned||(this.updatePlanned=!0,window.setTimeout(function(){this.updatePlanned=!1;var t=this.getInitialZoomFactor()*this.zoomFactor,e=-this.offset.x/t,n=-this.offset.y/t,o="scale3d("+t+", "+t+",1) translate3d("+e+"px,"+n+"px,0px)",i="scale("+t+", "+t+") translate("+e+"px,"+n+"px)",a=function(){this.clone&&(this.clone.parentNode.removeChild(this.clone),delete this.clone)}.bind(this);!this.options.use2d||this.hasInteraction||this.inAnimation?(this.is3d=!0,a(),this.el.style.webkitTransform=o,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=o):(this.is3d&&(this.clone=this.el.cloneNode(!0),this.clone.style.pointerEvents="none",this.container.appendChild(this.clone),window.setTimeout(a,200)),this.el.style.webkitTransform=i,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=i,this.is3d=!1)}.bind(this),0))},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},destroy:function(){window.removeEventListener("resize",this.resizeHandler),this.container&&(this.container.remove(),this.container=null)},reset:function(){this.zoomOutAnimation()}};var n=function(t,e){var n=null,o=0,i=null,a=null,s=function(t,o){if(n!==t){if(n&&!t)switch(n){case"zoom":e.handleZoomEnd(o);break;case"drag":e.handleDragEnd(o)}switch(t){case"zoom":e.handleZoomStart(o);break;case"drag":e.handleDragStart(o)}}n=t},r=function(t){2===o?s("zoom"):1===o&&e.canDrag()?s("drag",t):s(null,t)},l=function(t){return Array.from(t).map((function(t){return{x:t.pageX,y:t.pageY}}))},c=function(t,e){var n,o;return n=t.x-e.x,o=t.y-e.y,Math.sqrt(n*n+o*o)},u=function(t){t.stopPropagation(),t.preventDefault()},h=!0;t.addEventListener("touchstart",(function(t){e.enabled&&(h=!0,o=t.touches.length,function(t){var a=(new Date).getTime();if(o>1&&(i=null),a-i<300)switch(u(t),e.handleDoubleTap(t),n){case"zoom":e.handleZoomEnd(t);break;case"drag":e.handleDragEnd(t)}else e.isDoubleTap=!1;1===o&&(i=a)}(t))}),{passive:!1}),t.addEventListener("touchmove",(function(t){if(e.enabled&&!e.isDoubleTap){if(h)r(t),n&&u(t),a=l(t.touches);else{switch(n){case"zoom":2==a.length&&2==t.touches.length&&e.handleZoom(t,function(t,e){var n=c(t[0],t[1]);return c(e[0],e[1])/n}(a,l(t.touches)));break;case"drag":e.handleDrag(t)}n&&(u(t),e.update())}h=!1}}),{passive:!1}),t.addEventListener("touchend",(function(t){e.enabled&&(o=t.touches.length,r(t))})),e.options.useMouseWheel&&(t.addEventListener("mousewheel",(function(t){e.enabled&&(u(t),e.handleMouseWheel(t))})),t.addEventListener("mousedown",(function(t){e.enabled&&(h=!0,o=1)}),{passive:!0}),t.addEventListener("mousemove",(function(t){e.enabled&&(h?(r(t),n&&u(t)):("drag"===n&&e.handleDrag(t),n&&(u(t),e.update())),h=!1)}),{passive:!1}),t.addEventListener("mouseup",(function(t){e.enabled&&(o=0,r(t))}),{passive:!0}))};return t}(),C={scrolling:"q1DKc",root:"KiBKq",layout:"JBDok",layoutHeader:"tVG4b",slotLayoutHeader:"_8R2r5",layoutContent:"O43ff",layoutFooter:"Gz4gH",layoutSection:"CvZb6",layoutSectionContent:"_2TSDW",layoutSectionFooter:"LTbHF",layoutPreviews:"-hzyv",layoutAdditional:"mR5-f",header:"xfAad",headerTitle:"QiOEy",headerClose:"qdl3x",mainPhotoScrollControls:"PeY3Y",mainPhoto:"QIMHy q1DKc",mainPhotoItem:"aZCyk",mainPhotoImage:"_2aEr5",mainPhotoIframe:"kThdT",preview:"F-k0z q1DKc",previewItem:"jf683",previewButton:"VAXOP",previewImage:"Mx2Y-",videoPlayLabel:"jQiDN",videoPlayLabelIcon:"wSdjd",enter:"Lnosr",exit:"NW-xY",enterActive:"LrirU",exitActive:"L6st-"},O=y.forwardRef((function(t,e){var n=t.src,o=t.videoSrc,i=t.triggerInteraction,a=y.useRef(null),s=y.useRef(null),r=y.useRef(null),l=!!o,c=function(){var t,e;null===(t=s.current)||void 0===t||t.reset(),null===(e=a.current)||void 0===e||null===(e=e.contentWindow)||void 0===e||e.postMessage('{"event":"command","func":"pauseVideo","args":""}',"*")};return y.useEffect((function(){return requestAnimationFrame((function(){r.current&&!l&&(s.current=new z(r.current,{draggableUnzoomed:!1,animationDuration:200,setOffsetsOnce:!1,onDoubleTap:function(t){1===(null==t?void 0:t.zoomFactor)&&i("maybeZoomImage")}}))})),function(){var t;null===(t=s.current)||void 0===t||t.destroy()}}),[o]),y.useEffect((function(){var t=function(){l&&document.activeElement&&"iframe"===document.activeElement.nodeName.toLowerCase()&&a.current&&a.current===document.activeElement&&i("maybePlayVideo")};return window.addEventListener("blur",t),function(){window.removeEventListener("blur",t)}}),[o]),y.useImperativeHandle(e,(function(){return{reset:c}}),[]),l?y.createElement("iframe",{ref:a,className:C.mainPhotoIframe,src:o,width:"100%",height:"100%",allowFullScreen:!0,title:"",loading:"lazy","data-qaid":"photo_gallery_main_video","data-testid":"photo_gallery_main_video"}):y.createElement("img",{ref:r,className:C.mainPhotoImage,src:n,width:"100%",height:"100%",alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_main_image","data-testid":"photo_gallery_main_image"})}));O.displayName="MainPhotosImage";var _=y.forwardRef((function(t,e){var n=t.items,o=t.onChange,i=t.triggerInteraction,a=y.useRef(null),r=y.useRef([]),l=y.useRef(0),c=y.useRef(null),u=function(){r.current.forEach((function(t){null==t||t.reset()}))},h=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=c.current)||void 0===e?void 0:e.children[t];u(),o&&I(o,c.current,n)};y.useImperativeHandle(e,(function(){return{scrollToIndex:h}}),[]);return y.createElement(s.ScrollControls,{ref:c,className:C.mainPhotoScrollControls,showOnHover:!0,hideOnDisabled:!0,onClickPrev:function(){return i("clickPrevButton")},onClickNext:function(){return i("clickNextButton")}},y.createElement("div",{className:C.mainPhoto,onScroll:function(){if(c.current){var t=function(t,e){var n=t.scrollLeft/t.scrollWidth*e;return Math.round(n)}(c.current,n.length);l.current!==t&&(l.current=t,o(t),u())}},onTouchStart:function(t){var e=t.changedTouches[0].screenX;a.current=e},onTouchEnd:function(t){var e=t.changedTouches[0].screenX;a.current&&(a.current>e?i("maybeSwipeLeft"):a.current<e&&i("maybeSwipeRight"),a.current=null)}},n.map((function(t,e){var n,o=t.type,a=t.src,s="video"===o,l=s?P(a):a,c=s?(n=T(a),"https://youtube.com/embed/".concat(n,"?enablejsapi=1&rel=0")):void 0;return y.createElement("div",{key:e,className:C.mainPhotoItem,"data-qaid":"photo_gallery_main_item","data-testid":"photo_gallery_main_item"},y.createElement(O,{ref:function(t){r.current[e]=t},src:l,videoSrc:c,triggerInteraction:i}))}))))}));_.displayName="MainPhotos";var D,L=y.forwardRef((function(t,e){var n=t.items,o=t.selectedIndex,i=t.onChange,a=t.triggerInteraction,s=y.useRef(null),c=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=s.current)||void 0===e?void 0:e.children[t];o&&I(o,s.current,n)};y.useImperativeHandle(e,(function(){return{scrollToIndex:c}}),[]);return y.createElement("div",{ref:s,className:C.preview,onScroll:function(){a("scrollPreviews")}},n.map((function(t,e){var n=t.type,s=t.src,c="video"===n,u=c?P(s):s,h=c?"clickPreviewVideo":"clickPreviewImage";return y.createElement("div",{key:e,className:C.previewItem,"data-qaid":"photo_gallery_preview_item","data-testid":"photo_gallery_preview_item"},y.createElement("button",{className:C.previewButton,type:"button",onClick:function(){a(h),function(t){i(t)}(e)},disabled:o===e,"data-qaid":"photo_gallery_preview_button","data-testid":"photo_gallery_preview_button"},y.createElement("img",{className:C.previewImage,src:u,width:56,height:56,alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_preview_image","data-testid":"photo_gallery_preview_image"}),c&&y.createElement("div",{className:C.videoPlayLabel,"data-qaid":"photo_gallery_preview_play","data-testid":"photo_gallery_preview_play"},y.createElement(r.Icon,{className:C.videoPlayLabelIcon,"icon-as":l.SvgPlay}))))})))}));L.displayName="PreviewPhotos";var S=function(t){var e=t.title,n=t.onClose,o=t.selectedIndex,i=t.itemsLength,a=t.triggerInteraction,s=o+1,l=(0,h.useBodyStoreTTag().t)(D||(D=b.default(["Фото "," из ",""])),s,i);return y.createElement("div",{className:C.header},y.createElement("div",{className:C.headerTitle,"data-qaid":"photo_gallery_title","data-testid":"photo_gallery_title"},e||l),y.createElement("div",{className:C.headerClose},y.createElement(u.Button,{"button-padding":"xxs","button-theme":"black-inherit",type:"button",onClick:function(){a("clickCloseButton"),n()},"data-qaid":"photo_gallery_close_button","data-testid":"photo_gallery_close_button"},y.createElement(r.Icon,{"icon-as":d.SvgClose2,style:{width:24,height:24}}))))},F=function(t){var e,n=t.selectedIndex,o=t.onClose,i=t.className,a=t.slotProps,s=t.itemsLength,r=y.useRef(null),l=a.component;return y.useEffect((function(){var t;null===(t=r.current)||void 0===t||t.scrollTo({top:0})}),[n]),y.createElement("div",x.default({},a.props,{ref:r,className:E.default(i,null===(e=a.props)||void 0===e?void 0:e.className)}),y.createElement(l,{selectedIndex:n,itemsLength:s,onClose:o}))},A=function(t){var e=t.isOpen,s=t.title,r=t.visibleIndex,l=void 0===r?0:r,c=t.items,u=t.zIndex,h=void 0===u?5e3:u,d=t.onClose,f=t.onChange,m=t.onInteraction,p=t.slotHeader,g=t.slotAside,b=t.slotFooter,x=t.slotMainPhotoFooter,E=y.useRef(!0),w=y.useRef(null),I=y.useRef(null),T=y.useState(l),P=v.default(T,2),z=P[0],O=P[1],D=y.useRef(null),A=function(t){"function"==typeof m&&m(t)};y.useEffect((function(){e&&"function"==typeof f&&f(z)}),[z]),y.useEffect((function(){var t,n;e&&(O(l),null===(t=I.current)||void 0===t||t.scrollToIndex(l,!1),null===(n=w.current)||void 0===n||n.scrollToIndex(l,!1))}),[e]),y.useEffect((function(){var t;if(!e)return function(){};var n=null,o=function(){n&&clearTimeout(n)},i=function(){o(),n=setTimeout((function(){var t,e;null===(t=I.current)||void 0===t||t.scrollToIndex(z,!1),null===(e=w.current)||void 0===e||e.scrollToIndex(z,!1)}),100)};return window.addEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.addEventListener("change",i),function(){var t;o(),window.removeEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.removeEventListener("change",i)}}),[e,z]);var M=function(t){var e,n;E.current=!1,O(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t),null===(n=w.current)||void 0===n||n.scrollToIndex(t)},N=function(){d(z)};return y.createElement(y.Fragment,null,y.createElement(o.Backdrop,{isOpen:e,onClick:N,zIndex:h,isBodyScrollLock:!0}),y.createElement(n.CSSTransition,{nodeRef:D,in:e,timeout:240,classNames:C,unmountOnExit:!0,onEntered:function(){return A("opened")},onExited:function(){return A("closed")}},y.createElement(a.Portal,null,y.createElement("div",{ref:D,className:C.root,"data-qaid":"photo_gallery","data-testid":"photo_gallery",style:{zIndex:h}},y.createElement(i.KeyPress,{code:"Escape",onKeyUp:function(){A("keyPressClose"),N()}}),y.createElement(i.KeyPress,{code:"ArrowLeft",onKeyUp:function(){0!==z&&(A("keyPressPrev"),M(z-1))}}),y.createElement(i.KeyPress,{code:"ArrowRight",onKeyUp:function(){z!==c.length-1&&(A("keyPressNext"),M(z+1))}}),y.createElement("div",{className:C.layout},null!=p&&p.component?y.createElement(F,{className:C.slotLayoutHeader,selectedIndex:z,itemsLength:c.length,onClose:N,slotProps:p}):y.createElement("header",{className:C.layoutHeader},y.createElement(S,{title:s,selectedIndex:z,itemsLength:c.length,onClose:N,triggerInteraction:A})),y.createElement("div",{className:C.layoutContent},y.createElement("section",{className:C.layoutSection},y.createElement("div",{className:C.layoutSectionContent},y.createElement(_,{ref:w,items:c,onChange:function(t){var e;E.current&&(O(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t));E.current||z!==t||(E.current=!0)},triggerInteraction:A})),!(null==x||!x.component)&&y.createElement(F,{className:C.layoutSectionFooter,selectedIndex:z,itemsLength:c.length,onClose:N,slotProps:x})),c.length>1&&y.createElement("aside",{className:C.layoutPreviews},y.createElement(L,{ref:I,items:c,selectedIndex:z,onChange:M,triggerInteraction:A})),!(null==g||!g.component)&&y.createElement(F,{className:C.layoutAdditional,selectedIndex:z,itemsLength:c.length,onClose:N,slotProps:g})),!(null==b||!b.component)&&y.createElement(F,{className:C.layoutFooter,selectedIndex:z,itemsLength:c.length,onClose:N,slotProps:b}))))))};A.displayName="PhotoGallery",exports.PhotoGallery=A,require("./style.production.v2.css");
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var t=require("@babel/runtime/helpers/slicedToArray"),e=require("react"),n=require("react-transition-group"),o=require("@prom-ui/core/Backdrop"),i=require("@prom-ui/core/KeyPress"),a=require("@prom-ui/core/Portal"),s=require("@prom-ui/core/ScrollControls"),r=require("@prom-ui/core/Icon"),l=require("@prom-ui/icons/Play"),c=require("@prom-ui/icons/StarFill"),u=require("@babel/runtime/helpers/taggedTemplateLiteral"),h=require("@prom-ui/core/Button"),d=require("@prom-ui/core/BodyProvider"),f=require("@prom-ui/icons/Close2"),m=require("@babel/runtime/helpers/extends"),p=require("clsx");function g(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}function v(t){if(t&&"object"==typeof t&&"default"in t)return t;var e=Object.create(null);return t&&Object.keys(t).forEach(function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,o.get?o:{enumerable:!0,get:function(){return t[n]}})}}),e.default=t,Object.freeze(e)}var y=g(t),b=v(e),E=g(u),x=g(m),w=g(p),I=new Map,T=function(t,e){var n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];if(e){I.has(e)&&(cancelAnimationFrame(I.get(e)),I.delete(e));var o=requestAnimationFrame(function(){var o=e.getBoundingClientRect(),i=t.getBoundingClientRect(),a=i.top+e.scrollTop-o.top-o.height/2+i.height/2,s=i.left+e.scrollLeft-o.left-o.width/2+i.width/2;s<0&&(s=0),a<0&&(a=0),e.scrollTo({behavior:n?"smooth":"instant",top:a,left:s})});I.set(e,o)}},P=function(t){var e=/^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/|shorts\/)|(?:(?:watch)?\?v(?:i)?=|\&v(?:i)?=))([^#\&\?]*).*/.exec(t);return e&&e[1]},_=function(t){var e=P(t);return"https://img.youtube.com/vi/".concat(e,"/0.jpg")},z=function(){var t=function(t,e){this.el=t,this.zoomFactor=1,this.lastScale=1,this.offset={x:0,y:0},this.initialOffset={x:0,y:0},this.options=Object.assign({},this.defaults,e),this.setupMarkup(),this.bindEvents(),this.update(),this.isImageLoaded(this.el)&&(this.updateAspectRatio(),this.setupOffsets()),this.enable()},e=function(t,e){return t+e};t.prototype={defaults:{tapZoomFactor:2,zoomOutFactor:1.3,animationDuration:300,maxZoom:4,minZoom:.5,draggableUnzoomed:!0,lockDragAxis:!1,setOffsetsOnce:!1,use2d:!0,useMouseWheel:!1,verticalPadding:0,horizontalPadding:0,onZoomStart:null,onZoomEnd:null,onZoomUpdate:null,onDragStart:null,onDragEnd:null,onDragUpdate:null,onDoubleTap:null,onMouseWheel:null},handleDragStart:function(t){"function"==typeof this.options.onDragStart&&this.options.onDragStart(this,t),this.stopAnimation(),this.lastDragPosition=!1,this.hasInteraction=!0,this.handleDrag(t)},handleDrag:function(t){var e="touchmove"===t.type?this.getTouches(t)[0]:this.getPointer(t);this.drag(e,this.lastDragPosition),this.offset=this.sanitizeOffset(this.offset),this.lastDragPosition=e},handleDragEnd:function(){"function"==typeof this.options.onDragEnd&&this.options.onDragEnd(this,event),this.end()},handleZoomStart:function(t){"function"==typeof this.options.onZoomStart&&this.options.onZoomStart(this,t),this.stopAnimation(),this.lastScale=1,this.nthZoom=0,this.lastZoomCenter=!1,this.hasInteraction=!0},handleZoom:function(t,e){var n=this.getTouchCenter(this.getTouches(t)),o=e/this.lastScale;this.lastScale=e,this.nthZoom+=1,this.nthZoom>3&&(this.scale(o,n),this.drag(n,this.lastZoomCenter)),this.lastZoomCenter=n},handleZoomEnd:function(){"function"==typeof this.options.onZoomEnd&&this.options.onZoomEnd(this,event),this.end()},handleDoubleTap:function(t){var e=this.getTouches(t)[0],n=this.zoomFactor>1?1:this.options.tapZoomFactor,o=this.zoomFactor,i=function(t){this.scaleTo(o+t*(n-o),e)}.bind(this);this.hasInteraction||(this.isDoubleTap=!0,o>n&&(e=this.getCurrentZoomCenter()),this.animate(this.options.animationDuration,i,this.swing),"function"==typeof this.options.onDoubleTap&&this.options.onDoubleTap(this,t))},handleMouseWheel:function(t){var e=this.getPointer(t),n=Math.min(Math.max(this.options.minZoom,this.lastScale+-.01*t.deltaY),this.options.maxZoom),o=n/this.lastScale;this.scale(o,e),this.lastScale=n,this.update(),"function"==typeof this.options.onMouseWheel&&this.options.onMouseWheel(this,t)},computeInitialOffset:function(){this.initialOffset={x:-Math.abs(this.el.offsetWidth*this.getInitialZoomFactor()-this.container.offsetWidth)/2,y:-Math.abs(this.el.offsetHeight*this.getInitialZoomFactor()-this.container.offsetHeight)/2}},resetOffset:function(){this.offset.x=this.initialOffset.x,this.offset.y=this.initialOffset.y},isImageLoaded:function(t){return"IMG"===t.nodeName?t.complete&&0!==t.naturalHeight:Array.from(t.querySelectorAll("img")).every(this.isImageLoaded)},setupOffsets:function(){this.options.setOffsetsOnce&&this._isOffsetsSet||(this._isOffsetsSet=!0,this.computeInitialOffset(),this.resetOffset())},sanitizeOffset:function(t){var e=this.el.offsetWidth*this.getInitialZoomFactor()*this.zoomFactor,n=this.el.offsetHeight*this.getInitialZoomFactor()*this.zoomFactor,o=e-this.getContainerX()+this.options.horizontalPadding,i=n-this.getContainerY()+this.options.verticalPadding,a=Math.max(o,0),s=Math.max(i,0),r=Math.min(o,0)-this.options.horizontalPadding,l=Math.min(i,0)-this.options.verticalPadding;return{x:Math.min(Math.max(t.x,r),a),y:Math.min(Math.max(t.y,l),s)}},scaleTo:function(t,e){this.scale(t/this.zoomFactor,e)},scale:function(t,e){t=this.scaleZoomFactor(t),this.addOffset({x:(t-1)*(e.x+this.offset.x),y:(t-1)*(e.y+this.offset.y)}),"function"==typeof this.options.onZoomUpdate&&this.options.onZoomUpdate(this,event)},scaleZoomFactor:function(t){var e=this.zoomFactor;return this.zoomFactor*=t,this.zoomFactor=Math.min(this.options.maxZoom,Math.max(this.zoomFactor,this.options.minZoom)),this.zoomFactor/e},canDrag:function(){return this.options.draggableUnzoomed||!((t=this.zoomFactor)>(e=1)-.01&&t<e+.01);var t,e},drag:function(t,e){e&&(this.options.lockDragAxis?Math.abs(t.x-e.x)>Math.abs(t.y-e.y)?this.addOffset({x:-(t.x-e.x),y:0}):this.addOffset({y:-(t.y-e.y),x:0}):this.addOffset({y:-(t.y-e.y),x:-(t.x-e.x)}),"function"==typeof this.options.onDragUpdate&&this.options.onDragUpdate(this,event))},getTouchCenter:function(t){return this.getVectorAvg(t)},getVectorAvg:function(t){return{x:t.map(function(t){return t.x}).reduce(e)/t.length,y:t.map(function(t){return t.y}).reduce(e)/t.length}},addOffset:function(t){this.offset={x:this.offset.x+t.x,y:this.offset.y+t.y}},sanitize:function(){this.zoomFactor<this.options.zoomOutFactor?this.zoomOutAnimation():this.isInsaneOffset(this.offset)&&this.sanitizeOffsetAnimation()},isInsaneOffset:function(t){var e=this.sanitizeOffset(t);return e.x!==t.x||e.y!==t.y},sanitizeOffsetAnimation:function(){var t=this.sanitizeOffset(this.offset),e=this.offset.x,n=this.offset.y,o=function(o){this.offset.x=e+o*(t.x-e),this.offset.y=n+o*(t.y-n),this.update()}.bind(this);this.animate(this.options.animationDuration,o,this.swing)},zoomOutAnimation:function(){if(1!==this.zoomFactor){var t=this.zoomFactor,e=this.getCurrentZoomCenter(),n=function(n){this.scaleTo(t+n*(1-t),e)}.bind(this);this.animate(this.options.animationDuration,n,this.swing)}},updateAspectRatio:function(){this.unsetContainerY(),this.setContainerY(this.container.parentElement.offsetHeight)},getInitialZoomFactor:function(){var t=this.container.offsetWidth/this.el.offsetWidth,e=this.container.offsetHeight/this.el.offsetHeight;return Math.min(t,e)},getAspectRatio:function(){return this.el.offsetWidth/this.el.offsetHeight},getCurrentZoomCenter:function(){var t=this.offset.x-this.initialOffset.x,e=-1*this.offset.x-t/(1/this.zoomFactor-1),n=this.offset.y-this.initialOffset.y;return{x:e,y:-1*this.offset.y-n/(1/this.zoomFactor-1)}},getTouches:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return Array.prototype.slice.call(t.touches).map(function(t){return{x:t.pageX-a,y:t.pageY-i}})},getPointer:function(t){var e=this.container.getBoundingClientRect(),n=document.documentElement.scrollTop||document.body.scrollTop,o=document.documentElement.scrollLeft||document.body.scrollLeft,i=e.top+n,a=e.left+o;return{x:t.pageX-a,y:t.pageY-i}},animate:function(t,e,n,o){var i=(new Date).getTime(),a=function(){if(this.inAnimation){var s=(new Date).getTime()-i,r=s/t;s>=t?(e(1),o&&o(),this.update(),this.stopAnimation(),this.update()):(n&&(r=n(r)),e(r),this.update(),requestAnimationFrame(a))}}.bind(this);this.inAnimation=!0,requestAnimationFrame(a)},stopAnimation:function(){this.inAnimation=!1},swing:function(t){return-Math.cos(t*Math.PI)/2+.5},getContainerX:function(){return this.container.offsetWidth},getContainerY:function(){return this.container.offsetHeight},setContainerY:function(t){return this.container.style.height=t+"px"},unsetContainerY:function(){this.container.style.height=null},setupMarkup:function(){var t,e;this.container=(t='<div class="pinch-zoom-container" style="height: 100%;"></div>',(e=document.implementation.createHTMLDocument("")).body.innerHTML=t,Array.from(e.body.children)[0]),this.el.parentNode.insertBefore(this.container,this.el),this.container.appendChild(this.el),this.container.style.overflow="hidden",this.container.style.position="relative",this.el.style.webkitTransformOrigin="0% 0%",this.el.style.mozTransformOrigin="0% 0%",this.el.style.msTransformOrigin="0% 0%",this.el.style.oTransformOrigin="0% 0%",this.el.style.transformOrigin="0% 0%",this.el.style.position="absolute",this.el.style.backfaceVisibility="hidden",this.el.style.willChange="transform"},end:function(){this.hasInteraction=!1,this.sanitize(),this.update()},bindEvents:function(){var t=this;n(this.container,this),this.resizeHandler=this.update.bind(this),window.addEventListener("resize",this.resizeHandler),Array.from(this.el.querySelectorAll("img")).forEach(function(e){e.addEventListener("load",t.update.bind(t))}),"IMG"===this.el.nodeName&&this.el.addEventListener("load",this.update.bind(this))},update:function(t){t&&"resize"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),t&&"load"===t.type&&(this.updateAspectRatio(),this.setupOffsets()),this.updatePlanned||(this.updatePlanned=!0,window.setTimeout(function(){this.updatePlanned=!1;var t=this.getInitialZoomFactor()*this.zoomFactor,e=-this.offset.x/t,n=-this.offset.y/t,o="scale3d("+t+", "+t+",1) translate3d("+e+"px,"+n+"px,0px)",i="scale("+t+", "+t+") translate("+e+"px,"+n+"px)",a=function(){this.clone&&(this.clone.parentNode.removeChild(this.clone),delete this.clone)}.bind(this);!this.options.use2d||this.hasInteraction||this.inAnimation?(this.is3d=!0,a(),this.el.style.webkitTransform=o,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=o):(this.is3d&&(this.clone=this.el.cloneNode(!0),this.clone.style.pointerEvents="none",this.container.appendChild(this.clone),window.setTimeout(a,200)),this.el.style.webkitTransform=i,this.el.style.mozTransform=i,this.el.style.msTransform=i,this.el.style.oTransform=i,this.el.style.transform=i,this.is3d=!1)}.bind(this),0))},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},destroy:function(){window.removeEventListener("resize",this.resizeHandler),this.container&&(this.container.remove(),this.container=null)},reset:function(){this.zoomOutAnimation()}};var n=function(t,e){var n=null,o=0,i=null,a=null,s=function(t,o){if(n!==t){if(n&&!t)switch(n){case"zoom":e.handleZoomEnd(o);break;case"drag":e.handleDragEnd(o)}switch(t){case"zoom":e.handleZoomStart(o);break;case"drag":e.handleDragStart(o)}}n=t},r=function(t){2===o?s("zoom"):1===o&&e.canDrag()?s("drag",t):s(null,t)},l=function(t){return Array.from(t).map(function(t){return{x:t.pageX,y:t.pageY}})},c=function(t,e){var n,o;return n=t.x-e.x,o=t.y-e.y,Math.sqrt(n*n+o*o)},u=function(t){t.stopPropagation(),t.preventDefault()},h=!0;t.addEventListener("touchstart",function(t){e.enabled&&(h=!0,o=t.touches.length,function(t){var a=(new Date).getTime();if(o>1&&(i=null),a-i<300)switch(u(t),e.handleDoubleTap(t),n){case"zoom":e.handleZoomEnd(t);break;case"drag":e.handleDragEnd(t)}else e.isDoubleTap=!1;1===o&&(i=a)}(t))},{passive:!1}),t.addEventListener("touchmove",function(t){if(e.enabled&&!e.isDoubleTap){if(h)r(t),n&&u(t),a=l(t.touches);else{switch(n){case"zoom":2==a.length&&2==t.touches.length&&e.handleZoom(t,function(t,e){var n=c(t[0],t[1]);return c(e[0],e[1])/n}(a,l(t.touches)));break;case"drag":e.handleDrag(t)}n&&(u(t),e.update())}h=!1}},{passive:!1}),t.addEventListener("touchend",function(t){e.enabled&&(o=t.touches.length,r(t))}),e.options.useMouseWheel&&(t.addEventListener("mousewheel",function(t){e.enabled&&(u(t),e.handleMouseWheel(t))}),t.addEventListener("mousedown",function(t){e.enabled&&(h=!0,o=1)},{passive:!0}),t.addEventListener("mousemove",function(t){e.enabled&&(h?(r(t),n&&u(t)):("drag"===n&&e.handleDrag(t),n&&(u(t),e.update())),h=!1)},{passive:!1}),t.addEventListener("mouseup",function(t){e.enabled&&(o=0,r(t))},{passive:!0}))};return t}(),C={scrolling:"q1DKc",root:"KiBKq",layout:"JBDok",layoutHeader:"tVG4b",slotLayoutHeader:"_8R2r5",layoutContent:"O43ff",layoutFooter:"Gz4gH",layoutSection:"CvZb6",layoutSectionContent:"_2TSDW",layoutSectionFooter:"LTbHF",layoutPreviews:"-hzyv",layoutAdditional:"mR5-f",header:"xfAad",headerTitle:"QiOEy",headerClose:"qdl3x",mainPhotoScrollControls:"PeY3Y",mainPhoto:"QIMHy q1DKc",mainPhotoItem:"aZCyk",mainPhotoImage:"_2aEr5",mainPhotoIframe:"kThdT",preview:"F-k0z q1DKc",previewItem:"jf683",previewButton:"VAXOP",previewImage:"Mx2Y-",previewRating:"_6dvN5",previewRatingIcon:"qXV70",videoPlayLabel:"jQiDN",videoPlayLabelIcon:"wSdjd",enter:"Lnosr",exit:"NW-xY",enterActive:"LrirU",exitActive:"L6st-"},O=b.forwardRef(function(t,e){var n=t.src,o=t.videoSrc,i=t.triggerInteraction,a=b.useRef(null),s=b.useRef(null),r=b.useRef(null),l=!!o,c=function(){var t,e;null===(t=s.current)||void 0===t||t.reset(),null===(e=a.current)||void 0===e||null===(e=e.contentWindow)||void 0===e||e.postMessage('{"event":"command","func":"pauseVideo","args":""}',"*")};return b.useEffect(function(){return requestAnimationFrame(function(){r.current&&!l&&(s.current=new z(r.current,{draggableUnzoomed:!1,animationDuration:200,setOffsetsOnce:!1,onDoubleTap:function(t){1===(null==t?void 0:t.zoomFactor)&&i("maybeZoomImage")}}))}),function(){var t;null===(t=s.current)||void 0===t||t.destroy()}},[o]),b.useEffect(function(){var t=function(){l&&document.activeElement&&"iframe"===document.activeElement.nodeName.toLowerCase()&&a.current&&a.current===document.activeElement&&i("maybePlayVideo")};return window.addEventListener("blur",t),function(){window.removeEventListener("blur",t)}},[o]),b.useImperativeHandle(e,function(){return{reset:c}},[]),l?b.createElement("iframe",{ref:a,className:C.mainPhotoIframe,src:o,width:"100%",height:"100%",allowFullScreen:!0,title:"",loading:"lazy","data-qaid":"photo_gallery_main_video","data-testid":"photo_gallery_main_video"}):b.createElement("img",{ref:r,className:C.mainPhotoImage,src:n,width:"100%",height:"100%",alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_main_image","data-testid":"photo_gallery_main_image"})});O.displayName="MainPhotosImage";var D=b.forwardRef(function(t,e){var n=t.items,o=t.onChange,i=t.triggerInteraction,a=b.useRef(null),r=b.useRef([]),l=b.useRef(0),c=b.useRef(null),u=function(){r.current.forEach(function(t){null==t||t.reset()})},h=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=c.current)||void 0===e?void 0:e.children[t];u(),o&&T(o,c.current,n)};b.useImperativeHandle(e,function(){return{scrollToIndex:h}},[]);return b.createElement(s.ScrollControls,{ref:c,className:C.mainPhotoScrollControls,showOnHover:!0,hideOnDisabled:!0,onClickPrev:function(){return i("clickPrevButton")},onClickNext:function(){return i("clickNextButton")}},b.createElement("div",{className:C.mainPhoto,onScroll:function(){if(c.current){var t=function(t,e){var n=t.scrollLeft/t.scrollWidth*e;return Math.round(n)}(c.current,n.length);l.current!==t&&(l.current=t,o(t),u())}},onTouchStart:function(t){var e=t.changedTouches[0].screenX;a.current=e},onTouchEnd:function(t){var e=t.changedTouches[0].screenX;a.current&&(a.current>e?i("maybeSwipeLeft"):a.current<e&&i("maybeSwipeRight"),a.current=null)}},n.map(function(t,e){var n,o=t.type,a=t.src,s="video"===o,l=s?_(a):a,c=s?(n=P(a),"https://youtube.com/embed/".concat(n,"?enablejsapi=1&rel=0")):void 0;return b.createElement("div",{key:e,className:C.mainPhotoItem,"data-qaid":"photo_gallery_main_item","data-testid":"photo_gallery_main_item"},b.createElement(O,{ref:function(t){r.current[e]=t},src:l,videoSrc:c,triggerInteraction:i}))})))});D.displayName="MainPhotos";var L,S=b.forwardRef(function(t,e){var n=t.items,o=t.selectedIndex,i=t.onChange,a=t.triggerInteraction,s=b.useRef(null),u=function(t){var e,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],o=null===(e=s.current)||void 0===e?void 0:e.children[t];o&&T(o,s.current,n)};b.useImperativeHandle(e,function(){return{scrollToIndex:u}},[]);return b.createElement("div",{ref:s,className:C.preview,onScroll:function(){a("scrollPreviews")}},n.map(function(t,e){var n=t.type,s=t.src,u=t.rating,h="video"===n,d=h?_(s):s,f=h?"clickPreviewVideo":"clickPreviewImage";return b.createElement("div",{key:e,className:C.previewItem,"data-qaid":"photo_gallery_preview_item","data-testid":"photo_gallery_preview_item"},b.createElement("button",{className:C.previewButton,type:"button",onClick:function(){a(f),function(t){i(t)}(e)},disabled:o===e,"data-qaid":"photo_gallery_preview_button","data-testid":"photo_gallery_preview_button"},b.createElement("img",{className:C.previewImage,src:d,width:56,height:56,alt:"",decoding:"async",loading:"lazy","data-qaid":"photo_gallery_preview_image","data-testid":"photo_gallery_preview_image"}),u?b.createElement("div",{className:C.previewRating,"data-qaid":"photo_gallery_preview_rating","data-testid":"photo_gallery_preview_rating"},b.createElement(r.Icon,{className:C.previewRatingIcon,"icon-as":c.SvgStarFill}),u):null,h&&b.createElement("div",{className:C.videoPlayLabel,"data-qaid":"photo_gallery_preview_play","data-testid":"photo_gallery_preview_play"},b.createElement(r.Icon,{className:C.videoPlayLabelIcon,"icon-as":l.SvgPlay}))))}))});S.displayName="PreviewPhotos";var F=function(t){var e=t.title,n=t.onClose,o=t.selectedIndex,i=t.itemsLength,a=t.triggerInteraction,s=o+1,l=(0,d.useBodyStoreTTag().t)(L||(L=E.default(["Фото "," из ",""])),s,i);return b.createElement("div",{className:C.header},b.createElement("div",{className:C.headerTitle,"data-qaid":"photo_gallery_title","data-testid":"photo_gallery_title"},e||l),b.createElement("div",{className:C.headerClose},b.createElement(h.Button,{"button-padding":"xxs","button-theme":"black-inherit",type:"button",onClick:function(){a("clickCloseButton"),n()},"data-qaid":"photo_gallery_close_button","data-testid":"photo_gallery_close_button"},b.createElement(r.Icon,{"icon-as":f.SvgClose2,style:{width:24,height:24}}))))},N=function(t){var e,n=t.selectedIndex,o=t.onClose,i=t.className,a=t.slotProps,s=t.itemsLength,r=b.useRef(null),l=a.component;return b.useEffect(function(){var t;null===(t=r.current)||void 0===t||t.scrollTo({top:0})},[n]),b.createElement("div",x.default({},a.props,{ref:r,className:w.default(i,null===(e=a.props)||void 0===e?void 0:e.className)}),b.createElement(l,{selectedIndex:n,itemsLength:s,onClose:o}))},A=function(t){var e=t.isOpen,s=t.title,r=t.visibleIndex,l=void 0===r?0:r,c=t.items,u=t.zIndex,h=void 0===u?5e3:u,d=t.onClose,f=t.onChange,m=t.onInteraction,p=t.slotHeader,g=t.slotAside,v=t.slotFooter,E=t.slotMainPhotoFooter,x=b.useRef(!0),w=b.useRef(null),I=b.useRef(null),T=b.useState(l),P=y.default(T,2),_=P[0],z=P[1],O=b.useRef(null),L=function(t){"function"==typeof m&&m(t)};b.useEffect(function(){e&&"function"==typeof f&&f(_)},[_]),b.useEffect(function(){var t,n;e&&(z(l),null===(t=I.current)||void 0===t||t.scrollToIndex(l,!1),null===(n=w.current)||void 0===n||n.scrollToIndex(l,!1))},[e]),b.useEffect(function(){var t;if(!e)return function(){};var n=null,o=function(){n&&clearTimeout(n)},i=function(){o(),n=setTimeout(function(){var t,e;null===(t=I.current)||void 0===t||t.scrollToIndex(_,!1),null===(e=w.current)||void 0===e||e.scrollToIndex(_,!1)},100)};return window.addEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.addEventListener("change",i),function(){var t;o(),window.removeEventListener("resize",i),null===(t=window)||void 0===t||null===(t=t.matchMedia("(orientation: portrait)"))||void 0===t||t.removeEventListener("change",i)}},[e,_]);var A=function(t){var e,n;x.current=!1,z(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t),null===(n=w.current)||void 0===n||n.scrollToIndex(t)},M=function(){d(_)};return b.createElement(b.Fragment,null,b.createElement(o.Backdrop,{isOpen:e,onClick:M,zIndex:h,isBodyScrollLock:!0}),b.createElement(n.CSSTransition,{nodeRef:O,in:e,timeout:240,classNames:C,unmountOnExit:!0,onEntered:function(){return L("opened")},onExited:function(){return L("closed")}},b.createElement(a.Portal,null,b.createElement("div",{ref:O,className:C.root,"data-qaid":"photo_gallery","data-testid":"photo_gallery",style:{zIndex:h}},b.createElement(i.KeyPress,{code:"Escape",onKeyUp:function(){L("keyPressClose"),M()}}),b.createElement(i.KeyPress,{code:"ArrowLeft",onKeyUp:function(){0!==_&&(L("keyPressPrev"),A(_-1))}}),b.createElement(i.KeyPress,{code:"ArrowRight",onKeyUp:function(){_!==c.length-1&&(L("keyPressNext"),A(_+1))}}),b.createElement("div",{className:C.layout},null!=p&&p.component?b.createElement(N,{className:C.slotLayoutHeader,selectedIndex:_,itemsLength:c.length,onClose:M,slotProps:p}):b.createElement("header",{className:C.layoutHeader},b.createElement(F,{title:s,selectedIndex:_,itemsLength:c.length,onClose:M,triggerInteraction:L})),b.createElement("div",{className:C.layoutContent},b.createElement("section",{className:C.layoutSection},b.createElement("div",{className:C.layoutSectionContent},b.createElement(D,{ref:w,items:c,onChange:function(t){var e;x.current&&(z(t),null===(e=I.current)||void 0===e||e.scrollToIndex(t));x.current||_!==t||(x.current=!0)},triggerInteraction:L})),!(null==E||!E.component)&&b.createElement(N,{className:C.layoutSectionFooter,selectedIndex:_,itemsLength:c.length,onClose:M,slotProps:E})),c.length>1&&b.createElement("aside",{className:C.layoutPreviews},b.createElement(S,{ref:I,items:c,selectedIndex:_,onChange:A,triggerInteraction:L})),!(null==g||!g.component)&&b.createElement(N,{className:C.layoutAdditional,selectedIndex:_,itemsLength:c.length,onClose:M,slotProps:g})),!(null==v||!v.component)&&b.createElement(N,{className:C.layoutFooter,selectedIndex:_,itemsLength:c.length,onClose:M,slotProps:v}))))))};A.displayName="PhotoGallery",exports.PhotoGallery=A,require("./style.production.v2.css");
|