@vkontakte/vkui 8.1.2 → 8.1.3

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.
Files changed (51) hide show
  1. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts +2 -1
  2. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  3. package/dist/components/NavTransitionContext/NavTransitionContext.js +8 -4
  4. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  5. package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts.map +1 -1
  6. package/dist/components/OnboardingTooltip/OnboardingTooltip.js +2 -4
  7. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  8. package/dist/components/Popper/Popper.d.ts.map +1 -1
  9. package/dist/components/Popper/Popper.js +6 -3
  10. package/dist/components/Popper/Popper.js.map +1 -1
  11. package/dist/components/Root/Root.d.ts.map +1 -1
  12. package/dist/components/Root/Root.js +29 -32
  13. package/dist/components/Root/Root.js.map +1 -1
  14. package/dist/components/View/View.d.ts.map +1 -1
  15. package/dist/components/View/View.js +50 -53
  16. package/dist/components/View/View.js.map +1 -1
  17. package/dist/components/View/ViewInfinite.d.ts.map +1 -1
  18. package/dist/components/View/ViewInfinite.js +34 -37
  19. package/dist/components/View/ViewInfinite.js.map +1 -1
  20. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js +8 -4
  21. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  22. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js +2 -4
  23. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  24. package/dist/cssm/components/Popper/Popper.js +6 -3
  25. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  26. package/dist/cssm/components/Root/Root.js +29 -32
  27. package/dist/cssm/components/Root/Root.js.map +1 -1
  28. package/dist/cssm/components/View/View.js +50 -53
  29. package/dist/cssm/components/View/View.js.map +1 -1
  30. package/dist/cssm/components/View/ViewInfinite.js +34 -37
  31. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  32. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +4 -4
  33. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  34. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  35. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +4 -4
  36. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  37. package/package.json +1 -1
  38. package/src/components/NavTransitionContext/NavTransitionContext.tsx +5 -1
  39. package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +2 -5
  40. package/src/components/Popper/Popper.tsx +7 -4
  41. package/src/components/Root/Root.tsx +50 -52
  42. package/src/components/View/View.tsx +83 -89
  43. package/src/components/View/ViewInfinite.tsx +65 -69
  44. package/src/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.ts +4 -5
  45. package/dist/cssm/lib/floating/LockFloatingPosition/LockFloatingPosition.js +0 -6
  46. package/dist/cssm/lib/floating/LockFloatingPosition/LockFloatingPosition.js.map +0 -1
  47. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.d.ts +0 -6
  48. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.d.ts.map +0 -1
  49. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.js +0 -6
  50. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.js.map +0 -1
  51. package/src/lib/floating/LockFloatingPosition/LockFloatingPosition.tsx +0 -6
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/View/View.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { blurActiveElement, useDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HTMLAttributesWithRootRef } from '../../types';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport { useLayoutEffectCall } from './useLayoutEffectCall';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nexport const scrollsCache = new Map<string, Map<string, number | undefined>>();\n\nexport interface ViewProps extends HTMLAttributesWithRootRef<HTMLElement>, NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: (params: { isBack: boolean; from: string; to: string }) => void;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Коллекция Panel. У каждой Panel должен быть уникальный `id`.\n */\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkui.io/components/view\n */\nexport const View = ({\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n className,\n ...restProps\n}: ViewProps): React.ReactNode => {\n const id = getNavId({ nav, id: restProps.id });\n const [scrolls] = React.useState(\n () => scrollsCache.get(id as string) || new Map<string, number | undefined>(),\n );\n const layoutEffectCall = useLayoutEffectCall();\n\n React.useEffect(() => () => {\n if (id) {\n scrollsCache.set(id, scrolls);\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(activePanelProp);\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const swipeBackPrevented = React.useRef<boolean>(false);\n const [swipingBack, setSwipingBack] = React.useState<boolean | undefined>(undefined);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<string | null>(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<string | null>(null);\n const [swipeBackResult, setSwipeBackResult] = React.useState<'success' | 'fail' | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = React.useRef<string>(undefined);\n const prevSwipingBack = React.useRef<boolean>(undefined);\n const prevBrowserSwipe = React.useRef<boolean>(undefined);\n const prevSwipeBackResult = React.useRef<'success' | 'fail' | null>(undefined);\n const prevSwipeBackShift = React.useRef<number>(undefined);\n const prevSwipeBackPrevPanel = React.useRef<string | null>(undefined);\n const prevOnTransition = React.useRef<typeof onTransition>(undefined);\n\n const panels = (React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>).filter(\n (panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n },\n );\n\n const disableAnimation =\n !configProvider.transitionMotionEnabled || !splitCol.animate || platform === 'vkcom';\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider.isWebView && Boolean(onSwipeBack);\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.set(prevPanel, 0);\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(isBackTransition);\n\n layoutEffectCall(() => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.get(activePanelProp) : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n });\n },\n [activePanelProp, layoutEffectCall, onTransition, scroll, scrolls],\n );\n\n const handleAnimatedTargetAnimationEnd: React.AnimationEventHandler<HTMLDivElement> = (e) => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (prevPanel !== null) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n };\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(() => {\n switch (swipeBackResult) {\n case 'fail':\n onSwipeBackCancel();\n break;\n case 'success':\n onSwipeBackSuccess();\n }\n }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackResult]);\n\n const handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n setBrowserSwipe(true);\n }\n };\n\n const handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (swipeBackPrevented.current || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if (animated && swipeBackTriggered) {\n return;\n }\n\n if (!swipingBack && history && history.length > 1) {\n if (swipedToOpposite) {\n swipeBackPrevented.current = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n swipeBackPrevented.current = true;\n return;\n }\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n swipeBackPrevented.current = true;\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.set(activePanel, scroll?.getScroll().y);\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(event.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n\n if (swipingBack) {\n if (event.shiftX < 0) {\n setSwipeBackShift(0);\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n setSwipeBackShift(window!.innerWidth);\n } else {\n setSwipeBackShift(event.shiftX);\n }\n }\n };\n\n const handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n swipeBackPrevented.current = false;\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * millisecondsInSecond;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackShift >= window!.innerWidth / 2) {\n setSwipeBackResult('success');\n } else {\n setSwipeBackResult('fail');\n }\n }\n };\n\n const calcPanelSwipeStyles = (isPrev: boolean, isNext: boolean): React.CSSProperties => {\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n if (isNext) {\n return window\n ? {\n transform: `translate3d(${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%, 0, 0)`,\n }\n : {};\n }\n\n if (isPrev) {\n return { transform: `translate3d(${swipeBackShift}px, 0, 0)` };\n }\n\n return {};\n };\n\n const calcPanelSwipeBackOverlayStyles = (isNext: boolean): React.CSSProperties => {\n if (!window || !isNext) {\n return {};\n }\n const opacityOnSwipeEnd =\n swipeBackResult === 'success' ? 0 : swipeBackResult === 'fail' ? 1 : null;\n\n return {\n display: 'block',\n opacity:\n opacityOnSwipeEnd === null ? 1 - swipeBackShift / window.innerWidth : opacityOnSwipeEnd,\n };\n };\n\n const handleSwipeBackTargetTransitionEnd = (event: React.TransitionEvent<HTMLDivElement>) => {\n if (event.propertyName.includes('transform')) {\n swipingBackTransitionEndHandler();\n }\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n !prevSwipingBack.current &&\n !prevBrowserSwipe.current\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel.current || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.set(\n prevActivePanel.current,\n scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n );\n\n if (disableAnimation) {\n flushTransition(prevActivePanel.current, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel.current, activePanelProp]);\n setPrevPanel(prevActivePanel.current);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n prevSwipingBack.current\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel.current;\n if (prevSwipeBackPrevPanel.current) {\n scrolls.set(prevSwipeBackPrevPanel.current, 0);\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n setIsBack(true);\n\n layoutEffectCall(() => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.get(nextPanel));\n }\n prevOnTransition.current &&\n prevOnTransition.current({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n });\n }\n\n // Началась анимация завершения свайпа назад.\n // см. `onTransitionEnd()`\n\n // Закончился Safari свайп\n if (prevActivePanel.current !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n layoutEffectCall,\n scrolls,\n ]);\n\n React.useEffect(\n function restoreScrollPositionWhenSwipeBackIsCancelled() {\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n const swipeBackCancelledInTheMiddleOfAction =\n prevSwipeBackResult.current === 'fail' && !swipeBackResult;\n const swipeBackCancelledByMovingPanelBackToInitialPoint =\n prevSwipingBack.current && !swipingBack && prevSwipeBackShift.current === 0;\n\n if (\n (swipeBackCancelledInTheMiddleOfAction ||\n swipeBackCancelledByMovingPanelBackToInitialPoint) &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.get(activePanel));\n }\n },\n [swipeBackResult, swipingBack, activePanel, scroll, scrolls],\n );\n\n /**\n * @see https://github.com/VKCOM/VKUI/pull/9274\n */\n React.useEffect(function updateAfterAll() {\n prevActivePanel.current = activePanelProp;\n prevSwipingBack.current = swipingBack;\n prevBrowserSwipe.current = browserSwipe;\n prevSwipeBackResult.current = swipeBackResult;\n prevSwipeBackShift.current = swipeBackShift;\n prevSwipeBackPrevPanel.current = swipeBackPrevPanel;\n prevOnTransition.current = onTransition;\n });\n\n return (\n <NavViewIdContext.Provider value={id}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles.animated,\n !disableAnimation && swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled ? handleTouchEndForIOSSwipeBackSimulation : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n const isPanelActive = panelId === activePanel;\n const isPanelPrev = panelId === prevPanel;\n const isPanelNext = panelId === nextPanel;\n const isAnimatedTarget = animated && (isBack ? isPanelPrev : isPanelNext);\n\n const isSwipeBackPrev = panelId === swipeBackPrevPanel;\n const isSwipeBackNext = panelId === swipeBackNextPanel;\n const isSwipeBackTarget = swipeBackResult && isSwipeBackPrev;\n\n let scrollCompensateStyle: React.CSSProperties | undefined = undefined;\n\n if (isPanelPrev || (isPanelNext && isBack) || isSwipeBackPrev || isSwipeBackNext) {\n const marginTop = scrolls.get(panelId);\n if (marginTop !== undefined) {\n scrollCompensateStyle = { marginTop: -1 * marginTop };\n }\n }\n\n return (\n <div\n className={classNames(\n styles.panel,\n\n isPanelActive && styles.panelActive,\n isPanelPrev && styles.panelPrev,\n isPanelNext && styles.panelNext,\n\n isSwipeBackPrev && styles.panelSwipeBackPrev,\n isSwipeBackNext && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onTransitionEnd={\n isSwipeBackTarget ? handleSwipeBackTargetTransitionEnd : undefined\n }\n onAnimationEnd={isAnimatedTarget ? handleAnimatedTargetAnimationEnd : undefined}\n ref={(el) => {\n panelId !== undefined && (panelNodes.current[panelId] = el);\n }}\n style={calcPanelSwipeStyles(isSwipeBackPrev, isSwipeBackNext)}\n key={panelId}\n >\n {platform === 'ios' && (\n <div\n className={styles.panelOverlay}\n style={calcPanelSwipeBackOverlayStyles(isSwipeBackNext)}\n />\n )}\n <div className={styles.panelIn} style={scrollCompensateStyle}>\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n};\n"],"names":["React","classNames","usePlatform","millisecondsInSecond","blurActiveElement","useDOM","LockFloatingPositionContext","getNavId","warnOnce","useScroll","useConfigProvider","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","useSplitCol","Touch","useLayoutEffectCall","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","styles","scrollsCache","Map","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","id","scrolls","useState","get","layoutEffectCall","useEffect","set","panelNodes","useRef","window","document","scroll","configProvider","splitCol","platform","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","isBack","setIsBack","undefined","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipeBackPrevented","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackShift","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","iOSSwipeBackSimulationEnabled","isWebView","Boolean","flushTransition","useCallback","isBackTransition","scrollTo","from","to","handleAnimatedTargetAnimationEnd","e","target","currentTarget","onSwipeBackSuccess","swipingBackTransitionEndHandler","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","current","swipedToOpposite","length","originalEvent","payload","getScroll","y","slice","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","isPrev","isNext","transform","calcPanelSwipeBackOverlayStyles","opacityOnSwipeEnd","display","opacity","handleSwipeBackTargetTransitionEnd","propertyName","firstLayerId","map","find","compensateKeyboardHeight","restoreScrollPositionWhenSwipeBackIsCancelled","swipeBackCancelledInTheMiddleOfAction","swipeBackCancelledByMovingPanelBackToInitialPoint","updateAfterAll","Provider","value","Component","host","ios","noMotion","onMoveX","onEnd","div","isPanelActive","isPanelPrev","isPanelNext","isAnimatedTarget","isSwipeBackPrev","isSwipeBackNext","isSwipeBackTarget","scrollCompensateStyle","marginTop","panelActive","panelPrev","panelNext","panelSwipeBackPrev","panelSwipeBackNext","panelSwipeBackSuccess","panelSwipeBackFailed","onTransitionEnd","onAnimationEnd","ref","el","style","panelOverlay","panelIn","entering"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/components/View/View.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { blurActiveElement, useDOM } from '../../lib/dom';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HTMLAttributesWithRootRef } from '../../types';\nimport { useScroll } from '../AppRoot/ScrollContext';\nimport { useConfigProvider } from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { useSplitCol } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport { useLayoutEffectCall } from './useLayoutEffectCall';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nexport const scrollsCache = new Map<string, Map<string, number | undefined>>();\n\nexport interface ViewProps extends HTMLAttributesWithRootRef<HTMLElement>, NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: (params: { isBack: boolean; from: string; to: string }) => void;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n *\n * Чтобы остановить свайп назад, возвращайте `\"prevent\"`.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Коллекция Panel. У каждой Panel должен быть уникальный `id`.\n */\n children: React.ReactElement | Iterable<React.ReactElement>;\n}\n\nconst warn = warnOnce('View');\n\n/**\n * @see https://vkui.io/components/view\n */\nexport const View = ({\n activePanel: activePanelProp,\n history,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel: onSwipeBackCancelProp,\n children,\n className,\n ...restProps\n}: ViewProps): React.ReactNode => {\n const id = getNavId({ nav, id: restProps.id });\n const [scrolls] = React.useState(\n () => scrollsCache.get(id as string) || new Map<string, number | undefined>(),\n );\n const layoutEffectCall = useLayoutEffectCall();\n\n React.useEffect(() => () => {\n if (id) {\n scrollsCache.set(id, scrolls);\n }\n });\n\n const panelNodes = React.useRef<{ [id: string]: HTMLDivElement | null }>({});\n\n const { window, document } = useDOM();\n const scroll = useScroll();\n const configProvider = useConfigProvider();\n const splitCol = useSplitCol();\n const platform = usePlatform();\n\n const [animated, setAnimated] = React.useState(false);\n\n const [visiblePanels, setVisiblePanels] = React.useState([activePanelProp]);\n const [activePanel, setActivePanel] = React.useState<string | null>(activePanelProp);\n const [isBack, setIsBack] = React.useState<boolean | undefined>(undefined);\n const [prevPanel, setPrevPanel] = React.useState<string | null>(null);\n const [nextPanel, setNextPanel] = React.useState<string | null>(null);\n\n const swipeBackPrevented = React.useRef<boolean>(false);\n const [swipingBack, setSwipingBack] = React.useState<boolean | undefined>(undefined);\n const [swipeBackStartX, setSwipeBackStartX] = React.useState<number>(0);\n const [swipeBackShift, setSwipeBackShift] = React.useState<number>(0);\n const [swipeBackNextPanel, setSwipeBackNextPanel] = React.useState<string | null>(null);\n const [swipeBackPrevPanel, setSwipeBackPrevPanel] = React.useState<string | null>(null);\n const [swipeBackResult, setSwipeBackResult] = React.useState<'success' | 'fail' | null>(null);\n\n const [browserSwipe, setBrowserSwipe] = React.useState(false);\n\n const prevActivePanel = React.useRef<string>(undefined);\n const prevSwipingBack = React.useRef<boolean>(undefined);\n const prevBrowserSwipe = React.useRef<boolean>(undefined);\n const prevSwipeBackResult = React.useRef<'success' | 'fail' | null>(undefined);\n const prevSwipeBackShift = React.useRef<number>(undefined);\n const prevSwipeBackPrevPanel = React.useRef<string | null>(undefined);\n const prevOnTransition = React.useRef<typeof onTransition>(undefined);\n\n const panels = (React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>).filter(\n (panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n },\n );\n\n const disableAnimation =\n !configProvider.transitionMotionEnabled || !splitCol.animate || platform === 'vkcom';\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider.isWebView && Boolean(onSwipeBack);\n\n const flushTransition = React.useCallback(\n (prevPanel: string, isBackTransition: boolean) => {\n if (isBackTransition) {\n scrolls.set(prevPanel, 0);\n }\n setPrevPanel(null);\n setNextPanel(null);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n setAnimated(false);\n setIsBack(isBackTransition);\n\n layoutEffectCall(() => {\n scroll?.scrollTo(0, isBackTransition ? scrolls.get(activePanelProp) : 0);\n onTransition &&\n onTransition({\n isBack: isBackTransition,\n from: prevPanel,\n to: activePanelProp,\n });\n });\n },\n [activePanelProp, layoutEffectCall, onTransition, scroll, scrolls],\n );\n\n const handleAnimatedTargetAnimationEnd: React.AnimationEventHandler<HTMLDivElement> = (e) => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (prevPanel !== null) {\n flushTransition(prevPanel, Boolean(isBack));\n }\n };\n\n const onSwipeBackSuccess = React.useCallback(() => {\n onSwipeBack && onSwipeBack();\n }, [onSwipeBack]);\n\n const onSwipeBackCancel = React.useCallback(() => {\n onSwipeBackCancelProp && onSwipeBackCancelProp();\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n }, [onSwipeBackCancelProp]);\n\n const swipingBackTransitionEndHandler = React.useCallback(() => {\n switch (swipeBackResult) {\n case 'fail':\n onSwipeBackCancel();\n break;\n case 'success':\n onSwipeBackSuccess();\n }\n }, [onSwipeBackCancel, onSwipeBackSuccess, swipeBackResult]);\n\n const handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n setBrowserSwipe(true);\n }\n };\n\n const handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (swipeBackPrevented.current || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, window!.innerWidth);\n\n if (animated && swipeBackTriggered) {\n return;\n }\n\n if (!swipingBack && history && history.length > 1) {\n if (swipedToOpposite) {\n swipeBackPrevented.current = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n swipeBackPrevented.current = true;\n return;\n }\n // Начался свайп назад\n if (onSwipeBackStart) {\n const payload = onSwipeBackStart(activePanel);\n if (payload === 'prevent') {\n swipeBackPrevented.current = true;\n return;\n }\n }\n\n if (activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n blurActiveElement(document);\n scrolls.set(activePanel, scroll?.getScroll().y);\n }\n\n setSwipingBack(true);\n setSwipeBackStartX(event.startX);\n setSwipeBackPrevPanel(activePanel);\n setSwipeBackNextPanel(history.slice(-2)[0]);\n }\n\n if (swipingBack) {\n if (event.shiftX < 0) {\n setSwipeBackShift(0);\n } else if (event.shiftX > window!.innerWidth - swipeBackStartX) {\n setSwipeBackShift(window!.innerWidth);\n } else {\n setSwipeBackShift(event.shiftX);\n }\n }\n };\n\n const handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n swipeBackPrevented.current = false;\n if (swipingBack) {\n const speed = (swipeBackShift / event.duration) * millisecondsInSecond;\n if (swipeBackShift === 0) {\n onSwipeBackCancel();\n } else if (swipeBackShift >= (window!.innerWidth ?? 0)) {\n onSwipeBackSuccess();\n } else if (speed > 250 || swipeBackShift >= window!.innerWidth / 2) {\n setSwipeBackResult('success');\n } else {\n setSwipeBackResult('fail');\n }\n }\n };\n\n const calcPanelSwipeStyles = (isPrev: boolean, isNext: boolean): React.CSSProperties => {\n if ((!isPrev && !isNext) || swipeBackResult) {\n return {};\n }\n\n if (isNext) {\n return window\n ? {\n transform: `translate3d(${-50 + (swipeBackShift * 100) / window.innerWidth / 2}%, 0, 0)`,\n }\n : {};\n }\n\n if (isPrev) {\n return { transform: `translate3d(${swipeBackShift}px, 0, 0)` };\n }\n\n return {};\n };\n\n const calcPanelSwipeBackOverlayStyles = (isNext: boolean): React.CSSProperties => {\n if (!window || !isNext) {\n return {};\n }\n const opacityOnSwipeEnd =\n swipeBackResult === 'success' ? 0 : swipeBackResult === 'fail' ? 1 : null;\n\n return {\n display: 'block',\n opacity:\n opacityOnSwipeEnd === null ? 1 - swipeBackShift / window.innerWidth : opacityOnSwipeEnd,\n };\n };\n\n const handleSwipeBackTargetTransitionEnd = (event: React.TransitionEvent<HTMLDivElement>) => {\n if (event.propertyName.includes('transform')) {\n swipingBackTransitionEndHandler();\n }\n };\n\n React.useEffect(() => {\n // Нужен переход\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n !prevSwipingBack.current &&\n !prevBrowserSwipe.current\n ) {\n const firstLayerId = (\n React.Children.toArray(children) as Array<React.ReactElement<NavIdProps>>\n )\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevActivePanel.current || id === activePanelProp);\n\n const isBackTransition = firstLayerId === activePanelProp;\n scrolls.set(\n prevActivePanel.current,\n scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n );\n\n if (disableAnimation) {\n flushTransition(prevActivePanel.current, isBackTransition);\n } else {\n blurActiveElement(document);\n\n setVisiblePanels([prevActivePanel.current, activePanelProp]);\n setPrevPanel(prevActivePanel.current);\n setNextPanel(activePanelProp);\n setActivePanel(null);\n setAnimated(true);\n setIsBack(isBackTransition);\n }\n }\n\n // Закончилась анимация свайпа назад\n if (\n prevActivePanel.current &&\n prevActivePanel.current !== activePanelProp &&\n prevSwipingBack.current\n ) {\n const nextPanel = activePanelProp;\n const prevPanel = prevActivePanel.current;\n if (prevSwipeBackPrevPanel.current) {\n scrolls.set(prevSwipeBackPrevPanel.current, 0);\n }\n\n setSwipeBackPrevPanel(null);\n setSwipeBackNextPanel(null);\n setSwipingBack(false);\n setSwipeBackResult(null);\n setSwipeBackStartX(0);\n setSwipeBackShift(0);\n setActivePanel(nextPanel);\n setVisiblePanels([nextPanel]);\n setIsBack(true);\n\n layoutEffectCall(() => {\n if (nextPanel !== null) {\n scroll?.scrollTo(0, scrolls.get(nextPanel));\n }\n prevOnTransition.current &&\n prevOnTransition.current({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n });\n }\n\n // Началась анимация завершения свайпа назад.\n // см. `onTransitionEnd()`\n\n // Закончился Safari свайп\n if (prevActivePanel.current !== activePanelProp && browserSwipe) {\n setBrowserSwipe(false);\n setNextPanel(null);\n setPrevPanel(null);\n setAnimated(false);\n setVisiblePanels([activePanelProp]);\n setActivePanel(activePanelProp);\n }\n }, [\n activePanelProp,\n activePanel,\n browserSwipe,\n children,\n disableAnimation,\n document,\n flushTransition,\n scroll,\n swipeBackNextPanel,\n swipeBackResult,\n layoutEffectCall,\n scrolls,\n ]);\n\n React.useEffect(\n function restoreScrollPositionWhenSwipeBackIsCancelled() {\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n const swipeBackCancelledInTheMiddleOfAction =\n prevSwipeBackResult.current === 'fail' && !swipeBackResult;\n const swipeBackCancelledByMovingPanelBackToInitialPoint =\n prevSwipingBack.current && !swipingBack && prevSwipeBackShift.current === 0;\n\n if (\n (swipeBackCancelledInTheMiddleOfAction ||\n swipeBackCancelledByMovingPanelBackToInitialPoint) &&\n activePanel !== null\n ) {\n scroll?.scrollTo(0, scrolls.get(activePanel));\n }\n },\n [swipeBackResult, swipingBack, activePanel, scroll, scrolls],\n );\n\n /**\n * @see https://github.com/VKCOM/VKUI/pull/9274\n */\n React.useEffect(function updateAfterAll() {\n prevActivePanel.current = activePanelProp;\n prevSwipingBack.current = swipingBack;\n prevBrowserSwipe.current = browserSwipe;\n prevSwipeBackResult.current = swipeBackResult;\n prevSwipeBackShift.current = swipeBackShift;\n prevSwipeBackPrevPanel.current = swipeBackPrevPanel;\n prevOnTransition.current = onTransition;\n });\n\n return (\n <NavViewIdContext.Provider value={id}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && animated && styles.animated,\n !disableAnimation && swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={iOSSwipeBackSimulationEnabled ? handleTouchEndForIOSSwipeBackSimulation : undefined}\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n const isPanelActive = panelId === activePanel;\n const isPanelPrev = panelId === prevPanel;\n const isPanelNext = panelId === nextPanel;\n const isAnimatedTarget = animated && (isBack ? isPanelPrev : isPanelNext);\n\n const isSwipeBackPrev = panelId === swipeBackPrevPanel;\n const isSwipeBackNext = panelId === swipeBackNextPanel;\n const isSwipeBackTarget = swipeBackResult && isSwipeBackPrev;\n\n let scrollCompensateStyle: React.CSSProperties | undefined = undefined;\n\n if (isPanelPrev || (isPanelNext && isBack) || isSwipeBackPrev || isSwipeBackNext) {\n const marginTop = scrolls.get(panelId);\n if (marginTop !== undefined) {\n scrollCompensateStyle = { marginTop: -1 * marginTop };\n }\n }\n\n return (\n <div\n className={classNames(\n styles.panel,\n\n isPanelActive && styles.panelActive,\n isPanelPrev && styles.panelPrev,\n isPanelNext && styles.panelNext,\n\n isSwipeBackPrev && styles.panelSwipeBackPrev,\n isSwipeBackNext && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onTransitionEnd={isSwipeBackTarget ? handleSwipeBackTargetTransitionEnd : undefined}\n onAnimationEnd={isAnimatedTarget ? handleAnimatedTargetAnimationEnd : undefined}\n ref={(el) => {\n panelId !== undefined && (panelNodes.current[panelId] = el);\n }}\n style={calcPanelSwipeStyles(isSwipeBackPrev, isSwipeBackNext)}\n key={panelId}\n >\n {platform === 'ios' && (\n <div\n className={styles.panelOverlay}\n style={calcPanelSwipeBackOverlayStyles(isSwipeBackNext)}\n />\n )}\n <div className={styles.panelIn} style={scrollCompensateStyle}>\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n animating={swipingBack || animated}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n </NavViewIdContext.Provider>\n );\n};\n"],"names":["React","classNames","usePlatform","millisecondsInSecond","blurActiveElement","useDOM","getNavId","warnOnce","useScroll","useConfigProvider","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","useSplitCol","Touch","useLayoutEffectCall","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","styles","scrollsCache","Map","warn","View","activePanel","activePanelProp","history","nav","onTransition","onSwipeBack","onSwipeBackStart","onSwipeBackCancel","onSwipeBackCancelProp","children","className","restProps","id","scrolls","useState","get","layoutEffectCall","useEffect","set","panelNodes","useRef","window","document","scroll","configProvider","splitCol","platform","animated","setAnimated","visiblePanels","setVisiblePanels","setActivePanel","isBack","setIsBack","undefined","prevPanel","setPrevPanel","nextPanel","setNextPanel","swipeBackPrevented","swipingBack","setSwipingBack","swipeBackStartX","setSwipeBackStartX","swipeBackShift","setSwipeBackShift","swipeBackNextPanel","setSwipeBackNextPanel","swipeBackPrevPanel","setSwipeBackPrevPanel","swipeBackResult","setSwipeBackResult","browserSwipe","setBrowserSwipe","prevActivePanel","prevSwipingBack","prevBrowserSwipe","prevSwipeBackResult","prevSwipeBackShift","prevSwipeBackPrevPanel","prevOnTransition","panels","Children","toArray","filter","panel","panelId","props","includes","disableAnimation","transitionMotionEnabled","animate","iOSSwipeBackSimulationEnabled","isWebView","Boolean","flushTransition","useCallback","isBackTransition","scrollTo","from","to","handleAnimatedTargetAnimationEnd","e","target","currentTarget","onSwipeBackSuccess","swipingBackTransitionEndHandler","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","current","swipedToOpposite","length","originalEvent","payload","getScroll","y","slice","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","isPrev","isNext","transform","calcPanelSwipeBackOverlayStyles","opacityOnSwipeEnd","display","opacity","handleSwipeBackTargetTransitionEnd","propertyName","firstLayerId","map","find","compensateKeyboardHeight","restoreScrollPositionWhenSwipeBackIsCancelled","swipeBackCancelledInTheMiddleOfAction","swipeBackCancelledByMovingPanelBackToInitialPoint","updateAfterAll","Provider","value","Component","host","ios","noMotion","onMoveX","onEnd","div","isPanelActive","isPanelPrev","isPanelNext","isAnimatedTarget","isSwipeBackPrev","isSwipeBackNext","isSwipeBackTarget","scrollCompensateStyle","marginTop","panelActive","panelPrev","panelNext","panelSwipeBackPrev","panelSwipeBackNext","panelSwipeBackSuccess","panelSwipeBackFailed","onTransitionEnd","onAnimationEnd","ref","el","style","panelOverlay","panelIn","entering","animating"],"mappings":"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"}
@@ -6,7 +6,6 @@ import { withContext } from "../../hoc/withContext.js";
6
6
  import { withPlatform } from "../../hoc/withPlatform.js";
7
7
  import { millisecondsInSecond } from "../../lib/date.js";
8
8
  import { canUseDOM, withDOM } from "../../lib/dom.js";
9
- import { LockFloatingPositionContext } from "../../lib/floating/LockFloatingPosition/LockFloatingPosition.js";
10
9
  import { getNavId } from "../../lib/getNavId.js";
11
10
  import { warnOnce } from "../../lib/warnOnce.js";
12
11
  import { ScrollContext } from "../AppRoot/ScrollContext.js";
@@ -412,45 +411,43 @@ export let scrollsCache = new Map();
412
411
  const iOSSwipeBackSimulationEnabled = !disableAnimation && platform === 'ios' && configProvider?.isWebView && Boolean(onSwipeBack);
413
412
  return /*#__PURE__*/ _jsx(NavViewIdContext.Provider, {
414
413
  value: id || nav,
415
- children: /*#__PURE__*/ _jsx(LockFloatingPositionContext.Provider, {
416
- value: swipingBack || animated,
417
- children: /*#__PURE__*/ _jsx(Touch, {
418
- Component: "section",
419
- ...restProps,
420
- className: classNames(styles.host, platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'), !disableAnimation && this.state.animated && styles.animated, !disableAnimation && this.state.swipingBack && styles.swipingBack, disableAnimation && styles.noMotion, className),
421
- onMoveX: iOSSwipeBackSimulationEnabled ? this.handleTouchMoveXForIOSSwipeBackSimulation : platform === 'ios' ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext : undefined,
422
- onEnd: iOSSwipeBackSimulationEnabled ? this.handleTouchEndForIOSSwipeBackSimulation : undefined,
423
- children: /*#__PURE__*/ _jsx("div", {
424
- className: styles.panels,
425
- children: panels.map((panel)=>{
426
- const panelId = getNavId(panel.props, warn);
427
- const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;
428
- const compensateScroll = isPrev || panelId === swipeBackNextPanel || panelId === nextPanel && isBack;
429
- const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);
430
- const scrollList = panelId && this.scrolls.get(panelId) || [];
431
- const scroll = scrollList[scrollList.length - 1] || 0;
432
- return /*#__PURE__*/ _jsx("div", {
433
- className: classNames(styles.panel, panelId === activePanel && styles.panelActive, panelId === prevPanel && styles.panelPrev, panelId === nextPanel && styles.panelNext, panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev, panelId === swipeBackNextPanel && styles.panelSwipeBackNext, swipeBackResult === 'success' && styles.panelSwipeBackSuccess, swipeBackResult === 'fail' && styles.panelSwipeBackFailed),
434
- onAnimationEnd: isTransitionTarget ? this.transitionEndHandler : undefined,
435
- ref: (el)=>{
436
- panelId !== undefined && (this.panelNodes[panelId] = el);
414
+ children: /*#__PURE__*/ _jsx(Touch, {
415
+ Component: "section",
416
+ ...restProps,
417
+ className: classNames(styles.host, platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'), !disableAnimation && this.state.animated && styles.animated, !disableAnimation && this.state.swipingBack && styles.swipingBack, disableAnimation && styles.noMotion, className),
418
+ onMoveX: iOSSwipeBackSimulationEnabled ? this.handleTouchMoveXForIOSSwipeBackSimulation : platform === 'ios' ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext : undefined,
419
+ onEnd: iOSSwipeBackSimulationEnabled ? this.handleTouchEndForIOSSwipeBackSimulation : undefined,
420
+ children: /*#__PURE__*/ _jsx("div", {
421
+ className: styles.panels,
422
+ children: panels.map((panel)=>{
423
+ const panelId = getNavId(panel.props, warn);
424
+ const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;
425
+ const compensateScroll = isPrev || panelId === swipeBackNextPanel || panelId === nextPanel && isBack;
426
+ const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);
427
+ const scrollList = panelId && this.scrolls.get(panelId) || [];
428
+ const scroll = scrollList[scrollList.length - 1] || 0;
429
+ return /*#__PURE__*/ _jsx("div", {
430
+ className: classNames(styles.panel, panelId === activePanel && styles.panelActive, panelId === prevPanel && styles.panelPrev, panelId === nextPanel && styles.panelNext, panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev, panelId === swipeBackNextPanel && styles.panelSwipeBackNext, swipeBackResult === 'success' && styles.panelSwipeBackSuccess, swipeBackResult === 'fail' && styles.panelSwipeBackFailed),
431
+ onAnimationEnd: isTransitionTarget ? this.transitionEndHandler : undefined,
432
+ ref: (el)=>{
433
+ panelId !== undefined && (this.panelNodes[panelId] = el);
434
+ },
435
+ style: this.calcPanelSwipeStyles(panelId),
436
+ children: /*#__PURE__*/ _jsx("div", {
437
+ className: styles.panelIn,
438
+ style: {
439
+ marginTop: compensateScroll ? -scroll : undefined
437
440
  },
438
- style: this.calcPanelSwipeStyles(panelId),
439
- children: /*#__PURE__*/ _jsx("div", {
440
- className: styles.panelIn,
441
- style: {
442
- marginTop: compensateScroll ? -scroll : undefined
443
- },
444
- children: /*#__PURE__*/ _jsx(NavTransitionDirectionProvider, {
445
- isBack: swipingBack || isBack,
446
- children: /*#__PURE__*/ _jsx(NavTransitionProvider, {
447
- entering: panelId === nextPanel || panelId === swipeBackNextPanel,
448
- children: panel
449
- })
441
+ children: /*#__PURE__*/ _jsx(NavTransitionDirectionProvider, {
442
+ isBack: swipingBack || isBack,
443
+ children: /*#__PURE__*/ _jsx(NavTransitionProvider, {
444
+ entering: panelId === nextPanel || panelId === swipeBackNextPanel,
445
+ animating: swipingBack || animated,
446
+ children: panel
450
447
  })
451
448
  })
452
- }, panelId);
453
- })
449
+ })
450
+ }, panelId);
454
451
  })
455
452
  })
456
453
  })
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { canUseDOM, type DOMProps, withDOM } from '../../lib/dom';\nimport { LockFloatingPositionContext } from '../../lib/floating/LockFloatingPosition/LockFloatingPosition';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasPlatform, HTMLAttributesWithRootRef } from '../../types';\nimport { ScrollContext, type ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n type ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { SplitColContext, type SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nexport let scrollsCache = new Map<string, Map<string, Array<number | undefined>>>();\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends HTMLAttributesWithRootRef<HTMLElement>,\n HasPlatform,\n NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: ((params: TransitionParams & { isBack: boolean }) => void) | undefined;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Функция проверки перехода назад.\n */\n isBackCheck?: ((params: TransitionParams) => boolean) | undefined;\n /**\n * @ignore\n */\n splitCol?: SplitColContextProps | undefined;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface | undefined;\n /**\n * @ignore\n */\n scroll?: ScrollContextInterface | undefined;\n}\n\n/* eslint-disable jsdoc/require-jsdoc */\nexport interface ViewInfiniteState {\n animated: boolean;\n\n visiblePanels: Array<string | null>;\n activePanel: string | null;\n isBack?: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack?: boolean | undefined;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: 'success' | 'fail' | null;\n\n browserSwipe: boolean;\n}\n/* eslint-enable jsdoc/require-jsdoc */\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\n> {\n constructor(props: ViewInfiniteProps) {\n super(props);\n\n this.state = {\n animated: false,\n\n visiblePanels: [props.activePanel],\n activePanel: props.activePanel,\n isBack: undefined,\n prevPanel: null,\n nextPanel: null,\n\n swipingBack: undefined,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n swipeBackNextPanel: null,\n swipeBackPrevPanel: null,\n swipeBackResult: null,\n\n browserSwipe: false,\n };\n }\n\n static defaultProps: Partial<ViewInfiniteProps> = {\n history: [],\n };\n\n private swipeBackPrevented = false;\n private readonly scrolls: Map<string, Array<number | undefined>> =\n scrollsCache.get(getNavId(this.props, warn) as string) || new Map();\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private readonly animationFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n get panels() {\n return React.Children.toArray(this.props.children) as Array<React.ReactElement<NavIdProps>>;\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache.set(id, this.scrolls);\n }\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n }\n\n componentDidUpdate(prevProps: ViewInfiniteProps, prevState: ViewInfiniteState) {\n // Нужен переход\n if (\n prevProps.activePanel !== this.props.activePanel &&\n !prevState.swipingBack &&\n !prevState.browserSwipe\n ) {\n let isBack = false;\n\n if (this.props.isBackCheck) {\n isBack = this.props.isBackCheck({\n from: prevProps.activePanel,\n to: this.props.activePanel,\n });\n } else {\n const firstLayerId = this.panels\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevProps.activePanel || id === this.props.activePanel);\n isBack = firstLayerId === this.props.activePanel;\n }\n\n this.blurActiveElement();\n\n const prevScrolls = this.scrolls.get(prevProps.activePanel) || [];\n this.scrolls.set(prevProps.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n ]);\n\n if (this.shouldDisableTransitionMotion()) {\n this.flushTransition(prevProps.activePanel, isBack);\n } else {\n this.setState({\n visiblePanels: [prevProps.activePanel, this.props.activePanel],\n prevPanel: prevProps.activePanel,\n nextPanel: this.props.activePanel,\n activePanel: null,\n animated: true,\n isBack,\n });\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevProps.activePanel !== this.props.activePanel && prevState.swipingBack) {\n const nextPanel = this.state.swipeBackNextPanel;\n const prevPanel = this.state.swipeBackPrevPanel;\n let scrollPosition: undefined | number = undefined;\n\n if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n this.scrolls.set(prevPanel, prevPanelScrolls);\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls.get(nextPanel) || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(nextPanel, newPanelScrolls);\n }\n\n this.setState(\n {\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n activePanel: nextPanel,\n visiblePanels: [nextPanel],\n },\n () => {\n this.props.scroll?.scrollTo(0, scrollPosition);\n prevProps.onTransition &&\n prevProps.onTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n },\n );\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevState.swipeBackResult && this.state.swipeBackResult) {\n this.waitTransitionFinish(\n this.pickPanel(this.state.swipeBackNextPanel),\n this.swipingBackTransitionEndHandler,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevState.swipeBackResult === 'fail' &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls.get(this.state.activePanel) || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(this.state.activePanel, newPanelScrolls);\n\n this.props.scroll?.scrollTo(0, scrollPosition);\n }\n\n // Закончился Safari свайп\n if (prevProps.activePanel !== this.props.activePanel && this.state.browserSwipe) {\n this.setState({\n browserSwipe: false,\n nextPanel: null,\n prevPanel: null,\n animated: false,\n visiblePanels: [this.props.activePanel],\n activePanel: this.props.activePanel,\n });\n }\n }\n\n shouldDisableTransitionMotion(): boolean {\n return (\n this.props.configProvider?.transitionMotionEnabled === false ||\n !this.props.splitCol?.animate ||\n this.props.platform === 'vkcom'\n );\n }\n\n private transitionDisposer = noop;\n\n private disposeTransition() {\n this.transitionDisposer();\n this.transitionDisposer = noop;\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (this.shouldDisableTransitionMotion()) {\n this.disposeTransition();\n this.transitionFinishTimeout = setTimeout(eventHandler);\n } else if (elem) {\n this.disposeTransition();\n elem.addEventListener('transitionend', eventHandler);\n this.transitionDisposer = () => {\n elem.removeEventListener('transitionend', eventHandler);\n };\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === 'android' || this.props.platform === 'vkcom' ? 300 : 600,\n );\n }\n }\n\n blurActiveElement(): void {\n if (typeof this.window !== 'undefined' && this.document?.activeElement) {\n (this.document.activeElement as HTMLElement).blur();\n }\n }\n\n pickPanel(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.panelNodes[id];\n }\n\n flushTransition(prevPanel: string, isBack: boolean) {\n const activePanel = this.props.activePanel;\n\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls.get(activePanel) || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls.set(prevPanel, prevPanelScrolls);\n this.scrolls.set(activePanel, newPanelScrolls);\n }\n\n this.setState(\n {\n prevPanel: null,\n nextPanel: null,\n visiblePanels: [activePanel],\n activePanel: activePanel,\n animated: false,\n isBack,\n },\n () => {\n this.props.scroll?.scrollTo(0, isBack ? scrollPosition : 0);\n this.props.onTransition &&\n this.props.onTransition({ isBack, from: prevPanel, to: activePanel });\n },\n );\n }\n\n transitionEndHandler: React.AnimationEventHandler<HTMLDivElement> = (e): void => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (this.state.prevPanel !== null) {\n this.flushTransition(this.state.prevPanel, Boolean(this.state.isBack));\n }\n };\n\n swipingBackTransitionEndHandler = (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e.propertyName.includes('transform') &&\n e.target === this.pickPanel(this.state.swipeBackNextPanel))\n ) {\n switch (this.state.swipeBackResult) {\n case 'fail':\n this.onSwipeBackCancel();\n break;\n case 'success':\n this.onSwipeBackSuccess();\n }\n }\n };\n\n onSwipeBackSuccess(): void {\n this.props.onSwipeBack && this.props.onSwipeBack();\n }\n\n onSwipeBackCancel(): void {\n this.props.onSwipeBackCancel && this.props.onSwipeBackCancel();\n this.setState({\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n });\n }\n\n handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (this.state.browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n this.setState({ browserSwipe: true });\n }\n };\n\n handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (this.swipeBackPrevented || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if (this.state.animated && swipeBackTriggered) {\n return;\n }\n\n if (!this.state.swipingBack && this.props.history && this.props.history.length > 1) {\n if (swipedToOpposite) {\n this.swipeBackPrevented = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n this.swipeBackPrevented = true;\n return;\n }\n // Начался свайп назад\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.swipeBackPrevented = true;\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls.get(this.state.activePanel) || [];\n this.scrolls.set(this.state.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll().y,\n ]);\n }\n\n this.setState({\n swipingBack: true,\n swipeBackStartX: event.startX,\n swipeBackPrevPanel: this.state.activePanel,\n swipeBackNextPanel: this.props.history.slice(-2)[0],\n });\n }\n\n if (this.state.swipingBack) {\n if (event.shiftX < 0) {\n this.setState({ swipeBackShift: 0 });\n } else if (event.shiftX > this.window!.innerWidth - this.state.swipeBackStartX) {\n this.setState({ swipeBackShift: this.window!.innerWidth });\n } else {\n this.setState({ swipeBackShift: event.shiftX });\n }\n }\n };\n\n handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n this.swipeBackPrevented = false;\n\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * millisecondsInSecond;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (speed > 250 || this.state.swipeBackShift >= this.window.innerWidth / 2) {\n this.setState({ swipeBackResult: 'success' });\n } else {\n this.setState({ swipeBackResult: 'fail' });\n }\n }\n };\n\n calcPanelSwipeStyles(panelId: string | undefined): React.CSSProperties {\n if (!canUseDOM || !this.window) {\n return {};\n }\n\n const isPrev = panelId === this.state.swipeBackPrevPanel;\n const isNext = panelId === this.state.swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || this.state.swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${this.state.swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (this.state.swipeBackShift * 100) / this.window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (this.window.innerWidth - this.state.swipeBackShift)) / this.window.innerWidth;\n\n if (this.state.swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n }\n\n render() {\n const {\n platform,\n activePanel: _1,\n splitCol,\n configProvider,\n history,\n id,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel,\n window,\n document,\n scroll,\n isBackCheck,\n className,\n ...restProps\n } = this.props;\n const {\n prevPanel,\n nextPanel,\n activePanel,\n isBack,\n animated,\n swipeBackPrevPanel,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n } = this.state;\n\n const panels = this.panels\n .filter((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && this.state.visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n })\n .sort((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrevPanel = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isNextPanel = panelId === nextPanel || panelId === swipeBackNextPanel;\n\n if (isNextPanel) {\n return swipingBack || this.state.isBack ? -1 : 1;\n }\n\n if (isPrevPanel) {\n return swipingBack || this.state.isBack ? 1 : -1;\n }\n\n return 0;\n });\n\n const disableAnimation = this.shouldDisableTransitionMotion();\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider?.isWebView && Boolean(onSwipeBack);\n\n return (\n <NavViewIdContext.Provider value={id || nav}>\n <LockFloatingPositionContext.Provider value={swipingBack || animated}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles.animated,\n !disableAnimation && this.state.swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchEndForIOSSwipeBackSimulation\n : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const scrollList = (panelId && this.scrolls.get(panelId)) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles.panel,\n panelId === activePanel && styles.panelActive,\n panelId === prevPanel && styles.panelPrev,\n panelId === nextPanel && styles.panelNext,\n panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev,\n panelId === swipeBackNextPanel && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => {\n panelId !== undefined && (this.panelNodes[panelId] = el);\n }}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles.panelIn}\n style={{ marginTop: compensateScroll ? -scroll : undefined }}\n >\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n </LockFloatingPositionContext.Provider>\n </NavViewIdContext.Provider>\n );\n }\n}\n\nexport const ViewInfinite: React.FC<ViewInfiniteProps> = withContext(\n withContext(\n withContext(\n withPlatform(withDOM<ViewInfiniteProps>(ViewInfiniteComponent)),\n SplitColContext,\n 'splitCol',\n ),\n ConfigProviderContext,\n 'configProvider',\n ),\n ScrollContext,\n 'scroll',\n);\n"],"names":["React","classNames","noop","withContext","withPlatform","millisecondsInSecond","canUseDOM","withDOM","LockFloatingPositionContext","getNavId","warnOnce","ScrollContext","ConfigProviderContext","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","SplitColContext","Touch","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","styles","warn","scrollsCache","Map","ViewInfiniteComponent","Component","props","state","animated","visiblePanels","activePanel","isBack","undefined","prevPanel","nextPanel","swipingBack","swipeBackStartX","swipeBackShift","swipeBackNextPanel","swipeBackPrevPanel","swipeBackResult","browserSwipe","defaultProps","history","swipeBackPrevented","scrolls","get","transitionFinishTimeout","animationFinishTimeout","document","window","panels","Children","toArray","children","panelNodes","componentWillUnmount","id","set","clearTimeout","componentDidUpdate","prevProps","prevState","isBackCheck","from","to","firstLayerId","map","panel","find","blurActiveElement","prevScrolls","scroll","getScroll","compensateKeyboardHeight","y","shouldDisableTransitionMotion","flushTransition","setState","scrollPosition","prevPanelScrolls","slice","newPanelScrolls","pop","scrollTo","onTransition","waitTransitionFinish","pickPanel","swipingBackTransitionEndHandler","configProvider","transitionMotionEnabled","splitCol","animate","platform","transitionDisposer","disposeTransition","elem","eventHandler","setTimeout","addEventListener","removeEventListener","activeElement","blur","transitionEndHandler","e","target","currentTarget","Boolean","propertyName","includes","onSwipeBackCancel","onSwipeBackSuccess","onSwipeBack","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","swipedToOpposite","length","originalEvent","onSwipeBackStart","payload","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","render","_1","nav","className","restProps","filter","sort","isPrevPanel","isNextPanel","disableAnimation","iOSSwipeBackSimulationEnabled","isWebView","Provider","value","host","ios","noMotion","onMoveX","onEnd","div","compensateScroll","isTransitionTarget","scrollList","panelActive","panelPrev","panelNext","panelSwipeBackPrev","panelSwipeBackNext","panelSwipeBackSuccess","panelSwipeBackFailed","onAnimationEnd","ref","el","style","panelIn","marginTop","entering","ViewInfinite"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAQ;AAC/B,SAASC,UAAU,EAAEC,IAAI,QAAQ,kBAAkB;AACnD,SAASC,WAAW,QAAQ,2BAAwB;AACpD,SAASC,YAAY,QAAQ,4BAAyB;AACtD,SAASC,oBAAoB,QAAQ,oBAAiB;AACtD,SAASC,SAAS,EAAiBC,OAAO,QAAQ,mBAAgB;AAClE,SAASC,2BAA2B,QAAQ,kEAA+D;AAC3G,SAASC,QAAQ,QAAyB,wBAAqB;AAC/D,SAASC,QAAQ,QAAQ,wBAAqB;AAE9C,SAASC,aAAa,QAAqC,8BAA2B;AACtF,SACEC,qBAAqB,QAEhB,6CAA0C;AACjD,SAASC,gBAAgB,QAAQ,kCAA+B;AAChE,SAASC,qBAAqB,QAAQ,kDAA+C;AACrF,SAASC,8BAA8B,QAAQ,oEAAiE;AAChH,SAASC,eAAe,QAAmC,iCAA8B;AACzF,SAAgCC,KAAK,QAAQ,oBAAiB;AAC9D,SACEC,sBAAsB,EACtBC,gDAAgD,EAChDC,iBAAiB,QACZ,aAAU;AACjB,OAAOC,YAAY,oBAAoB;AAEvC,MAAMC,OAAOZ,SAAS;AAItB,OAAO,IAAIa,eAAe,IAAIC,MAAsD;AAsEpF,qCAAqC,GAErC,MAAMC,8BAA8BzB,MAAM0B,SAAS;IAIjD,YAAYC,KAAwB,CAAE;QACpC,KAAK,CAACA;QAEN,IAAI,CAACC,KAAK,GAAG;YACXC,UAAU;YAEVC,eAAe;gBAACH,MAAMI,WAAW;aAAC;YAClCA,aAAaJ,MAAMI,WAAW;YAC9BC,QAAQC;YACRC,WAAW;YACXC,WAAW;YAEXC,aAAaH;YACbI,iBAAiB;YACjBC,gBAAgB;YAChBC,oBAAoB;YACpBC,oBAAoB;YACpBC,iBAAiB;YAEjBC,cAAc;QAChB;IACF;IAEA,OAAOC,eAA2C;QAChDC,SAAS,EAAE;IACb,EAAE;IAEMC,qBAAqB,MAAM;IAClBC,UACfvB,aAAawB,GAAG,CAACtC,SAAS,IAAI,CAACkB,KAAK,EAAEL,UAAoB,IAAIE,MAAM;IAC9DwB,0BAAqEf,UAAU;IACtEgB,yBAAoEhB,UAAU;IAE/F,IAAIiB,WAAW;QACb,OAAO,IAAI,CAACvB,KAAK,CAACuB,QAAQ;IAC5B;IAEA,IAAIC,SAAS;QACX,OAAO,IAAI,CAACxB,KAAK,CAACwB,MAAM;IAC1B;IAEA,IAAIC,SAAS;QACX,OAAOpD,MAAMqD,QAAQ,CAACC,OAAO,CAAC,IAAI,CAAC3B,KAAK,CAAC4B,QAAQ;IACnD;IAEAC,aAAsD,CAAC,EAAE;IAEzDC,uBAAuB;QACrB,MAAMC,KAAKjD,SAAS,IAAI,CAACkB,KAAK;QAC9B,IAAI+B,IAAI;YACNnC,aAAaoC,GAAG,CAACD,IAAI,IAAI,CAACZ,OAAO;QACnC;QACA,IAAI,IAAI,CAACG,sBAAsB,EAAE;YAC/BW,aAAa,IAAI,CAACX,sBAAsB;QAC1C;IACF;IAEAY,mBAAmBC,SAA4B,EAAEC,SAA4B,EAAE;QAC7E,gBAAgB;QAChB,IACED,UAAU/B,WAAW,KAAK,IAAI,CAACJ,KAAK,CAACI,WAAW,IAChD,CAACgC,UAAU3B,WAAW,IACtB,CAAC2B,UAAUrB,YAAY,EACvB;YACA,IAAIV,SAAS;YAEb,IAAI,IAAI,CAACL,KAAK,CAACqC,WAAW,EAAE;gBAC1BhC,SAAS,IAAI,CAACL,KAAK,CAACqC,WAAW,CAAC;oBAC9BC,MAAMH,UAAU/B,WAAW;oBAC3BmC,IAAI,IAAI,CAACvC,KAAK,CAACI,WAAW;gBAC5B;YACF,OAAO;gBACL,MAAMoC,eAAe,IAAI,CAACf,MAAM,CAC7BgB,GAAG,CAAC,CAACC,QAAU5D,SAAS4D,MAAM1C,KAAK,EAAEL,OACrCgD,IAAI,CAAC,CAACZ,KAAOA,OAAOI,UAAU/B,WAAW,IAAI2B,OAAO,IAAI,CAAC/B,KAAK,CAACI,WAAW;gBAC7EC,SAASmC,iBAAiB,IAAI,CAACxC,KAAK,CAACI,WAAW;YAClD;YAEA,IAAI,CAACwC,iBAAiB;YAEtB,MAAMC,cAAc,IAAI,CAAC1B,OAAO,CAACC,GAAG,CAACe,UAAU/B,WAAW,KAAK,EAAE;YACjE,IAAI,CAACe,OAAO,CAACa,GAAG,CAACG,UAAU/B,WAAW,EAAE;mBACnCyC;gBACH,IAAI,CAAC7C,KAAK,CAAC8C,MAAM,EAAEC,UAAU;oBAAEC,0BAA0B;gBAAM,GAAGC;aACnE;YAED,IAAI,IAAI,CAACC,6BAA6B,IAAI;gBACxC,IAAI,CAACC,eAAe,CAAChB,UAAU/B,WAAW,EAAEC;YAC9C,OAAO;gBACL,IAAI,CAAC+C,QAAQ,CAAC;oBACZjD,eAAe;wBAACgC,UAAU/B,WAAW;wBAAE,IAAI,CAACJ,KAAK,CAACI,WAAW;qBAAC;oBAC9DG,WAAW4B,UAAU/B,WAAW;oBAChCI,WAAW,IAAI,CAACR,KAAK,CAACI,WAAW;oBACjCA,aAAa;oBACbF,UAAU;oBACVG;gBACF;YACF;QACF;QAEA,oCAAoC;QACpC,IAAI8B,UAAU/B,WAAW,KAAK,IAAI,CAACJ,KAAK,CAACI,WAAW,IAAIgC,UAAU3B,WAAW,EAAE;YAC7E,MAAMD,YAAY,IAAI,CAACP,KAAK,CAACW,kBAAkB;YAC/C,MAAML,YAAY,IAAI,CAACN,KAAK,CAACY,kBAAkB;YAC/C,IAAIwC,iBAAqC/C;YAEzC,IAAIC,cAAc,MAAM;gBACtB,MAAM+C,mBAAmB;uBAAK,IAAI,CAACnC,OAAO,CAACC,GAAG,CAACb,cAAc,EAAE;iBAAE,CAACgD,KAAK,CAAC,GAAG,CAAC;gBAC5E,IAAI,CAACpC,OAAO,CAACa,GAAG,CAACzB,WAAW+C;YAC9B;YACA,IAAI9C,cAAc,MAAM;gBACtB,MAAMgD,kBAAkB;uBAAK,IAAI,CAACrC,OAAO,CAACC,GAAG,CAACZ,cAAc,EAAE;iBAAE;gBAChE6C,iBAAiBG,gBAAgBC,GAAG;gBACpC,IAAI,CAACtC,OAAO,CAACa,GAAG,CAACxB,WAAWgD;YAC9B;YAEA,IAAI,CAACJ,QAAQ,CACX;gBACEvC,oBAAoB;gBACpBD,oBAAoB;gBACpBH,aAAa;gBACbK,iBAAiB;gBACjBJ,iBAAiB;gBACjBC,gBAAgB;gBAChBP,aAAaI;gBACbL,eAAe;oBAACK;iBAAU;YAC5B,GACA;gBACE,IAAI,CAACR,KAAK,CAAC8C,MAAM,EAAEY,SAAS,GAAGL;gBAC/BlB,UAAUwB,YAAY,IACpBxB,UAAUwB,YAAY,CAAC;oBACrBtD,QAAQ;oBACRiC,MAAM/B;oBACNgC,IAAI/B;gBACN;YACJ;QAEJ;QAEA,6CAA6C;QAC7C,IAAI,CAAC4B,UAAUtB,eAAe,IAAI,IAAI,CAACb,KAAK,CAACa,eAAe,EAAE;YAC5D,IAAI,CAAC8C,oBAAoB,CACvB,IAAI,CAACC,SAAS,CAAC,IAAI,CAAC5D,KAAK,CAACW,kBAAkB,GAC5C,IAAI,CAACkD,+BAA+B;QAExC;QAEA,+EAA+E;QAC/E,IACE1B,UAAUtB,eAAe,KAAK,UAC9B,CAAC,IAAI,CAACb,KAAK,CAACa,eAAe,IAC3B,IAAI,CAACb,KAAK,CAACG,WAAW,KAAK,MAC3B;YACA,MAAMoD,kBAAkB;mBAAK,IAAI,CAACrC,OAAO,CAACC,GAAG,CAAC,IAAI,CAACnB,KAAK,CAACG,WAAW,KAAK,EAAE;aAAE;YAC7E,MAAMiD,iBAAiBG,gBAAgBC,GAAG;YAC1C,IAAI,CAACtC,OAAO,CAACa,GAAG,CAAC,IAAI,CAAC/B,KAAK,CAACG,WAAW,EAAEoD;YAEzC,IAAI,CAACxD,KAAK,CAAC8C,MAAM,EAAEY,SAAS,GAAGL;QACjC;QAEA,0BAA0B;QAC1B,IAAIlB,UAAU/B,WAAW,KAAK,IAAI,CAACJ,KAAK,CAACI,WAAW,IAAI,IAAI,CAACH,KAAK,CAACc,YAAY,EAAE;YAC/E,IAAI,CAACqC,QAAQ,CAAC;gBACZrC,cAAc;gBACdP,WAAW;gBACXD,WAAW;gBACXL,UAAU;gBACVC,eAAe;oBAAC,IAAI,CAACH,KAAK,CAACI,WAAW;iBAAC;gBACvCA,aAAa,IAAI,CAACJ,KAAK,CAACI,WAAW;YACrC;QACF;IACF;IAEA8C,gCAAyC;QACvC,OACE,IAAI,CAAClD,KAAK,CAAC+D,cAAc,EAAEC,4BAA4B,SACvD,CAAC,IAAI,CAAChE,KAAK,CAACiE,QAAQ,EAAEC,WACtB,IAAI,CAAClE,KAAK,CAACmE,QAAQ,KAAK;IAE5B;IAEQC,qBAAqB7F,KAAK;IAE1B8F,oBAAoB;QAC1B,IAAI,CAACD,kBAAkB;QACvB,IAAI,CAACA,kBAAkB,GAAG7F;IAC5B;IAEAqF,qBACEU,IAAoC,EACpCC,YAAoC,EAC9B;QACN,IAAI,IAAI,CAACrB,6BAA6B,IAAI;YACxC,IAAI,CAACmB,iBAAiB;YACtB,IAAI,CAAChD,uBAAuB,GAAGmD,WAAWD;QAC5C,OAAO,IAAID,MAAM;YACf,IAAI,CAACD,iBAAiB;YACtBC,KAAKG,gBAAgB,CAAC,iBAAiBF;YACvC,IAAI,CAACH,kBAAkB,GAAG;gBACxBE,KAAKI,mBAAmB,CAAC,iBAAiBH;YAC5C;QACF,OAAO;YACL,IAAI,IAAI,CAAClD,uBAAuB,EAAE;gBAChCY,aAAa,IAAI,CAACZ,uBAAuB;YAC3C;YACA,IAAI,CAACA,uBAAuB,GAAGmD,WAC7BD,cACA,IAAI,CAACvE,KAAK,CAACmE,QAAQ,KAAK,aAAa,IAAI,CAACnE,KAAK,CAACmE,QAAQ,KAAK,UAAU,MAAM;QAEjF;IACF;IAEAvB,oBAA0B;QACxB,IAAI,OAAO,IAAI,CAACpB,MAAM,KAAK,eAAe,IAAI,CAACD,QAAQ,EAAEoD,eAAe;YACrE,IAAI,CAACpD,QAAQ,CAACoD,aAAa,CAAiBC,IAAI;QACnD;IACF;IAEAf,UAAU9B,EAAiB,EAAE;QAC3B,IAAIA,OAAO,MAAM;YACf,OAAOzB;QACT;QACA,OAAO,IAAI,CAACuB,UAAU,CAACE,GAAG;IAC5B;IAEAoB,gBAAgB5C,SAAiB,EAAEF,MAAe,EAAE;QAClD,MAAMD,cAAc,IAAI,CAACJ,KAAK,CAACI,WAAW;QAE1C,MAAMkD,mBAAmB;eAAK,IAAI,CAACnC,OAAO,CAACC,GAAG,CAACb,cAAc,EAAE;SAAE,CAACgD,KAAK,CAAC,GAAG,CAAC;QAC5E,MAAMC,kBAAkB;eAAK,IAAI,CAACrC,OAAO,CAACC,GAAG,CAAChB,gBAAgB,EAAE;SAAE;QAClE,MAAMiD,iBAAiBhD,SAASmD,gBAAgBC,GAAG,KAAK;QACxD,IAAIpD,QAAQ;YACV,IAAI,CAACc,OAAO,CAACa,GAAG,CAACzB,WAAW+C;YAC5B,IAAI,CAACnC,OAAO,CAACa,GAAG,CAAC5B,aAAaoD;QAChC;QAEA,IAAI,CAACJ,QAAQ,CACX;YACE7C,WAAW;YACXC,WAAW;YACXL,eAAe;gBAACC;aAAY;YAC5BA,aAAaA;YACbF,UAAU;YACVG;QACF,GACA;YACE,IAAI,CAACL,KAAK,CAAC8C,MAAM,EAAEY,SAAS,GAAGrD,SAASgD,iBAAiB;YACzD,IAAI,CAACrD,KAAK,CAAC2D,YAAY,IACrB,IAAI,CAAC3D,KAAK,CAAC2D,YAAY,CAAC;gBAAEtD;gBAAQiC,MAAM/B;gBAAWgC,IAAInC;YAAY;QACvE;IAEJ;IAEAyE,uBAAoE,CAACC;QACnE,IAAIA,EAAEC,MAAM,KAAKD,EAAEE,aAAa,EAAE;YAChC;QACF;QAEA,IAAI,IAAI,CAAC/E,KAAK,CAACM,SAAS,KAAK,MAAM;YACjC,IAAI,CAAC4C,eAAe,CAAC,IAAI,CAAClD,KAAK,CAACM,SAAS,EAAE0E,QAAQ,IAAI,CAAChF,KAAK,CAACI,MAAM;QACtE;IACF,EAAE;IAEFyD,kCAAkC,CAACgB;QACjC,qDAAqD;QACrD,IACE,CAACA,KACAA,EAAEI,YAAY,CAACC,QAAQ,CAAC,gBACvBL,EAAEC,MAAM,KAAK,IAAI,CAAClB,SAAS,CAAC,IAAI,CAAC5D,KAAK,CAACW,kBAAkB,GAC3D;YACA,OAAQ,IAAI,CAACX,KAAK,CAACa,eAAe;gBAChC,KAAK;oBACH,IAAI,CAACsE,iBAAiB;oBACtB;gBACF,KAAK;oBACH,IAAI,CAACC,kBAAkB;YAC3B;QACF;IACF,EAAE;IAEFA,qBAA2B;QACzB,IAAI,CAACrF,KAAK,CAACsF,WAAW,IAAI,IAAI,CAACtF,KAAK,CAACsF,WAAW;IAClD;IAEAF,oBAA0B;QACxB,IAAI,CAACpF,KAAK,CAACoF,iBAAiB,IAAI,IAAI,CAACpF,KAAK,CAACoF,iBAAiB;QAC5D,IAAI,CAAChC,QAAQ,CAAC;YACZvC,oBAAoB;YACpBD,oBAAoB;YACpBH,aAAa;YACbK,iBAAiB;YACjBJ,iBAAiB;YACjBC,gBAAgB;QAClB;IACF;IAEA4E,mDAAmD,CAACC;QAClD,IAAI,IAAI,CAACvF,KAAK,CAACc,YAAY,EAAE;YAC3B;QACF;QACA,MAAM,EAAE0E,kBAAkB,EAAEC,wBAAwB,EAAEC,sBAAsB,EAAE,GAC5EpG,uBAAuBiG,MAAMI,MAAM,EAAEJ,MAAMK,MAAM,EAAE,IAAI,CAACrE,MAAM,CAAEsE,UAAU;QAE5E,IAAI,AAACJ,CAAAA,4BAA4BC,sBAAqB,KAAMF,oBAAoB;YAC9E,IAAI,CAACrC,QAAQ,CAAC;gBAAErC,cAAc;YAAK;QACrC;IACF,EAAE;IAEFgF,4CAA4C,CAACP;QAC3C,IAAI,IAAI,CAACtE,kBAAkB,IAAIzB,kBAAkB+F,QAAQ;YACvD;QACF;QAEA,MAAM,EAAEQ,gBAAgB,EAAEP,kBAAkB,EAAEC,wBAAwB,EAAE,GACtEnG,uBAAuBiG,MAAMI,MAAM,EAAEJ,MAAMK,MAAM,EAAE,IAAI,CAACrE,MAAM,CAAEsE,UAAU;QAE5E,IAAI,IAAI,CAAC7F,KAAK,CAACC,QAAQ,IAAIuF,oBAAoB;YAC7C;QACF;QAEA,IAAI,CAAC,IAAI,CAACxF,KAAK,CAACQ,WAAW,IAAI,IAAI,CAACT,KAAK,CAACiB,OAAO,IAAI,IAAI,CAACjB,KAAK,CAACiB,OAAO,CAACgF,MAAM,GAAG,GAAG;YAClF,IAAID,kBAAkB;gBACpB,IAAI,CAAC9E,kBAAkB,GAAG;gBAC1B;YACF;YAEA,IAAI,CAACuE,oBAAoB;gBACvB;YACF;YAEA,IACE,CAACC,4BACDlG,iDAAiDgG,MAAMU,aAAa,CAACnB,MAAM,GAC3E;gBACA,IAAI,CAAC7D,kBAAkB,GAAG;gBAC1B;YACF;YACA,sBAAsB;YACtB,IAAI,IAAI,CAAClB,KAAK,CAACmG,gBAAgB,EAAE;gBAC/B,MAAMC,UAAU,IAAI,CAACpG,KAAK,CAACmG,gBAAgB,CAAC,IAAI,CAAClG,KAAK,CAACG,WAAW;gBAClE,IAAIgG,YAAY,WAAW;oBACzB,IAAI,CAAClF,kBAAkB,GAAG;oBAC1B;gBACF;YACF;YAEA,IAAI,IAAI,CAACjB,KAAK,CAACG,WAAW,KAAK,MAAM;gBACnC,+EAA+E;gBAC/E,IAAI,CAACwC,iBAAiB;gBACtB,MAAMC,cAAc,IAAI,CAAC1B,OAAO,CAACC,GAAG,CAAC,IAAI,CAACnB,KAAK,CAACG,WAAW,KAAK,EAAE;gBAClE,IAAI,CAACe,OAAO,CAACa,GAAG,CAAC,IAAI,CAAC/B,KAAK,CAACG,WAAW,EAAE;uBACpCyC;oBACH,IAAI,CAAC7C,KAAK,CAAC8C,MAAM,EAAEC,YAAYE;iBAChC;YACH;YAEA,IAAI,CAACG,QAAQ,CAAC;gBACZ3C,aAAa;gBACbC,iBAAiB8E,MAAMI,MAAM;gBAC7B/E,oBAAoB,IAAI,CAACZ,KAAK,CAACG,WAAW;gBAC1CQ,oBAAoB,IAAI,CAACZ,KAAK,CAACiB,OAAO,CAACsC,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE;YACrD;QACF;QAEA,IAAI,IAAI,CAACtD,KAAK,CAACQ,WAAW,EAAE;YAC1B,IAAI+E,MAAMK,MAAM,GAAG,GAAG;gBACpB,IAAI,CAACzC,QAAQ,CAAC;oBAAEzC,gBAAgB;gBAAE;YACpC,OAAO,IAAI6E,MAAMK,MAAM,GAAG,IAAI,CAACrE,MAAM,CAAEsE,UAAU,GAAG,IAAI,CAAC7F,KAAK,CAACS,eAAe,EAAE;gBAC9E,IAAI,CAAC0C,QAAQ,CAAC;oBAAEzC,gBAAgB,IAAI,CAACa,MAAM,CAAEsE,UAAU;gBAAC;YAC1D,OAAO;gBACL,IAAI,CAAC1C,QAAQ,CAAC;oBAAEzC,gBAAgB6E,MAAMK,MAAM;gBAAC;YAC/C;QACF;IACF,EAAE;IAEFQ,0CAA0C,CAACb;QACzC,IAAI,CAACtE,kBAAkB,GAAG;QAE1B,IAAI,IAAI,CAACjB,KAAK,CAACQ,WAAW,IAAI,IAAI,CAACe,MAAM,EAAE;YACzC,MAAM8E,QAAQ,AAAC,IAAI,CAACrG,KAAK,CAACU,cAAc,GAAG6E,MAAMe,QAAQ,GAAI7H;YAC7D,IAAI,IAAI,CAACuB,KAAK,CAACU,cAAc,KAAK,GAAG;gBACnC,IAAI,CAACyE,iBAAiB;YACxB,OAAO,IAAI,IAAI,CAACnF,KAAK,CAACU,cAAc,IAAI,IAAI,CAACa,MAAM,CAACsE,UAAU,EAAE;gBAC9D,IAAI,CAACT,kBAAkB;YACzB,OAAO,IAAIiB,QAAQ,OAAO,IAAI,CAACrG,KAAK,CAACU,cAAc,IAAI,IAAI,CAACa,MAAM,CAACsE,UAAU,GAAG,GAAG;gBACjF,IAAI,CAAC1C,QAAQ,CAAC;oBAAEtC,iBAAiB;gBAAU;YAC7C,OAAO;gBACL,IAAI,CAACsC,QAAQ,CAAC;oBAAEtC,iBAAiB;gBAAO;YAC1C;QACF;IACF,EAAE;IAEF0F,qBAAqBC,OAA2B,EAAuB;QACrE,IAAI,CAAC9H,aAAa,CAAC,IAAI,CAAC6C,MAAM,EAAE;YAC9B,OAAO,CAAC;QACV;QAEA,MAAMkF,SAASD,YAAY,IAAI,CAACxG,KAAK,CAACY,kBAAkB;QACxD,MAAM8F,SAASF,YAAY,IAAI,CAACxG,KAAK,CAACW,kBAAkB;QAExD,IAAI,AAAC,CAAC8F,UAAU,CAACC,UAAW,IAAI,CAAC1G,KAAK,CAACa,eAAe,EAAE;YACtD,OAAO,CAAC;QACV;QAEA,IAAI8F,qBAAqB,GAAG,IAAI,CAAC3G,KAAK,CAACU,cAAc,CAAC,EAAE,CAAC;QACzD,IAAIkG,qBAAqB,GACvB,CAAC,KAAK,AAAC,IAAI,CAAC5G,KAAK,CAACU,cAAc,GAAG,MAAO,IAAI,CAACa,MAAM,CAACsE,UAAU,GAAG,EACpE,CAAC,CAAC;QACH,IAAIgB,kBACF,AAAC,MAAO,CAAA,IAAI,CAACtF,MAAM,CAACsE,UAAU,GAAG,IAAI,CAAC7F,KAAK,CAACU,cAAc,AAAD,IAAM,IAAI,CAACa,MAAM,CAACsE,UAAU;QAEvF,IAAI,IAAI,CAAC7F,KAAK,CAACa,eAAe,EAAE;YAC9B,OAAO4F,SAAS;gBAAEK,WAAW,CAAC,0BAA0B,EAAED,gBAAgB,CAAC,CAAC;YAAC,IAAI,CAAC;QACpF;QAEA,IAAIH,QAAQ;YACV,OAAO;gBACLK,WAAW,CAAC,YAAY,EAAEH,mBAAmB,OAAO,CAAC;YACvD;QACF;QACA,IAAIH,QAAQ;YACV,OAAO;gBACLM,WAAW,CAAC,YAAY,EAAEJ,mBAAmB,OAAO,CAAC;gBACrDG,WAAW,CAAC,0BAA0B,EAAED,gBAAgB,CAAC,CAAC;YAC5D;QACF;QAEA,OAAO,CAAC;IACV;IAEAG,SAAS;QACP,MAAM,EACJ9C,QAAQ,EACR/D,aAAa8G,EAAE,EACfjD,QAAQ,EACRF,cAAc,EACd9C,OAAO,EACPc,EAAE,EACFoF,GAAG,EACHxD,YAAY,EACZ2B,WAAW,EACXa,gBAAgB,EAChBf,iBAAiB,EACjB5D,MAAM,EACND,QAAQ,EACRuB,MAAM,EACNT,WAAW,EACX+E,SAAS,EACT,GAAGC,WACJ,GAAG,IAAI,CAACrH,KAAK;QACd,MAAM,EACJO,SAAS,EACTC,SAAS,EACTJ,WAAW,EACXC,MAAM,EACNH,QAAQ,EACRW,kBAAkB,EAClBD,kBAAkB,EAClBE,eAAe,EACfL,WAAW,EACZ,GAAG,IAAI,CAACR,KAAK;QAEd,MAAMwB,SAAS,IAAI,CAACA,MAAM,CACvB6F,MAAM,CAAC,CAAC5E;YACP,MAAM+D,UAAU3H,SAAS4D,MAAM1C,KAAK,EAAEL;YAEtC,OACE,AAAC8G,YAAYnG,aAAa,IAAI,CAACL,KAAK,CAACE,aAAa,CAACgF,QAAQ,CAACsB,YAC5DA,YAAY5F,sBACZ4F,YAAY7F;QAEhB,GACC2G,IAAI,CAAC,CAAC7E;YACL,MAAM+D,UAAU3H,SAAS4D,MAAM1C,KAAK,EAAEL;YACtC,MAAM6H,cAAcf,YAAYlG,aAAakG,YAAY5F;YACzD,MAAM4G,cAAchB,YAAYjG,aAAaiG,YAAY7F;YAEzD,IAAI6G,aAAa;gBACf,OAAOhH,eAAe,IAAI,CAACR,KAAK,CAACI,MAAM,GAAG,CAAC,IAAI;YACjD;YAEA,IAAImH,aAAa;gBACf,OAAO/G,eAAe,IAAI,CAACR,KAAK,CAACI,MAAM,GAAG,IAAI,CAAC;YACjD;YAEA,OAAO;QACT;QAEF,MAAMqH,mBAAmB,IAAI,CAACxE,6BAA6B;QAC3D,MAAMyE,gCACJ,CAACD,oBAAoBvD,aAAa,SAASJ,gBAAgB6D,aAAa3C,QAAQK;QAElF,qBACE,KAACpG,iBAAiB2I,QAAQ;YAACC,OAAO/F,MAAMoF;sBACtC,cAAA,KAACtI,4BAA4BgJ,QAAQ;gBAACC,OAAOrH,eAAeP;0BAC1D,cAAA,KAACZ;oBACCS,WAAU;oBACT,GAAGsH,SAAS;oBACbD,WAAW9I,WACToB,OAAOqI,IAAI,EACX5D,aAAa,SAAS7F,WAAWoB,OAAOsI,GAAG,EAAE,0BAC7C,CAACN,oBAAoB,IAAI,CAACzH,KAAK,CAACC,QAAQ,IAAIR,OAAOQ,QAAQ,EAC3D,CAACwH,oBAAoB,IAAI,CAACzH,KAAK,CAACQ,WAAW,IAAIf,OAAOe,WAAW,EACjEiH,oBAAoBhI,OAAOuI,QAAQ,EACnCb;oBAEFc,SACEP,gCACI,IAAI,CAAC5B,yCAAyC,GAC9C5B,aAAa,QACX,IAAI,CAACoB,gDAAgD,GACrDjF;oBAER6H,OACER,gCACI,IAAI,CAACtB,uCAAuC,GAC5C/F;8BAGN,cAAA,KAAC8H;wBAAIhB,WAAW1H,OAAO+B,MAAM;kCAC1BA,OAAOgB,GAAG,CAAC,CAACC;4BACX,MAAM+D,UAAU3H,SAAS4D,MAAM1C,KAAK,EAAEL;4BACtC,MAAM+G,SAASD,YAAYlG,aAAakG,YAAY5F;4BACpD,MAAMwH,mBACJ3B,UAAUD,YAAY7F,sBAAuB6F,YAAYjG,aAAaH;4BACxE,MAAMiI,qBAAqBpI,YAAYuG,YAAapG,CAAAA,SAASE,YAAYC,SAAQ;4BACjF,MAAM+H,aAAa,AAAC9B,WAAW,IAAI,CAACtF,OAAO,CAACC,GAAG,CAACqF,YAAa,EAAE;4BAC/D,MAAM3D,SAASyF,UAAU,CAACA,WAAWtC,MAAM,GAAG,EAAE,IAAI;4BAEpD,qBACE,KAACmC;gCACChB,WAAW9I,WACToB,OAAOgD,KAAK,EACZ+D,YAAYrG,eAAeV,OAAO8I,WAAW,EAC7C/B,YAAYlG,aAAab,OAAO+I,SAAS,EACzChC,YAAYjG,aAAad,OAAOgJ,SAAS,EACzCjC,YAAY5F,sBAAsBnB,OAAOiJ,kBAAkB,EAC3DlC,YAAY7F,sBAAsBlB,OAAOkJ,kBAAkB,EAC3D9H,oBAAoB,aAAapB,OAAOmJ,qBAAqB,EAC7D/H,oBAAoB,UAAUpB,OAAOoJ,oBAAoB;gCAE3DC,gBAAgBT,qBAAqB,IAAI,CAACzD,oBAAoB,GAAGvE;gCACjE0I,KAAK,CAACC;oCACJxC,YAAYnG,aAAc,CAAA,IAAI,CAACuB,UAAU,CAAC4E,QAAQ,GAAGwC,EAAC;gCACxD;gCACAC,OAAO,IAAI,CAAC1C,oBAAoB,CAACC;0CAGjC,cAAA,KAAC2B;oCACChB,WAAW1H,OAAOyJ,OAAO;oCACzBD,OAAO;wCAAEE,WAAWf,mBAAmB,CAACvF,SAASxC;oCAAU;8CAE3D,cAAA,KAAClB;wCAA+BiB,QAAQI,eAAeJ;kDACrD,cAAA,KAAClB;4CACCkK,UAAU5C,YAAYjG,aAAaiG,YAAY7F;sDAE9C8B;;;;+BAVF+D;wBAgBX;;;;;IAMZ;AACF;AAEA,OAAO,MAAM6C,eAA4C9K,YACvDA,YACEA,YACEC,aAAaG,QAA2BkB,yBACxCT,iBACA,aAEFJ,uBACA,mBAEFD,eACA,UACA"}
1
+ {"version":3,"sources":["../../../../src/components/View/ViewInfinite.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { withContext } from '../../hoc/withContext';\nimport { withPlatform } from '../../hoc/withPlatform';\nimport { millisecondsInSecond } from '../../lib/date';\nimport { canUseDOM, type DOMProps, withDOM } from '../../lib/dom';\nimport { getNavId, type NavIdProps } from '../../lib/getNavId';\nimport { warnOnce } from '../../lib/warnOnce';\nimport type { HasPlatform, HTMLAttributesWithRootRef } from '../../types';\nimport { ScrollContext, type ScrollContextInterface } from '../AppRoot/ScrollContext';\nimport {\n ConfigProviderContext,\n type ConfigProviderContextInterface,\n} from '../ConfigProvider/ConfigProviderContext';\nimport { NavViewIdContext } from '../NavIdContext/NavIdContext';\nimport { NavTransitionProvider } from '../NavTransitionContext/NavTransitionContext';\nimport { NavTransitionDirectionProvider } from '../NavTransitionDirectionContext/NavTransitionDirectionContext';\nimport { SplitColContext, type SplitColContextProps } from '../SplitCol/SplitColContext';\nimport { type CustomTouchEvent, Touch } from '../Touch/Touch';\nimport {\n getSwipeBackPredicates,\n hasHorizontalScrollableElementWithScrolledToLeft,\n swipeBackExcluded,\n} from './utils';\nimport styles from './View.module.css';\n\nconst warn = warnOnce('ViewInfinite');\n\ntype TransitionEventHandler = (e?: TransitionEvent) => void;\n\nexport let scrollsCache = new Map<string, Map<string, Array<number | undefined>>>();\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nexport type TransitionParams = { from: string | null; to: string | null };\n\nexport interface ViewInfiniteProps\n extends HTMLAttributesWithRootRef<HTMLElement>,\n HasPlatform,\n NavIdProps {\n /**\n * `id` активной панели.\n */\n activePanel: string;\n /**\n * Обработчик, который вызывается при завершении анимации смены активной панели.\n */\n onTransition?: ((params: TransitionParams & { isBack: boolean }) => void) | undefined;\n /**\n * Обработчик свайпа назад.\n */\n onSwipeBack?: (() => void) | undefined;\n /**\n * Обработчик начала анимации свайпа назад.\n */\n onSwipeBackStart?: ((activePanel: string | null) => void | 'prevent') | undefined;\n /**\n * Обработчик завершения анимации отмененного пользователем свайпа.\n */\n onSwipeBackCancel?: (() => void) | undefined;\n /**\n * Массив из id панелей в порядке открытия.\n */\n history?: string[] | undefined;\n /**\n * Функция проверки перехода назад.\n */\n isBackCheck?: ((params: TransitionParams) => boolean) | undefined;\n /**\n * @ignore\n */\n splitCol?: SplitColContextProps | undefined;\n /**\n * @ignore\n */\n configProvider?: ConfigProviderContextInterface | undefined;\n /**\n * @ignore\n */\n scroll?: ScrollContextInterface | undefined;\n}\n\n/* eslint-disable jsdoc/require-jsdoc */\nexport interface ViewInfiniteState {\n animated: boolean;\n\n visiblePanels: Array<string | null>;\n activePanel: string | null;\n isBack?: boolean | undefined;\n prevPanel: string | null;\n nextPanel: string | null;\n\n swipingBack?: boolean | undefined;\n swipeBackStartX: number;\n swipeBackShift: number;\n swipeBackNextPanel: string | null;\n swipeBackPrevPanel: string | null;\n swipeBackResult: 'success' | 'fail' | null;\n\n browserSwipe: boolean;\n}\n/* eslint-enable jsdoc/require-jsdoc */\n\nclass ViewInfiniteComponent extends React.Component<\n ViewInfiniteProps & DOMProps,\n ViewInfiniteState\n> {\n constructor(props: ViewInfiniteProps) {\n super(props);\n\n this.state = {\n animated: false,\n\n visiblePanels: [props.activePanel],\n activePanel: props.activePanel,\n isBack: undefined,\n prevPanel: null,\n nextPanel: null,\n\n swipingBack: undefined,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n swipeBackNextPanel: null,\n swipeBackPrevPanel: null,\n swipeBackResult: null,\n\n browserSwipe: false,\n };\n }\n\n static defaultProps: Partial<ViewInfiniteProps> = {\n history: [],\n };\n\n private swipeBackPrevented = false;\n private readonly scrolls: Map<string, Array<number | undefined>> =\n scrollsCache.get(getNavId(this.props, warn) as string) || new Map();\n private transitionFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n private readonly animationFinishTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n get window() {\n return this.props.window;\n }\n\n get panels() {\n return React.Children.toArray(this.props.children) as Array<React.ReactElement<NavIdProps>>;\n }\n\n panelNodes: { [id: string]: HTMLDivElement | null } = {};\n\n componentWillUnmount() {\n const id = getNavId(this.props);\n if (id) {\n scrollsCache.set(id, this.scrolls);\n }\n if (this.animationFinishTimeout) {\n clearTimeout(this.animationFinishTimeout);\n }\n }\n\n componentDidUpdate(prevProps: ViewInfiniteProps, prevState: ViewInfiniteState) {\n // Нужен переход\n if (\n prevProps.activePanel !== this.props.activePanel &&\n !prevState.swipingBack &&\n !prevState.browserSwipe\n ) {\n let isBack = false;\n\n if (this.props.isBackCheck) {\n isBack = this.props.isBackCheck({\n from: prevProps.activePanel,\n to: this.props.activePanel,\n });\n } else {\n const firstLayerId = this.panels\n .map((panel) => getNavId(panel.props, warn))\n .find((id) => id === prevProps.activePanel || id === this.props.activePanel);\n isBack = firstLayerId === this.props.activePanel;\n }\n\n this.blurActiveElement();\n\n const prevScrolls = this.scrolls.get(prevProps.activePanel) || [];\n this.scrolls.set(prevProps.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll({ compensateKeyboardHeight: false }).y,\n ]);\n\n if (this.shouldDisableTransitionMotion()) {\n this.flushTransition(prevProps.activePanel, isBack);\n } else {\n this.setState({\n visiblePanels: [prevProps.activePanel, this.props.activePanel],\n prevPanel: prevProps.activePanel,\n nextPanel: this.props.activePanel,\n activePanel: null,\n animated: true,\n isBack,\n });\n }\n }\n\n // Закончилась анимация свайпа назад\n if (prevProps.activePanel !== this.props.activePanel && prevState.swipingBack) {\n const nextPanel = this.state.swipeBackNextPanel;\n const prevPanel = this.state.swipeBackPrevPanel;\n let scrollPosition: undefined | number = undefined;\n\n if (prevPanel !== null) {\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n this.scrolls.set(prevPanel, prevPanelScrolls);\n }\n if (nextPanel !== null) {\n const newPanelScrolls = [...(this.scrolls.get(nextPanel) || [])];\n scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(nextPanel, newPanelScrolls);\n }\n\n this.setState(\n {\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n activePanel: nextPanel,\n visiblePanels: [nextPanel],\n },\n () => {\n this.props.scroll?.scrollTo(0, scrollPosition);\n prevProps.onTransition &&\n prevProps.onTransition({\n isBack: true,\n from: prevPanel,\n to: nextPanel,\n });\n },\n );\n }\n\n // Началась анимация завершения свайпа назад.\n if (!prevState.swipeBackResult && this.state.swipeBackResult) {\n this.waitTransitionFinish(\n this.pickPanel(this.state.swipeBackNextPanel),\n this.swipingBackTransitionEndHandler,\n );\n }\n\n // Если свайп назад отменился (когда пользователь недостаточно сильно свайпнул)\n if (\n prevState.swipeBackResult === 'fail' &&\n !this.state.swipeBackResult &&\n this.state.activePanel !== null\n ) {\n const newPanelScrolls = [...(this.scrolls.get(this.state.activePanel) || [])];\n const scrollPosition = newPanelScrolls.pop();\n this.scrolls.set(this.state.activePanel, newPanelScrolls);\n\n this.props.scroll?.scrollTo(0, scrollPosition);\n }\n\n // Закончился Safari свайп\n if (prevProps.activePanel !== this.props.activePanel && this.state.browserSwipe) {\n this.setState({\n browserSwipe: false,\n nextPanel: null,\n prevPanel: null,\n animated: false,\n visiblePanels: [this.props.activePanel],\n activePanel: this.props.activePanel,\n });\n }\n }\n\n shouldDisableTransitionMotion(): boolean {\n return (\n this.props.configProvider?.transitionMotionEnabled === false ||\n !this.props.splitCol?.animate ||\n this.props.platform === 'vkcom'\n );\n }\n\n private transitionDisposer = noop;\n\n private disposeTransition() {\n this.transitionDisposer();\n this.transitionDisposer = noop;\n }\n\n waitTransitionFinish(\n elem: HTMLElement | null | undefined,\n eventHandler: TransitionEventHandler,\n ): void {\n if (this.shouldDisableTransitionMotion()) {\n this.disposeTransition();\n this.transitionFinishTimeout = setTimeout(eventHandler);\n } else if (elem) {\n this.disposeTransition();\n elem.addEventListener('transitionend', eventHandler);\n this.transitionDisposer = () => {\n elem.removeEventListener('transitionend', eventHandler);\n };\n } else {\n if (this.transitionFinishTimeout) {\n clearTimeout(this.transitionFinishTimeout);\n }\n this.transitionFinishTimeout = setTimeout(\n eventHandler,\n this.props.platform === 'android' || this.props.platform === 'vkcom' ? 300 : 600,\n );\n }\n }\n\n blurActiveElement(): void {\n if (typeof this.window !== 'undefined' && this.document?.activeElement) {\n (this.document.activeElement as HTMLElement).blur();\n }\n }\n\n pickPanel(id: string | null) {\n if (id === null) {\n return undefined;\n }\n return this.panelNodes[id];\n }\n\n flushTransition(prevPanel: string, isBack: boolean) {\n const activePanel = this.props.activePanel;\n\n const prevPanelScrolls = [...(this.scrolls.get(prevPanel) || [])].slice(0, -1);\n const newPanelScrolls = [...(this.scrolls.get(activePanel) || [])];\n const scrollPosition = isBack ? newPanelScrolls.pop() : 0;\n if (isBack) {\n this.scrolls.set(prevPanel, prevPanelScrolls);\n this.scrolls.set(activePanel, newPanelScrolls);\n }\n\n this.setState(\n {\n prevPanel: null,\n nextPanel: null,\n visiblePanels: [activePanel],\n activePanel: activePanel,\n animated: false,\n isBack,\n },\n () => {\n this.props.scroll?.scrollTo(0, isBack ? scrollPosition : 0);\n this.props.onTransition &&\n this.props.onTransition({ isBack, from: prevPanel, to: activePanel });\n },\n );\n }\n\n transitionEndHandler: React.AnimationEventHandler<HTMLDivElement> = (e): void => {\n if (e.target !== e.currentTarget) {\n return;\n }\n\n if (this.state.prevPanel !== null) {\n this.flushTransition(this.state.prevPanel, Boolean(this.state.isBack));\n }\n };\n\n swipingBackTransitionEndHandler = (e?: TransitionEvent): void => {\n // indexOf because of vendor prefixes in old browsers\n if (\n !e ||\n (e.propertyName.includes('transform') &&\n e.target === this.pickPanel(this.state.swipeBackNextPanel))\n ) {\n switch (this.state.swipeBackResult) {\n case 'fail':\n this.onSwipeBackCancel();\n break;\n case 'success':\n this.onSwipeBackSuccess();\n }\n }\n };\n\n onSwipeBackSuccess(): void {\n this.props.onSwipeBack && this.props.onSwipeBack();\n }\n\n onSwipeBackCancel(): void {\n this.props.onSwipeBackCancel && this.props.onSwipeBackCancel();\n this.setState({\n swipeBackPrevPanel: null,\n swipeBackNextPanel: null,\n swipingBack: false,\n swipeBackResult: null,\n swipeBackStartX: 0,\n swipeBackShift: 0,\n });\n }\n\n handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext = (event: CustomTouchEvent) => {\n if (this.state.browserSwipe) {\n return;\n }\n const { swipeBackTriggered, viewportStartEdgeTouched, viewportEndEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if ((viewportStartEdgeTouched || viewportEndEdgeTouched) && swipeBackTriggered) {\n this.setState({ browserSwipe: true });\n }\n };\n\n handleTouchMoveXForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n if (this.swipeBackPrevented || swipeBackExcluded(event)) {\n return;\n }\n\n const { swipedToOpposite, swipeBackTriggered, viewportStartEdgeTouched } =\n getSwipeBackPredicates(event.startX, event.shiftX, this.window!.innerWidth);\n\n if (this.state.animated && swipeBackTriggered) {\n return;\n }\n\n if (!this.state.swipingBack && this.props.history && this.props.history.length > 1) {\n if (swipedToOpposite) {\n this.swipeBackPrevented = true;\n return;\n }\n\n if (!swipeBackTriggered) {\n return;\n }\n\n if (\n !viewportStartEdgeTouched &&\n hasHorizontalScrollableElementWithScrolledToLeft(event.originalEvent.target as HTMLElement)\n ) {\n this.swipeBackPrevented = true;\n return;\n }\n // Начался свайп назад\n if (this.props.onSwipeBackStart) {\n const payload = this.props.onSwipeBackStart(this.state.activePanel);\n if (payload === 'prevent') {\n this.swipeBackPrevented = true;\n return;\n }\n }\n\n if (this.state.activePanel !== null) {\n // Note: вызываем закрытие клавиатуры. В iOS это нативное поведение при свайпе.\n this.blurActiveElement();\n const prevScrolls = this.scrolls.get(this.state.activePanel) || [];\n this.scrolls.set(this.state.activePanel, [\n ...prevScrolls,\n this.props.scroll?.getScroll().y,\n ]);\n }\n\n this.setState({\n swipingBack: true,\n swipeBackStartX: event.startX,\n swipeBackPrevPanel: this.state.activePanel,\n swipeBackNextPanel: this.props.history.slice(-2)[0],\n });\n }\n\n if (this.state.swipingBack) {\n if (event.shiftX < 0) {\n this.setState({ swipeBackShift: 0 });\n } else if (event.shiftX > this.window!.innerWidth - this.state.swipeBackStartX) {\n this.setState({ swipeBackShift: this.window!.innerWidth });\n } else {\n this.setState({ swipeBackShift: event.shiftX });\n }\n }\n };\n\n handleTouchEndForIOSSwipeBackSimulation = (event: CustomTouchEvent) => {\n this.swipeBackPrevented = false;\n\n if (this.state.swipingBack && this.window) {\n const speed = (this.state.swipeBackShift / event.duration) * millisecondsInSecond;\n if (this.state.swipeBackShift === 0) {\n this.onSwipeBackCancel();\n } else if (this.state.swipeBackShift >= this.window.innerWidth) {\n this.onSwipeBackSuccess();\n } else if (speed > 250 || this.state.swipeBackShift >= this.window.innerWidth / 2) {\n this.setState({ swipeBackResult: 'success' });\n } else {\n this.setState({ swipeBackResult: 'fail' });\n }\n }\n };\n\n calcPanelSwipeStyles(panelId: string | undefined): React.CSSProperties {\n if (!canUseDOM || !this.window) {\n return {};\n }\n\n const isPrev = panelId === this.state.swipeBackPrevPanel;\n const isNext = panelId === this.state.swipeBackNextPanel;\n\n if ((!isPrev && !isNext) || this.state.swipeBackResult) {\n return {};\n }\n\n let prevPanelTranslate = `${this.state.swipeBackShift}px`;\n let nextPanelTranslate = `${\n -50 + (this.state.swipeBackShift * 100) / this.window.innerWidth / 2\n }%`;\n let prevPanelShadow =\n (0.3 * (this.window.innerWidth - this.state.swipeBackShift)) / this.window.innerWidth;\n\n if (this.state.swipeBackResult) {\n return isPrev ? { boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})` } : {};\n }\n\n if (isNext) {\n return {\n transform: `translate3d(${nextPanelTranslate}, 0, 0)`,\n };\n }\n if (isPrev) {\n return {\n transform: `translate3d(${prevPanelTranslate}, 0, 0)`,\n boxShadow: `-2px 0 12px rgba(0, 0, 0, ${prevPanelShadow})`,\n };\n }\n\n return {};\n }\n\n render() {\n const {\n platform,\n activePanel: _1,\n splitCol,\n configProvider,\n history,\n id,\n nav,\n onTransition,\n onSwipeBack,\n onSwipeBackStart,\n onSwipeBackCancel,\n window,\n document,\n scroll,\n isBackCheck,\n className,\n ...restProps\n } = this.props;\n const {\n prevPanel,\n nextPanel,\n activePanel,\n isBack,\n animated,\n swipeBackPrevPanel,\n swipeBackNextPanel,\n swipeBackResult,\n swipingBack,\n } = this.state;\n\n const panels = this.panels\n .filter((panel) => {\n const panelId = getNavId(panel.props, warn);\n\n return (\n (panelId !== undefined && this.state.visiblePanels.includes(panelId)) ||\n panelId === swipeBackPrevPanel ||\n panelId === swipeBackNextPanel\n );\n })\n .sort((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrevPanel = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const isNextPanel = panelId === nextPanel || panelId === swipeBackNextPanel;\n\n if (isNextPanel) {\n return swipingBack || this.state.isBack ? -1 : 1;\n }\n\n if (isPrevPanel) {\n return swipingBack || this.state.isBack ? 1 : -1;\n }\n\n return 0;\n });\n\n const disableAnimation = this.shouldDisableTransitionMotion();\n const iOSSwipeBackSimulationEnabled =\n !disableAnimation && platform === 'ios' && configProvider?.isWebView && Boolean(onSwipeBack);\n\n return (\n <NavViewIdContext.Provider value={id || nav}>\n <Touch\n Component=\"section\"\n {...restProps}\n className={classNames(\n styles.host,\n platform === 'ios' && classNames(styles.ios, 'vkuiInternalView--ios'),\n !disableAnimation && this.state.animated && styles.animated,\n !disableAnimation && this.state.swipingBack && styles.swipingBack,\n disableAnimation && styles.noMotion,\n className,\n )}\n onMoveX={\n iOSSwipeBackSimulationEnabled\n ? this.handleTouchMoveXForIOSSwipeBackSimulation\n : platform === 'ios'\n ? this.handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext\n : undefined\n }\n onEnd={\n iOSSwipeBackSimulationEnabled ? this.handleTouchEndForIOSSwipeBackSimulation : undefined\n }\n >\n <div className={styles.panels}>\n {panels.map((panel) => {\n const panelId = getNavId(panel.props, warn);\n const isPrev = panelId === prevPanel || panelId === swipeBackPrevPanel;\n const compensateScroll =\n isPrev || panelId === swipeBackNextPanel || (panelId === nextPanel && isBack);\n const isTransitionTarget = animated && panelId === (isBack ? prevPanel : nextPanel);\n const scrollList = (panelId && this.scrolls.get(panelId)) || [];\n const scroll = scrollList[scrollList.length - 1] || 0;\n\n return (\n <div\n className={classNames(\n styles.panel,\n panelId === activePanel && styles.panelActive,\n panelId === prevPanel && styles.panelPrev,\n panelId === nextPanel && styles.panelNext,\n panelId === swipeBackPrevPanel && styles.panelSwipeBackPrev,\n panelId === swipeBackNextPanel && styles.panelSwipeBackNext,\n swipeBackResult === 'success' && styles.panelSwipeBackSuccess,\n swipeBackResult === 'fail' && styles.panelSwipeBackFailed,\n )}\n onAnimationEnd={isTransitionTarget ? this.transitionEndHandler : undefined}\n ref={(el) => {\n panelId !== undefined && (this.panelNodes[panelId] = el);\n }}\n style={this.calcPanelSwipeStyles(panelId)}\n key={panelId}\n >\n <div\n className={styles.panelIn}\n style={{ marginTop: compensateScroll ? -scroll : undefined }}\n >\n <NavTransitionDirectionProvider isBack={swipingBack || isBack}>\n <NavTransitionProvider\n entering={panelId === nextPanel || panelId === swipeBackNextPanel}\n animating={swipingBack || animated}\n >\n {panel}\n </NavTransitionProvider>\n </NavTransitionDirectionProvider>\n </div>\n </div>\n );\n })}\n </div>\n </Touch>\n </NavViewIdContext.Provider>\n );\n }\n}\n\nexport const ViewInfinite: React.FC<ViewInfiniteProps> = withContext(\n withContext(\n withContext(\n withPlatform(withDOM<ViewInfiniteProps>(ViewInfiniteComponent)),\n SplitColContext,\n 'splitCol',\n ),\n ConfigProviderContext,\n 'configProvider',\n ),\n ScrollContext,\n 'scroll',\n);\n"],"names":["React","classNames","noop","withContext","withPlatform","millisecondsInSecond","canUseDOM","withDOM","getNavId","warnOnce","ScrollContext","ConfigProviderContext","NavViewIdContext","NavTransitionProvider","NavTransitionDirectionProvider","SplitColContext","Touch","getSwipeBackPredicates","hasHorizontalScrollableElementWithScrolledToLeft","swipeBackExcluded","styles","warn","scrollsCache","Map","ViewInfiniteComponent","Component","props","state","animated","visiblePanels","activePanel","isBack","undefined","prevPanel","nextPanel","swipingBack","swipeBackStartX","swipeBackShift","swipeBackNextPanel","swipeBackPrevPanel","swipeBackResult","browserSwipe","defaultProps","history","swipeBackPrevented","scrolls","get","transitionFinishTimeout","animationFinishTimeout","document","window","panels","Children","toArray","children","panelNodes","componentWillUnmount","id","set","clearTimeout","componentDidUpdate","prevProps","prevState","isBackCheck","from","to","firstLayerId","map","panel","find","blurActiveElement","prevScrolls","scroll","getScroll","compensateKeyboardHeight","y","shouldDisableTransitionMotion","flushTransition","setState","scrollPosition","prevPanelScrolls","slice","newPanelScrolls","pop","scrollTo","onTransition","waitTransitionFinish","pickPanel","swipingBackTransitionEndHandler","configProvider","transitionMotionEnabled","splitCol","animate","platform","transitionDisposer","disposeTransition","elem","eventHandler","setTimeout","addEventListener","removeEventListener","activeElement","blur","transitionEndHandler","e","target","currentTarget","Boolean","propertyName","includes","onSwipeBackCancel","onSwipeBackSuccess","onSwipeBack","handleTouchMoveXForNativeIOSSwipeBackOrSwipeNext","event","swipeBackTriggered","viewportStartEdgeTouched","viewportEndEdgeTouched","startX","shiftX","innerWidth","handleTouchMoveXForIOSSwipeBackSimulation","swipedToOpposite","length","originalEvent","onSwipeBackStart","payload","handleTouchEndForIOSSwipeBackSimulation","speed","duration","calcPanelSwipeStyles","panelId","isPrev","isNext","prevPanelTranslate","nextPanelTranslate","prevPanelShadow","boxShadow","transform","render","_1","nav","className","restProps","filter","sort","isPrevPanel","isNextPanel","disableAnimation","iOSSwipeBackSimulationEnabled","isWebView","Provider","value","host","ios","noMotion","onMoveX","onEnd","div","compensateScroll","isTransitionTarget","scrollList","panelActive","panelPrev","panelNext","panelSwipeBackPrev","panelSwipeBackNext","panelSwipeBackSuccess","panelSwipeBackFailed","onAnimationEnd","ref","el","style","panelIn","marginTop","entering","animating","ViewInfinite"],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  import * as React from "react";
2
2
  import { debounce, noop } from "@vkontakte/vkjs";
3
3
  import { getWindow, isHTMLElement } from "@vkontakte/vkui-floating-ui/utils/dom";
4
+ import { useNavTransition } from "../../../components/NavTransitionContext/NavTransitionContext.js";
4
5
  import { useCustomEnsuredControl } from "../../../hooks/useEnsuredControl.js";
5
6
  import { useGlobalOnClickOutside } from "../../../hooks/useGlobalOnClickOutside.js";
6
7
  import { useStableCallback } from "../../../hooks/useStableCallback.js";
7
8
  import { contains, getActiveElementByAnotherElement } from "../../dom.js";
8
9
  import { useIsomorphicLayoutEffect } from "../../useIsomorphicLayoutEffect.js";
9
- import { LockFloatingPositionContext } from "../LockFloatingPosition/LockFloatingPosition.js";
10
10
  import { autoUpdateFloatingElement, useFloating } from "../adapters.js";
11
11
  import { convertFloatingDataToReactCSSProperties } from "../functions.js";
12
12
  import { DEFAULT_TRIGGER } from "./constants.js";
@@ -26,6 +26,7 @@ shown: shownProp, onShownChange: onShownChangeProp, onShownChanged: onShownChang
26
26
  } : undefined, [
27
27
  shownProp
28
28
  ]);
29
+ const { entering, animating } = useNavTransition();
29
30
  const [shownLocalState, setShownLocalState] = useCustomEnsuredControl({
30
31
  value: memoizedValue,
31
32
  disabled,
@@ -48,7 +49,6 @@ shown: shownProp, onShownChange: onShownChangeProp, onShownChanged: onShownChang
48
49
  const handleCloseOnReferenceClickOutsideDisabled = disabled || disableCloseOnClickOutside || willBeHide || !shownLocalState.shown;
49
50
  const handleCloseOnFloatingClickOutsideDisabled = disableInteractive || handleCloseOnReferenceClickOutsideDisabled;
50
51
  const { triggerOnFocus, triggerOnClick, triggerOnHover } = useResolveTriggerType(trigger);
51
- const isLock = React.useContext(LockFloatingPositionContext);
52
52
  // Библиотека `floating-ui`
53
53
  const { placement, x, y, strategy, refs, middlewareData } = useFloating({
54
54
  strategy: strategyProp,
@@ -56,7 +56,7 @@ shown: shownProp, onShownChange: onShownChangeProp, onShownChanged: onShownChang
56
56
  ...middlewares !== undefined ? {
57
57
  middleware: middlewares
58
58
  } : {},
59
- ...!isLock && {
59
+ ...!animating && {
60
60
  whileElementsMounted
61
61
  }
62
62
  });
@@ -292,7 +292,7 @@ shown: shownProp, onShownChange: onShownChangeProp, onShownChanged: onShownChang
292
292
  }
293
293
  return {
294
294
  placement,
295
- shown: shownFinalState,
295
+ shown: shownFinalState && !entering,
296
296
  willBeHide,
297
297
  refs,
298
298
  referenceProps,