react-native-screen-transitions 3.4.0-alpha.0 → 3.4.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -1046
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js +69 -2
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/commonjs/component-stack/navigators/create-component-stack-navigator.js +9 -0
- package/lib/commonjs/component-stack/navigators/create-component-stack-navigator.js.map +1 -1
- package/lib/commonjs/shared/animation/snap-to.js +5 -1
- package/lib/commonjs/shared/animation/snap-to.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js +195 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-auto-source-measurement.js +7 -14
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-auto-source-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js +19 -18
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.js +54 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-group-active-measurement.js +40 -8
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-group-active-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.js +72 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-initial-layout-handler.js +16 -7
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-initial-layout-handler.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.js +7 -4
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js +14 -15
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.js +27 -9
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/index.js +22 -8
- package/lib/commonjs/shared/components/create-boundary-component/index.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/utils/build-boundary-match-key.js +5 -10
- package/lib/commonjs/shared/components/create-boundary-component/utils/build-boundary-match-key.js.map +1 -1
- package/lib/commonjs/shared/components/create-transition-aware-component.js +3 -2
- package/lib/commonjs/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/commonjs/shared/components/native-screen-container.js +12 -6
- package/lib/commonjs/shared/components/native-screen-container.js.map +1 -1
- package/lib/commonjs/shared/components/native-screen.js +35 -8
- package/lib/commonjs/shared/components/native-screen.js.map +1 -1
- package/lib/commonjs/shared/components/overlay/helpers/get-active-overlay.js +2 -2
- package/lib/commonjs/shared/components/overlay/helpers/get-active-overlay.js.map +1 -1
- package/lib/commonjs/shared/components/overlay/index.js +1 -3
- package/lib/commonjs/shared/components/overlay/index.js.map +1 -1
- package/lib/commonjs/shared/components/overlay/variations/overlay-host.js +2 -16
- package/lib/commonjs/shared/components/overlay/variations/overlay-host.js.map +1 -1
- package/lib/commonjs/shared/components/scene-view.js +2 -4
- package/lib/commonjs/shared/components/scene-view.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/hooks/use-content-layout.js +60 -0
- package/lib/commonjs/shared/components/screen-container/hooks/use-content-layout.js.map +1 -0
- package/lib/commonjs/shared/components/screen-container/layers/backdrop.js +9 -6
- package/lib/commonjs/shared/components/screen-container/layers/backdrop.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/content.js +16 -56
- package/lib/commonjs/shared/components/screen-container/layers/content.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/maybe-masked-navigation-container.js +86 -0
- package/lib/commonjs/shared/components/screen-container/layers/maybe-masked-navigation-container.js.map +1 -0
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-close-transition/index.js.map +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-open-transition.js +17 -4
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-open-transition.js.map +1 -1
- package/lib/commonjs/shared/constants.js +6 -2
- package/lib/commonjs/shared/constants.js.map +1 -1
- package/lib/commonjs/shared/hooks/gestures/resolve-screen-gesture-target.js +49 -0
- package/lib/commonjs/shared/hooks/gestures/resolve-screen-gesture-target.js.map +1 -0
- package/lib/commonjs/shared/hooks/gestures/types.js +2 -0
- package/lib/commonjs/shared/hooks/gestures/types.js.map +1 -0
- package/lib/commonjs/shared/hooks/gestures/use-screen-gesture.js +7 -3
- package/lib/commonjs/shared/hooks/gestures/use-screen-gesture.js.map +1 -1
- package/lib/commonjs/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/commonjs/shared/index.js +15 -3
- package/lib/commonjs/shared/index.js.map +1 -1
- package/lib/commonjs/shared/providers/gestures/handlers/use-handlers.js +61 -25
- package/lib/commonjs/shared/providers/gestures/handlers/use-handlers.js.map +1 -1
- package/lib/commonjs/shared/providers/gestures/helpers/gesture-activation.js +11 -6
- package/lib/commonjs/shared/providers/gestures/helpers/gesture-activation.js.map +1 -1
- package/lib/commonjs/shared/providers/gestures/helpers/gesture-snap-points.js +44 -0
- package/lib/commonjs/shared/providers/gestures/helpers/gesture-snap-points.js.map +1 -0
- package/lib/commonjs/shared/providers/layout-anchor.provider.js +4 -6
- package/lib/commonjs/shared/providers/layout-anchor.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/animation.provider.js +31 -17
- package/lib/commonjs/shared/providers/screen/animation/animation.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/derivations.js +1 -9
- package/lib/commonjs/shared/providers/screen/animation/helpers/derivations.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js +25 -13
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/resolve-screen-animation-target.js +33 -0
- package/lib/commonjs/shared/providers/screen/animation/helpers/resolve-screen-animation-target.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/animation/types.js +2 -0
- package/lib/commonjs/shared/providers/screen/animation/types.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/animation/use-screen-animation.js +9 -3
- package/lib/commonjs/shared/providers/screen/animation/use-screen-animation.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/core.provider.js +14 -21
- package/lib/commonjs/shared/providers/stack/core.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/direct.provider.js +1 -1
- package/lib/commonjs/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-processed-routes.js +1 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-processed-routes.js.map +1 -1
- package/lib/commonjs/shared/stores/animation.store.js +10 -2
- package/lib/commonjs/shared/stores/animation.store.js.map +1 -1
- package/lib/commonjs/shared/stores/bounds/internals/presence.js.map +1 -1
- package/lib/commonjs/shared/stores/bounds/internals/resolver.js +7 -0
- package/lib/commonjs/shared/stores/bounds/internals/resolver.js.map +1 -1
- package/lib/commonjs/shared/utils/animation/animate-to-progress.js +6 -0
- package/lib/commonjs/shared/utils/animation/animate-to-progress.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/compute-bounds-styles.js +33 -9
- package/lib/commonjs/shared/utils/bounds/helpers/compute-bounds-styles.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/geometry.js +3 -2
- package/lib/commonjs/shared/utils/bounds/helpers/geometry.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/interpolators.js +3 -2
- package/lib/commonjs/shared/utils/bounds/helpers/interpolators.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/link-accessor.js +2 -2
- package/lib/commonjs/shared/utils/bounds/helpers/link-accessor.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/resolve-bound-tag.js +4 -8
- package/lib/commonjs/shared/utils/bounds/helpers/resolve-bound-tag.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/style-composers.js +4 -3
- package/lib/commonjs/shared/utils/bounds/helpers/style-composers.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/index.js +13 -3
- package/lib/commonjs/shared/utils/bounds/index.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/types/frame-props.js +6 -0
- package/lib/commonjs/shared/utils/bounds/types/frame-props.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/zoom/accessor.js +54 -0
- package/lib/commonjs/shared/utils/bounds/zoom/accessor.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/zoom/build.js +548 -0
- package/lib/commonjs/shared/utils/bounds/zoom/build.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/zoom/config.js +118 -0
- package/lib/commonjs/shared/utils/bounds/zoom/config.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/zoom/index.js +20 -0
- package/lib/commonjs/shared/utils/bounds/zoom/index.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/zoom/types.js.map +1 -0
- package/lib/commonjs/shared/utils/gesture/validate-snap-points.js +11 -5
- package/lib/commonjs/shared/utils/gesture/validate-snap-points.js.map +1 -1
- package/lib/commonjs/shared/utils/overlay/visibility.js +2 -9
- package/lib/commonjs/shared/utils/overlay/visibility.js.map +1 -1
- package/lib/commonjs/shared/utils/resolve-screen-transition-options.js +25 -0
- package/lib/commonjs/shared/utils/resolve-screen-transition-options.js.map +1 -0
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js +69 -3
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/module/component-stack/navigators/create-component-stack-navigator.js +9 -0
- package/lib/module/component-stack/navigators/create-component-stack-navigator.js.map +1 -1
- package/lib/module/shared/animation/snap-to.js +5 -1
- package/lib/module/shared/animation/snap-to.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js +182 -0
- package/lib/module/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-auto-source-measurement.js +7 -14
- package/lib/module/shared/components/create-boundary-component/hooks/use-auto-source-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js +19 -18
- package/lib/module/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.js +49 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-group-active-measurement.js +41 -8
- package/lib/module/shared/components/create-boundary-component/hooks/use-group-active-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.js +67 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-initial-layout-handler.js +16 -7
- package/lib/module/shared/components/create-boundary-component/hooks/use-initial-layout-handler.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.js +7 -4
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js +14 -15
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.js +27 -9
- package/lib/module/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/index.js +22 -8
- package/lib/module/shared/components/create-boundary-component/index.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/utils/build-boundary-match-key.js +5 -10
- package/lib/module/shared/components/create-boundary-component/utils/build-boundary-match-key.js.map +1 -1
- package/lib/module/shared/components/create-transition-aware-component.js +3 -2
- package/lib/module/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/module/shared/components/native-screen-container.js +12 -6
- package/lib/module/shared/components/native-screen-container.js.map +1 -1
- package/lib/module/shared/components/native-screen.js +35 -8
- package/lib/module/shared/components/native-screen.js.map +1 -1
- package/lib/module/shared/components/overlay/helpers/get-active-overlay.js +3 -3
- package/lib/module/shared/components/overlay/helpers/get-active-overlay.js.map +1 -1
- package/lib/module/shared/components/overlay/index.js +1 -3
- package/lib/module/shared/components/overlay/index.js.map +1 -1
- package/lib/module/shared/components/overlay/variations/overlay-host.js +3 -17
- package/lib/module/shared/components/overlay/variations/overlay-host.js.map +1 -1
- package/lib/module/shared/components/scene-view.js +3 -5
- package/lib/module/shared/components/scene-view.js.map +1 -1
- package/lib/module/shared/components/screen-container/hooks/use-content-layout.js +56 -0
- package/lib/module/shared/components/screen-container/hooks/use-content-layout.js.map +1 -0
- package/lib/module/shared/components/screen-container/layers/backdrop.js +9 -6
- package/lib/module/shared/components/screen-container/layers/backdrop.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/content.js +18 -58
- package/lib/module/shared/components/screen-container/layers/content.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/maybe-masked-navigation-container.js +81 -0
- package/lib/module/shared/components/screen-container/layers/maybe-masked-navigation-container.js.map +1 -0
- package/lib/module/shared/components/screen-lifecycle/hooks/use-close-transition/index.js.map +1 -1
- package/lib/module/shared/components/screen-lifecycle/hooks/use-open-transition.js +17 -4
- package/lib/module/shared/components/screen-lifecycle/hooks/use-open-transition.js.map +1 -1
- package/lib/module/shared/constants.js +6 -2
- package/lib/module/shared/constants.js.map +1 -1
- package/lib/module/shared/hooks/gestures/resolve-screen-gesture-target.js +45 -0
- package/lib/module/shared/hooks/gestures/resolve-screen-gesture-target.js.map +1 -0
- package/lib/module/shared/hooks/gestures/types.js +2 -0
- package/lib/module/shared/hooks/gestures/types.js.map +1 -0
- package/lib/module/shared/hooks/gestures/use-screen-gesture.js +7 -4
- package/lib/module/shared/hooks/gestures/use-screen-gesture.js.map +1 -1
- package/lib/module/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/module/shared/index.js +1 -2
- package/lib/module/shared/index.js.map +1 -1
- package/lib/module/shared/providers/gestures/handlers/use-handlers.js +61 -25
- package/lib/module/shared/providers/gestures/handlers/use-handlers.js.map +1 -1
- package/lib/module/shared/providers/gestures/helpers/gesture-activation.js +11 -6
- package/lib/module/shared/providers/gestures/helpers/gesture-activation.js.map +1 -1
- package/lib/module/shared/providers/gestures/helpers/gesture-snap-points.js +38 -0
- package/lib/module/shared/providers/gestures/helpers/gesture-snap-points.js.map +1 -0
- package/lib/module/shared/providers/layout-anchor.provider.js +4 -6
- package/lib/module/shared/providers/layout-anchor.provider.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/animation.provider.js +30 -15
- package/lib/module/shared/providers/screen/animation/animation.provider.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/derivations.js +1 -9
- package/lib/module/shared/providers/screen/animation/helpers/derivations.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js +25 -13
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/resolve-screen-animation-target.js +29 -0
- package/lib/module/shared/providers/screen/animation/helpers/resolve-screen-animation-target.js.map +1 -0
- package/lib/module/shared/providers/screen/animation/index.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/types.js +2 -0
- package/lib/module/shared/providers/screen/animation/types.js.map +1 -0
- package/lib/module/shared/providers/screen/animation/use-screen-animation.js +9 -3
- package/lib/module/shared/providers/screen/animation/use-screen-animation.js.map +1 -1
- package/lib/module/shared/providers/stack/core.provider.js +14 -21
- package/lib/module/shared/providers/stack/core.provider.js.map +1 -1
- package/lib/module/shared/providers/stack/direct.provider.js +2 -2
- package/lib/module/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/module/shared/providers/stack/helpers/use-processed-routes.js +2 -2
- package/lib/module/shared/providers/stack/helpers/use-processed-routes.js.map +1 -1
- package/lib/module/shared/stores/animation.store.js +10 -2
- package/lib/module/shared/stores/animation.store.js.map +1 -1
- package/lib/module/shared/stores/bounds/internals/presence.js.map +1 -1
- package/lib/module/shared/stores/bounds/internals/resolver.js +7 -0
- package/lib/module/shared/stores/bounds/internals/resolver.js.map +1 -1
- package/lib/module/shared/utils/animation/animate-to-progress.js +6 -0
- package/lib/module/shared/utils/animation/animate-to-progress.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/compute-bounds-styles.js +33 -9
- package/lib/module/shared/utils/bounds/helpers/compute-bounds-styles.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/geometry.js +3 -2
- package/lib/module/shared/utils/bounds/helpers/geometry.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/interpolators.js +3 -2
- package/lib/module/shared/utils/bounds/helpers/interpolators.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/link-accessor.js +2 -2
- package/lib/module/shared/utils/bounds/helpers/link-accessor.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/resolve-bound-tag.js +4 -8
- package/lib/module/shared/utils/bounds/helpers/resolve-bound-tag.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/style-composers.js +4 -3
- package/lib/module/shared/utils/bounds/helpers/style-composers.js.map +1 -1
- package/lib/module/shared/utils/bounds/index.js +13 -3
- package/lib/module/shared/utils/bounds/index.js.map +1 -1
- package/lib/module/shared/utils/bounds/types/frame-props.js +4 -0
- package/lib/module/shared/utils/bounds/types/frame-props.js.map +1 -0
- package/lib/module/shared/utils/bounds/zoom/accessor.js +49 -0
- package/lib/module/shared/utils/bounds/zoom/accessor.js.map +1 -0
- package/lib/module/shared/utils/bounds/zoom/build.js +543 -0
- package/lib/module/shared/utils/bounds/zoom/build.js.map +1 -0
- package/lib/module/shared/utils/bounds/zoom/config.js +112 -0
- package/lib/module/shared/utils/bounds/zoom/config.js.map +1 -0
- package/lib/module/shared/utils/bounds/zoom/index.js +5 -0
- package/lib/module/shared/utils/bounds/zoom/index.js.map +1 -0
- package/lib/module/shared/utils/bounds/zoom/types.js.map +1 -0
- package/lib/module/shared/utils/gesture/validate-snap-points.js +11 -5
- package/lib/module/shared/utils/gesture/validate-snap-points.js.map +1 -1
- package/lib/module/shared/utils/overlay/visibility.js +1 -7
- package/lib/module/shared/utils/overlay/visibility.js.map +1 -1
- package/lib/module/shared/utils/resolve-screen-transition-options.js +19 -0
- package/lib/module/shared/utils/resolve-screen-transition-options.js.map +1 -0
- package/lib/typescript/blank-stack/index.d.ts +1 -1
- package/lib/typescript/blank-stack/index.d.ts.map +1 -1
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts +29 -4
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts.map +1 -1
- package/lib/typescript/blank-stack/types.d.ts +33 -4
- package/lib/typescript/blank-stack/types.d.ts.map +1 -1
- package/lib/typescript/component-stack/navigators/create-component-stack-navigator.d.ts +8 -0
- package/lib/typescript/component-stack/navigators/create-component-stack-navigator.d.ts.map +1 -1
- package/lib/typescript/shared/animation/snap-to.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/helpers/measurement-rules.d.ts +81 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/helpers/measurement-rules.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-auto-source-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.d.ts +2 -3
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.d.ts +11 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-group-active-measurement.d.ts +2 -2
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-group-active-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.d.ts +11 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-initial-layout-handler.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.d.ts +3 -3
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.d.ts +2 -2
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/index.d.ts +5 -3
- package/lib/typescript/shared/components/create-boundary-component/index.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/types.d.ts +2 -4
- package/lib/typescript/shared/components/create-boundary-component/types.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/utils/build-boundary-match-key.d.ts +0 -1
- package/lib/typescript/shared/components/create-boundary-component/utils/build-boundary-match-key.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-transition-aware-component.d.ts +1 -0
- package/lib/typescript/shared/components/create-transition-aware-component.d.ts.map +1 -1
- package/lib/typescript/shared/components/native-screen-container.d.ts.map +1 -1
- package/lib/typescript/shared/components/native-screen.d.ts.map +1 -1
- package/lib/typescript/shared/components/overlay/helpers/get-active-overlay.d.ts +1 -1
- package/lib/typescript/shared/components/overlay/index.d.ts +0 -2
- package/lib/typescript/shared/components/overlay/index.d.ts.map +1 -1
- package/lib/typescript/shared/components/overlay/variations/overlay-host.d.ts.map +1 -1
- package/lib/typescript/shared/components/scene-view.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/hooks/use-content-layout.d.ts +3 -0
- package/lib/typescript/shared/components/screen-container/hooks/use-content-layout.d.ts.map +1 -0
- package/lib/typescript/shared/components/screen-container/layers/backdrop.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/layers/content.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/layers/maybe-masked-navigation-container.d.ts +9 -0
- package/lib/typescript/shared/components/screen-container/layers/maybe-masked-navigation-container.d.ts.map +1 -0
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-close-transition/index.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-open-transition.d.ts.map +1 -1
- package/lib/typescript/shared/constants.d.ts +3 -0
- package/lib/typescript/shared/constants.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/gestures/resolve-screen-gesture-target.d.ts +10 -0
- package/lib/typescript/shared/hooks/gestures/resolve-screen-gesture-target.d.ts.map +1 -0
- package/lib/typescript/shared/hooks/gestures/types.d.ts +4 -0
- package/lib/typescript/shared/hooks/gestures/types.d.ts.map +1 -0
- package/lib/typescript/shared/hooks/gestures/use-screen-gesture.d.ts +4 -2
- package/lib/typescript/shared/hooks/gestures/use-screen-gesture.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts +1 -2
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts.map +1 -1
- package/lib/typescript/shared/index.d.ts +16 -18
- package/lib/typescript/shared/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/gestures/handlers/use-handlers.d.ts +1 -1
- package/lib/typescript/shared/providers/gestures/handlers/use-handlers.d.ts.map +1 -1
- package/lib/typescript/shared/providers/gestures/helpers/gesture-activation.d.ts.map +1 -1
- package/lib/typescript/shared/providers/gestures/helpers/gesture-snap-points.d.ts +18 -0
- package/lib/typescript/shared/providers/gestures/helpers/gesture-snap-points.d.ts.map +1 -0
- package/lib/typescript/shared/providers/layout-anchor.provider.d.ts +1 -1
- package/lib/typescript/shared/providers/layout-anchor.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/animation.provider.d.ts +6 -3
- package/lib/typescript/shared/providers/screen/animation/animation.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/derivations.d.ts +0 -2
- package/lib/typescript/shared/providers/screen/animation/helpers/derivations.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/pipeline.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/resolve-screen-animation-target.d.ts +11 -0
- package/lib/typescript/shared/providers/screen/animation/helpers/resolve-screen-animation-target.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/animation/index.d.ts +1 -1
- package/lib/typescript/shared/providers/screen/animation/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/types.d.ts +4 -0
- package/lib/typescript/shared/providers/screen/animation/types.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/animation/use-screen-animation.d.ts +5 -1
- package/lib/typescript/shared/providers/screen/animation/use-screen-animation.d.ts.map +1 -1
- package/lib/typescript/shared/providers/stack/core.provider.d.ts +2 -0
- package/lib/typescript/shared/providers/stack/core.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/stack/direct.provider.d.ts.map +1 -1
- package/lib/typescript/shared/stores/animation.store.d.ts +8 -2
- package/lib/typescript/shared/stores/animation.store.d.ts.map +1 -1
- package/lib/typescript/shared/stores/bounds/internals/presence.d.ts.map +1 -1
- package/lib/typescript/shared/stores/bounds/internals/resolver.d.ts.map +1 -1
- package/lib/typescript/shared/stores/bounds/types.d.ts +2 -0
- package/lib/typescript/shared/stores/bounds/types.d.ts.map +1 -1
- package/lib/typescript/shared/types/animation.types.d.ts +33 -51
- package/lib/typescript/shared/types/animation.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/bounds.types.d.ts +46 -9
- package/lib/typescript/shared/types/bounds.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/index.d.ts +3 -3
- package/lib/typescript/shared/types/index.d.ts.map +1 -1
- package/lib/typescript/shared/types/overlay.types.d.ts +1 -22
- package/lib/typescript/shared/types/overlay.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/screen.types.d.ts +62 -37
- package/lib/typescript/shared/types/screen.types.d.ts.map +1 -1
- package/lib/typescript/shared/utils/animation/animate-to-progress.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/build-bounds-options.d.ts +2 -2
- package/lib/typescript/shared/utils/bounds/helpers/build-bounds-options.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/compute-bounds-styles.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/geometry.d.ts +3 -2
- package/lib/typescript/shared/utils/bounds/helpers/geometry.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/interpolators.d.ts +3 -2
- package/lib/typescript/shared/utils/bounds/helpers/interpolators.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/link-accessor.d.ts +3 -2
- package/lib/typescript/shared/utils/bounds/helpers/link-accessor.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/resolve-bound-tag.d.ts +2 -1
- package/lib/typescript/shared/utils/bounds/helpers/resolve-bound-tag.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/style-composers.d.ts +4 -3
- package/lib/typescript/shared/utils/bounds/helpers/style-composers.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/index.d.ts +2 -2
- package/lib/typescript/shared/utils/bounds/index.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/types/frame-props.d.ts +5 -0
- package/lib/typescript/shared/utils/bounds/types/frame-props.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/types/options.d.ts +5 -4
- package/lib/typescript/shared/utils/bounds/types/options.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/zoom/accessor.d.ts +17 -0
- package/lib/typescript/shared/utils/bounds/zoom/accessor.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/zoom/build.d.ts +4 -0
- package/lib/typescript/shared/utils/bounds/zoom/build.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/zoom/config.d.ts +43 -0
- package/lib/typescript/shared/utils/bounds/zoom/config.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/zoom/index.d.ts +3 -0
- package/lib/typescript/shared/utils/bounds/zoom/index.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/zoom/types.d.ts +17 -0
- package/lib/typescript/shared/utils/bounds/zoom/types.d.ts.map +1 -0
- package/lib/typescript/shared/utils/gesture/validate-snap-points.d.ts +5 -3
- package/lib/typescript/shared/utils/gesture/validate-snap-points.d.ts.map +1 -1
- package/lib/typescript/shared/utils/overlay/visibility.d.ts +1 -4
- package/lib/typescript/shared/utils/overlay/visibility.d.ts.map +1 -1
- package/lib/typescript/shared/utils/resolve-screen-transition-options.d.ts +5 -0
- package/lib/typescript/shared/utils/resolve-screen-transition-options.d.ts.map +1 -0
- package/package.json +3 -2
- package/src/blank-stack/index.ts +1 -0
- package/src/blank-stack/navigators/create-blank-stack-navigator.tsx +138 -19
- package/src/blank-stack/types.ts +33 -5
- package/src/component-stack/navigators/create-component-stack-navigator.tsx +8 -0
- package/src/shared/animation/snap-to.ts +12 -1
- package/src/shared/components/create-boundary-component/hooks/helpers/measurement-rules.ts +258 -0
- package/src/shared/components/create-boundary-component/hooks/use-auto-source-measurement.ts +7 -17
- package/src/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.ts +38 -28
- package/src/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.ts +58 -0
- package/src/shared/components/create-boundary-component/hooks/use-group-active-measurement.ts +41 -10
- package/src/shared/components/create-boundary-component/hooks/use-group-active-source-measurement.ts +82 -0
- package/src/shared/components/create-boundary-component/hooks/use-initial-layout-handler.ts +24 -12
- package/src/shared/components/create-boundary-component/hooks/use-pending-destination-measurement.ts +11 -9
- package/src/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.ts +29 -26
- package/src/shared/components/create-boundary-component/hooks/use-scroll-settled-measurement.ts +26 -17
- package/src/shared/components/create-boundary-component/index.tsx +25 -6
- package/src/shared/components/create-boundary-component/types.ts +8 -4
- package/src/shared/components/create-boundary-component/utils/build-boundary-match-key.ts +2 -14
- package/src/shared/components/create-transition-aware-component.tsx +5 -2
- package/src/shared/components/native-screen-container.tsx +11 -3
- package/src/shared/components/native-screen.tsx +65 -20
- package/src/shared/components/overlay/helpers/get-active-overlay.ts +3 -3
- package/src/shared/components/overlay/index.ts +0 -2
- package/src/shared/components/overlay/variations/overlay-host.tsx +2 -16
- package/src/shared/components/scene-view.tsx +0 -3
- package/src/shared/components/screen-container/hooks/use-content-layout.ts +82 -0
- package/src/shared/components/screen-container/layers/backdrop.tsx +25 -6
- package/src/shared/components/screen-container/layers/content.tsx +23 -82
- package/src/shared/components/screen-container/layers/maybe-masked-navigation-container.tsx +101 -0
- package/src/shared/components/screen-lifecycle/hooks/use-close-transition/index.ts +1 -2
- package/src/shared/components/screen-lifecycle/hooks/use-open-transition.ts +20 -6
- package/src/shared/constants.ts +6 -2
- package/src/shared/hooks/gestures/resolve-screen-gesture-target.ts +66 -0
- package/src/shared/hooks/gestures/types.ts +5 -0
- package/src/shared/hooks/gestures/use-screen-gesture.ts +10 -3
- package/src/shared/hooks/navigation/use-stack.tsx +1 -2
- package/src/shared/index.ts +14 -16
- package/src/shared/providers/gestures/handlers/use-handlers.ts +75 -29
- package/src/shared/providers/gestures/helpers/gesture-activation.ts +11 -6
- package/src/shared/providers/gestures/helpers/gesture-snap-points.ts +72 -0
- package/src/shared/providers/layout-anchor.provider.tsx +2 -5
- package/src/shared/providers/register-bounds.provider.tsx +1 -1
- package/src/shared/providers/screen/animation/animation.provider.tsx +46 -10
- package/src/shared/providers/screen/animation/helpers/derivations.ts +0 -8
- package/src/shared/providers/screen/animation/helpers/pipeline.ts +51 -14
- package/src/shared/providers/screen/animation/helpers/resolve-screen-animation-target.ts +44 -0
- package/src/shared/providers/screen/animation/index.tsx +4 -1
- package/src/shared/providers/screen/animation/types.ts +5 -0
- package/src/shared/providers/screen/animation/use-screen-animation.tsx +16 -3
- package/src/shared/providers/stack/core.provider.tsx +27 -14
- package/src/shared/providers/stack/direct.provider.tsx +2 -5
- package/src/shared/providers/stack/helpers/use-processed-routes.ts +2 -2
- package/src/shared/stores/animation.store.ts +21 -5
- package/src/shared/stores/bounds/internals/presence.ts +3 -1
- package/src/shared/stores/bounds/internals/resolver.ts +13 -1
- package/src/shared/stores/bounds/types.ts +2 -0
- package/src/shared/types/animation.types.ts +32 -58
- package/src/shared/types/bounds.types.ts +30 -10
- package/src/shared/types/index.ts +2 -15
- package/src/shared/types/overlay.types.ts +1 -28
- package/src/shared/types/screen.types.ts +67 -38
- package/src/shared/utils/animation/animate-to-progress.ts +7 -0
- package/src/shared/utils/bounds/helpers/build-bounds-options.ts +2 -2
- package/src/shared/utils/bounds/helpers/compute-bounds-styles.ts +47 -8
- package/src/shared/utils/bounds/helpers/geometry.ts +3 -2
- package/src/shared/utils/bounds/helpers/interpolators.ts +8 -6
- package/src/shared/utils/bounds/helpers/link-accessor.ts +10 -6
- package/src/shared/utils/bounds/helpers/resolve-bound-tag.ts +7 -10
- package/src/shared/utils/bounds/helpers/style-composers.ts +4 -3
- package/src/shared/utils/bounds/index.ts +22 -13
- package/src/shared/utils/bounds/types/frame-props.ts +5 -0
- package/src/shared/utils/bounds/types/options.ts +6 -4
- package/src/shared/utils/bounds/zoom/accessor.ts +69 -0
- package/src/shared/utils/bounds/zoom/build.ts +715 -0
- package/src/shared/utils/bounds/zoom/config.ts +179 -0
- package/src/shared/utils/bounds/zoom/index.ts +2 -0
- package/src/shared/utils/bounds/zoom/types.ts +22 -0
- package/src/shared/utils/gesture/validate-snap-points.ts +20 -8
- package/src/shared/utils/overlay/visibility.ts +1 -16
- package/src/shared/utils/resolve-screen-transition-options.ts +37 -0
- package/lib/commonjs/shared/components/overlay/variations/screen-overlay.js +0 -64
- package/lib/commonjs/shared/components/overlay/variations/screen-overlay.js.map +0 -1
- package/lib/commonjs/shared/providers/viewport.provider.js +0 -33
- package/lib/commonjs/shared/providers/viewport.provider.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/helpers/math.js +0 -132
- package/lib/commonjs/shared/utils/bounds/helpers/math.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/helpers/navigation-accessor.js +0 -45
- package/lib/commonjs/shared/utils/bounds/helpers/navigation-accessor.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/helpers.js +0 -60
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/helpers.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/index.js +0 -20
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/index.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/types.js.map +0 -1
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/zoom.js +0 -295
- package/lib/commonjs/shared/utils/bounds/sugar/navigation/zoom.js.map +0 -1
- package/lib/module/shared/components/overlay/variations/screen-overlay.js +0 -61
- package/lib/module/shared/components/overlay/variations/screen-overlay.js.map +0 -1
- package/lib/module/shared/providers/viewport.provider.js +0 -27
- package/lib/module/shared/providers/viewport.provider.js.map +0 -1
- package/lib/module/shared/utils/bounds/helpers/math.js +0 -115
- package/lib/module/shared/utils/bounds/helpers/math.js.map +0 -1
- package/lib/module/shared/utils/bounds/helpers/navigation-accessor.js +0 -40
- package/lib/module/shared/utils/bounds/helpers/navigation-accessor.js.map +0 -1
- package/lib/module/shared/utils/bounds/sugar/navigation/helpers.js +0 -54
- package/lib/module/shared/utils/bounds/sugar/navigation/helpers.js.map +0 -1
- package/lib/module/shared/utils/bounds/sugar/navigation/index.js +0 -15
- package/lib/module/shared/utils/bounds/sugar/navigation/index.js.map +0 -1
- package/lib/module/shared/utils/bounds/sugar/navigation/types.js.map +0 -1
- package/lib/module/shared/utils/bounds/sugar/navigation/zoom.js +0 -290
- package/lib/module/shared/utils/bounds/sugar/navigation/zoom.js.map +0 -1
- package/lib/typescript/shared/components/overlay/variations/screen-overlay.d.ts +0 -10
- package/lib/typescript/shared/components/overlay/variations/screen-overlay.d.ts.map +0 -1
- package/lib/typescript/shared/providers/viewport.provider.d.ts +0 -13
- package/lib/typescript/shared/providers/viewport.provider.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/helpers/math.d.ts +0 -38
- package/lib/typescript/shared/utils/bounds/helpers/math.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/helpers/navigation-accessor.d.ts +0 -16
- package/lib/typescript/shared/utils/bounds/helpers/navigation-accessor.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/sugar/navigation/helpers.d.ts +0 -17
- package/lib/typescript/shared/utils/bounds/sugar/navigation/helpers.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/sugar/navigation/index.d.ts +0 -3
- package/lib/typescript/shared/utils/bounds/sugar/navigation/index.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/sugar/navigation/types.d.ts +0 -18
- package/lib/typescript/shared/utils/bounds/sugar/navigation/types.d.ts.map +0 -1
- package/lib/typescript/shared/utils/bounds/sugar/navigation/zoom.d.ts +0 -4
- package/lib/typescript/shared/utils/bounds/sugar/navigation/zoom.d.ts.map +0 -1
- package/src/shared/components/overlay/variations/screen-overlay.tsx +0 -68
- package/src/shared/providers/viewport.provider.tsx +0 -39
- package/src/shared/utils/bounds/helpers/math.ts +0 -161
- package/src/shared/utils/bounds/helpers/navigation-accessor.ts +0 -61
- package/src/shared/utils/bounds/sugar/navigation/helpers.ts +0 -74
- package/src/shared/utils/bounds/sugar/navigation/index.ts +0 -14
- package/src/shared/utils/bounds/sugar/navigation/types.ts +0 -26
- package/src/shared/utils/bounds/sugar/navigation/zoom.ts +0 -348
- /package/lib/commonjs/shared/utils/bounds/{sugar/navigation → zoom}/types.js +0 -0
- /package/lib/module/shared/utils/bounds/{sugar/navigation → zoom}/types.js +0 -0
package/src/blank-stack/types.ts
CHANGED
|
@@ -51,9 +51,38 @@ export type BlankStackNavigationHelpers = NavigationHelpers<
|
|
|
51
51
|
BlankStackNavigationEventMap
|
|
52
52
|
>;
|
|
53
53
|
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
54
|
+
/**
|
|
55
|
+
* Factory-only options for `createBlankStackNavigator`.
|
|
56
|
+
*
|
|
57
|
+
* Use these when you need to change how the blank stack itself is hosted,
|
|
58
|
+
* not how individual screens transition.
|
|
59
|
+
*/
|
|
60
|
+
export interface BlankStackFactoryOptions {
|
|
61
|
+
/**
|
|
62
|
+
* Creates an isolated navigation tree for embedded flows.
|
|
63
|
+
*
|
|
64
|
+
* Use this when the blank stack needs to live inside another screen or host
|
|
65
|
+
* application without joining the parent React Navigation tree.
|
|
66
|
+
*
|
|
67
|
+
* When enabled, the navigator:
|
|
68
|
+
* - wraps itself in `NavigationIndependentTree` + `NavigationContainer`
|
|
69
|
+
* - skips the shared native `ScreenContainer`
|
|
70
|
+
*
|
|
71
|
+
* Leave this disabled for normal top-level app stacks.
|
|
72
|
+
*/
|
|
73
|
+
independent?: boolean;
|
|
74
|
+
/**
|
|
75
|
+
* Enables native screen primitives on supported native platforms.
|
|
76
|
+
*
|
|
77
|
+
* Use this when you want the embedded blank stack to keep `react-native-screens`
|
|
78
|
+
* behavior such as native activity state and freezing.
|
|
79
|
+
*
|
|
80
|
+
* Set this to `false` when you want the blank stack to render with regular
|
|
81
|
+
* views instead of native screen primitives. This is useful for embedded
|
|
82
|
+
* flows where plain views are a better fit than native screen layering.
|
|
83
|
+
*/
|
|
84
|
+
enableNativeScreens?: boolean;
|
|
85
|
+
}
|
|
57
86
|
|
|
58
87
|
/**
|
|
59
88
|
* Props passed to overlay components in blank-stack.
|
|
@@ -91,8 +120,7 @@ export type BlankStackNavigatorProps = DefaultNavigatorOptions<
|
|
|
91
120
|
BlankStackNavigationEventMap,
|
|
92
121
|
BlankStackNavigationProp<ParamListBase>
|
|
93
122
|
> &
|
|
94
|
-
StackRouterOptions
|
|
95
|
-
BlankStackNavigationConfig;
|
|
123
|
+
StackRouterOptions;
|
|
96
124
|
|
|
97
125
|
export type BlankStackDescriptor = Descriptor<
|
|
98
126
|
BlankStackNavigationOptions,
|
|
@@ -95,6 +95,14 @@ function IsolatedComponentStackNavigator(props: ComponentStackNavigatorProps) {
|
|
|
95
95
|
);
|
|
96
96
|
}
|
|
97
97
|
|
|
98
|
+
/**
|
|
99
|
+
* @deprecated Component stack was originally introduced for independent,
|
|
100
|
+
* embedded navigation flows. Blank stack now supports that use case directly
|
|
101
|
+
* via `createBlankStackNavigator({ independent: true })`, with
|
|
102
|
+
* `enableNativeScreens` available when you need to switch between native
|
|
103
|
+
* screens and regular views. Prefer blank stack for new work; component stack
|
|
104
|
+
* will be removed in a future release.
|
|
105
|
+
*/
|
|
98
106
|
export function createComponentStackNavigator<
|
|
99
107
|
const ParamList extends ParamListBase,
|
|
100
108
|
const NavigatorID extends string | undefined = undefined,
|
|
@@ -11,7 +11,18 @@ const getSortedSnapPoints = (
|
|
|
11
11
|
): number[] | null => {
|
|
12
12
|
const snapPoints = descriptor.options?.snapPoints;
|
|
13
13
|
if (!snapPoints || snapPoints.length === 0) return null;
|
|
14
|
-
|
|
14
|
+
|
|
15
|
+
// Resolve 'auto' to the measured fraction stored in AnimationStore
|
|
16
|
+
const autoVal = AnimationStore.getAnimation(
|
|
17
|
+
descriptor.route.key,
|
|
18
|
+
"autoSnapPoint",
|
|
19
|
+
).value;
|
|
20
|
+
|
|
21
|
+
const resolved = snapPoints
|
|
22
|
+
.map((p) => (p === "auto" ? autoVal : p))
|
|
23
|
+
.filter((p): p is number => typeof p === "number" && p > 0);
|
|
24
|
+
|
|
25
|
+
return resolved.length > 0 ? resolved.sort((a, b) => a - b) : null;
|
|
15
26
|
};
|
|
16
27
|
|
|
17
28
|
export function snapDescriptorToIndex(
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
import type { MeasurementIntent } from "../../types";
|
|
2
|
+
|
|
3
|
+
type PresenceLikeEntry = {
|
|
4
|
+
count: number;
|
|
5
|
+
ancestorKeys?: string[];
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
export type MeasurementIntentFlags = {
|
|
9
|
+
captureSource: boolean;
|
|
10
|
+
completeDestination: boolean;
|
|
11
|
+
refreshSource: boolean;
|
|
12
|
+
refreshDestination: boolean;
|
|
13
|
+
snapshotOnly: boolean;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export type MeasurementWritePlan = {
|
|
17
|
+
captureSource: boolean;
|
|
18
|
+
completeDestination: boolean;
|
|
19
|
+
refreshSource: boolean;
|
|
20
|
+
refreshDestination: boolean;
|
|
21
|
+
registerSnapshot: boolean;
|
|
22
|
+
writesAny: boolean;
|
|
23
|
+
wantsDestinationWrite: boolean;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export type DeferredMeasurementAction =
|
|
27
|
+
| "clear-pending"
|
|
28
|
+
| "queue-or-flush"
|
|
29
|
+
| "noop";
|
|
30
|
+
|
|
31
|
+
export const getMeasurementIntentFlags = (
|
|
32
|
+
intent?: MeasurementIntent | readonly MeasurementIntent[],
|
|
33
|
+
): MeasurementIntentFlags => {
|
|
34
|
+
"worklet";
|
|
35
|
+
const flags: MeasurementIntentFlags = {
|
|
36
|
+
captureSource: false,
|
|
37
|
+
completeDestination: false,
|
|
38
|
+
refreshSource: false,
|
|
39
|
+
refreshDestination: false,
|
|
40
|
+
snapshotOnly: false,
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
if (!intent) {
|
|
44
|
+
return flags;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const intents = Array.isArray(intent) ? intent : [intent];
|
|
48
|
+
|
|
49
|
+
for (let i = 0; i < intents.length; i++) {
|
|
50
|
+
switch (intents[i]) {
|
|
51
|
+
case "capture-source":
|
|
52
|
+
flags.captureSource = true;
|
|
53
|
+
break;
|
|
54
|
+
case "complete-destination":
|
|
55
|
+
flags.completeDestination = true;
|
|
56
|
+
break;
|
|
57
|
+
case "refresh-source":
|
|
58
|
+
flags.refreshSource = true;
|
|
59
|
+
break;
|
|
60
|
+
case "refresh-destination":
|
|
61
|
+
flags.refreshDestination = true;
|
|
62
|
+
break;
|
|
63
|
+
case "snapshot-only":
|
|
64
|
+
flags.snapshotOnly = true;
|
|
65
|
+
break;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
return flags;
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
export const resolveMeasurementWritePlan = (params: {
|
|
73
|
+
intents: MeasurementIntentFlags;
|
|
74
|
+
hasPendingLink: boolean;
|
|
75
|
+
hasSourceLink: boolean;
|
|
76
|
+
hasDestinationLink: boolean;
|
|
77
|
+
}): MeasurementWritePlan => {
|
|
78
|
+
"worklet";
|
|
79
|
+
const { intents, hasPendingLink, hasSourceLink, hasDestinationLink } = params;
|
|
80
|
+
|
|
81
|
+
const captureSource = intents.captureSource;
|
|
82
|
+
const completeDestination = intents.completeDestination && hasPendingLink;
|
|
83
|
+
const refreshSource = intents.refreshSource && hasSourceLink;
|
|
84
|
+
const refreshDestination =
|
|
85
|
+
intents.refreshDestination && (hasDestinationLink || hasPendingLink);
|
|
86
|
+
const registerSnapshot = intents.snapshotOnly;
|
|
87
|
+
const writesAny =
|
|
88
|
+
registerSnapshot ||
|
|
89
|
+
captureSource ||
|
|
90
|
+
completeDestination ||
|
|
91
|
+
refreshSource ||
|
|
92
|
+
refreshDestination;
|
|
93
|
+
|
|
94
|
+
return {
|
|
95
|
+
captureSource,
|
|
96
|
+
completeDestination,
|
|
97
|
+
refreshSource,
|
|
98
|
+
refreshDestination,
|
|
99
|
+
registerSnapshot,
|
|
100
|
+
writesAny,
|
|
101
|
+
wantsDestinationWrite: completeDestination || refreshDestination,
|
|
102
|
+
};
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
export const resolveAutoSourceCaptureSignal = (params: {
|
|
106
|
+
enabled: boolean;
|
|
107
|
+
nextScreenKey?: string;
|
|
108
|
+
tagPresence?: Record<string, PresenceLikeEntry>;
|
|
109
|
+
}): string | 0 => {
|
|
110
|
+
"worklet";
|
|
111
|
+
const { enabled, nextScreenKey, tagPresence } = params;
|
|
112
|
+
if (!enabled) return 0;
|
|
113
|
+
if (!nextScreenKey) return 0;
|
|
114
|
+
if (!tagPresence) return 0;
|
|
115
|
+
|
|
116
|
+
const direct = tagPresence[nextScreenKey];
|
|
117
|
+
if (direct && direct.count > 0) return nextScreenKey;
|
|
118
|
+
|
|
119
|
+
for (const screenKey in tagPresence) {
|
|
120
|
+
const entry = tagPresence[screenKey];
|
|
121
|
+
if (entry.ancestorKeys?.includes(nextScreenKey)) {
|
|
122
|
+
return nextScreenKey;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
return 0;
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
export const resolvePendingDestinationCaptureSignal = (params: {
|
|
130
|
+
enabled: boolean;
|
|
131
|
+
resolvedSourceKey?: string | null;
|
|
132
|
+
hasPendingLinkFromSource: boolean;
|
|
133
|
+
}): string | 0 => {
|
|
134
|
+
"worklet";
|
|
135
|
+
const { enabled, resolvedSourceKey, hasPendingLinkFromSource } = params;
|
|
136
|
+
if (!enabled) return 0;
|
|
137
|
+
if (!resolvedSourceKey) return 0;
|
|
138
|
+
return hasPendingLinkFromSource ? resolvedSourceKey : 0;
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
export const resolvePendingDestinationRetrySignal = (params: {
|
|
142
|
+
enabled: boolean;
|
|
143
|
+
retryCount: number;
|
|
144
|
+
maxRetries: number;
|
|
145
|
+
isAnimating: boolean;
|
|
146
|
+
hasDestinationLink: boolean;
|
|
147
|
+
progress: number;
|
|
148
|
+
retryProgressMax: number;
|
|
149
|
+
retryProgressBuckets: number;
|
|
150
|
+
resolvedSourceKey?: string | null;
|
|
151
|
+
hasPendingLinkFromSource: boolean;
|
|
152
|
+
}): number => {
|
|
153
|
+
"worklet";
|
|
154
|
+
const {
|
|
155
|
+
enabled,
|
|
156
|
+
retryCount,
|
|
157
|
+
maxRetries,
|
|
158
|
+
isAnimating,
|
|
159
|
+
hasDestinationLink,
|
|
160
|
+
progress,
|
|
161
|
+
retryProgressMax,
|
|
162
|
+
retryProgressBuckets,
|
|
163
|
+
resolvedSourceKey,
|
|
164
|
+
hasPendingLinkFromSource,
|
|
165
|
+
} = params;
|
|
166
|
+
|
|
167
|
+
if (!enabled) return 0;
|
|
168
|
+
if (retryCount >= maxRetries) return 0;
|
|
169
|
+
if (!isAnimating) return 0;
|
|
170
|
+
if (hasDestinationLink) return 0;
|
|
171
|
+
if (progress <= 0 || progress >= retryProgressMax) return 0;
|
|
172
|
+
if (!resolvedSourceKey) return 0;
|
|
173
|
+
if (!hasPendingLinkFromSource) return 0;
|
|
174
|
+
|
|
175
|
+
return Math.floor(progress * retryProgressBuckets) + 1;
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
export const resolveInitialLayoutMeasurementIntent = (params: {
|
|
179
|
+
enabled: boolean;
|
|
180
|
+
hasSharedBoundTag: boolean;
|
|
181
|
+
hasMeasuredOnLayout: boolean;
|
|
182
|
+
isAnyAnimating: boolean;
|
|
183
|
+
hasPendingLinkFromSource: boolean;
|
|
184
|
+
}): MeasurementIntent | readonly MeasurementIntent[] | null => {
|
|
185
|
+
"worklet";
|
|
186
|
+
const {
|
|
187
|
+
enabled,
|
|
188
|
+
hasSharedBoundTag,
|
|
189
|
+
hasMeasuredOnLayout,
|
|
190
|
+
isAnyAnimating,
|
|
191
|
+
hasPendingLinkFromSource,
|
|
192
|
+
} = params;
|
|
193
|
+
|
|
194
|
+
if (!enabled) return null;
|
|
195
|
+
if (!hasSharedBoundTag || hasMeasuredOnLayout) return null;
|
|
196
|
+
|
|
197
|
+
if (!isAnyAnimating) {
|
|
198
|
+
return "snapshot-only";
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return hasPendingLinkFromSource
|
|
202
|
+
? ["snapshot-only", "complete-destination"]
|
|
203
|
+
: "snapshot-only";
|
|
204
|
+
};
|
|
205
|
+
|
|
206
|
+
export const resolveGroupActiveMeasurementAction = (params: {
|
|
207
|
+
enabled: boolean;
|
|
208
|
+
isEligible: boolean;
|
|
209
|
+
memberId: string;
|
|
210
|
+
activeId: string | null;
|
|
211
|
+
previousActiveId: string | null;
|
|
212
|
+
}): DeferredMeasurementAction => {
|
|
213
|
+
"worklet";
|
|
214
|
+
const { enabled, isEligible, memberId, activeId, previousActiveId } = params;
|
|
215
|
+
|
|
216
|
+
if (!enabled || !isEligible) return "noop";
|
|
217
|
+
if (activeId !== memberId) return "clear-pending";
|
|
218
|
+
if (activeId === memberId && activeId !== previousActiveId) {
|
|
219
|
+
return "queue-or-flush";
|
|
220
|
+
}
|
|
221
|
+
return "noop";
|
|
222
|
+
};
|
|
223
|
+
|
|
224
|
+
export const canFlushGroupActiveMeasurement = (params: {
|
|
225
|
+
enabled: boolean;
|
|
226
|
+
isEligible: boolean;
|
|
227
|
+
memberId: string;
|
|
228
|
+
activeId: string | null;
|
|
229
|
+
}): boolean => {
|
|
230
|
+
"worklet";
|
|
231
|
+
const { enabled, isEligible, memberId, activeId } = params;
|
|
232
|
+
if (!enabled || !isEligible) return false;
|
|
233
|
+
return activeId === memberId;
|
|
234
|
+
};
|
|
235
|
+
|
|
236
|
+
export const shouldTriggerScrollSettledRefresh = (params: {
|
|
237
|
+
enabled: boolean;
|
|
238
|
+
group: string | undefined;
|
|
239
|
+
hasNextScreen: boolean;
|
|
240
|
+
hasSettledSignal: boolean;
|
|
241
|
+
signal: number;
|
|
242
|
+
previousSignal: number | null;
|
|
243
|
+
}): boolean => {
|
|
244
|
+
"worklet";
|
|
245
|
+
const {
|
|
246
|
+
enabled,
|
|
247
|
+
group,
|
|
248
|
+
hasNextScreen,
|
|
249
|
+
hasSettledSignal,
|
|
250
|
+
signal,
|
|
251
|
+
previousSignal,
|
|
252
|
+
} = params;
|
|
253
|
+
|
|
254
|
+
if (!enabled) return false;
|
|
255
|
+
if (!group || !hasNextScreen || !hasSettledSignal) return false;
|
|
256
|
+
if (signal === 0 || signal === previousSignal) return false;
|
|
257
|
+
return true;
|
|
258
|
+
};
|
package/src/shared/components/create-boundary-component/hooks/use-auto-source-measurement.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useAnimatedReaction } from "react-native-reanimated";
|
|
2
2
|
import { BoundStore } from "../../../stores/bounds";
|
|
3
3
|
import type { MaybeMeasureAndStoreParams } from "../types";
|
|
4
|
+
import { resolveAutoSourceCaptureSignal } from "./helpers/measurement-rules";
|
|
4
5
|
|
|
5
6
|
export const useAutoSourceMeasurement = (params: {
|
|
6
7
|
enabled: boolean;
|
|
@@ -15,29 +16,18 @@ export const useAutoSourceMeasurement = (params: {
|
|
|
15
16
|
useAnimatedReaction(
|
|
16
17
|
() => {
|
|
17
18
|
"worklet";
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
const direct = tagPresence[nextScreenKey];
|
|
24
|
-
if (direct && direct.count > 0) return nextScreenKey;
|
|
25
|
-
|
|
26
|
-
for (const screenKey in tagPresence) {
|
|
27
|
-
const entry = tagPresence[screenKey];
|
|
28
|
-
if (entry.ancestorKeys?.includes(nextScreenKey)) {
|
|
29
|
-
return nextScreenKey;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return 0;
|
|
19
|
+
return resolveAutoSourceCaptureSignal({
|
|
20
|
+
enabled,
|
|
21
|
+
nextScreenKey,
|
|
22
|
+
tagPresence: boundaryPresence.value[sharedBoundTag],
|
|
23
|
+
});
|
|
34
24
|
},
|
|
35
25
|
(captureSignal, previousCaptureSignal) => {
|
|
36
26
|
"worklet";
|
|
37
27
|
if (!enabled) return;
|
|
38
28
|
if (!nextScreenKey) return;
|
|
39
29
|
if (!captureSignal || captureSignal === previousCaptureSignal) return;
|
|
40
|
-
maybeMeasureAndStore({
|
|
30
|
+
maybeMeasureAndStore({ intent: "capture-source" });
|
|
41
31
|
},
|
|
42
32
|
[
|
|
43
33
|
enabled,
|
package/src/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.ts
CHANGED
|
@@ -3,14 +3,18 @@ import {
|
|
|
3
3
|
type AnimatedRef,
|
|
4
4
|
type MeasuredDimensions,
|
|
5
5
|
measure,
|
|
6
|
+
type SharedValue,
|
|
6
7
|
type StyleProps,
|
|
7
8
|
} from "react-native-reanimated";
|
|
8
9
|
import useStableCallbackValue from "../../../hooks/use-stable-callback-value";
|
|
9
|
-
import type { AnimationStore } from "../../../stores/animation.store";
|
|
10
10
|
import { BoundStore } from "../../../stores/bounds";
|
|
11
11
|
import { applyMeasuredBoundsWrites } from "../../../stores/bounds/helpers/apply-measured-bounds-writes";
|
|
12
12
|
import { resolvePendingSourceKey } from "../helpers/resolve-pending-source-key";
|
|
13
13
|
import type { MaybeMeasureAndStoreParams } from "../types";
|
|
14
|
+
import {
|
|
15
|
+
getMeasurementIntentFlags,
|
|
16
|
+
resolveMeasurementWritePlan,
|
|
17
|
+
} from "./helpers/measurement-rules";
|
|
14
18
|
|
|
15
19
|
type LayoutAnchor = {
|
|
16
20
|
correctMeasurement: (measured: MeasuredDimensions) => MeasuredDimensions;
|
|
@@ -43,7 +47,7 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
43
47
|
ancestorKeys: string[];
|
|
44
48
|
navigatorKey?: string;
|
|
45
49
|
ancestorNavigatorKeys?: string[];
|
|
46
|
-
isAnimating:
|
|
50
|
+
isAnimating: SharedValue<number>;
|
|
47
51
|
preparedStyles: StyleProps;
|
|
48
52
|
animatedRef: AnimatedRef<View>;
|
|
49
53
|
layoutAnchor: LayoutAnchor;
|
|
@@ -63,20 +67,17 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
63
67
|
} = params;
|
|
64
68
|
|
|
65
69
|
return useStableCallbackValue(
|
|
66
|
-
({
|
|
67
|
-
shouldSetSource,
|
|
68
|
-
shouldSetDestination,
|
|
69
|
-
shouldUpdateSource,
|
|
70
|
-
shouldUpdateDestination,
|
|
71
|
-
}: MaybeMeasureAndStoreParams = {}) => {
|
|
70
|
+
({ intent }: MaybeMeasureAndStoreParams = {}) => {
|
|
72
71
|
"worklet";
|
|
73
72
|
if (!enabled) return;
|
|
74
73
|
|
|
74
|
+
const intents = getMeasurementIntentFlags(intent);
|
|
75
|
+
|
|
75
76
|
const expectedSourceScreenKey: string | undefined =
|
|
76
77
|
resolvePendingSourceKey(sharedBoundTag, preferredSourceScreenKey) ||
|
|
77
78
|
undefined;
|
|
78
79
|
|
|
79
|
-
if (
|
|
80
|
+
if (intents.captureSource && isAnimating.get()) {
|
|
80
81
|
const existing = BoundStore.getSnapshot(
|
|
81
82
|
sharedBoundTag,
|
|
82
83
|
currentScreenKey,
|
|
@@ -115,18 +116,14 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
115
116
|
currentScreenKey,
|
|
116
117
|
);
|
|
117
118
|
|
|
118
|
-
const
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
119
|
+
const writePlan = resolveMeasurementWritePlan({
|
|
120
|
+
intents,
|
|
121
|
+
hasPendingLink,
|
|
122
|
+
hasSourceLink,
|
|
123
|
+
hasDestinationLink,
|
|
124
|
+
});
|
|
123
125
|
|
|
124
|
-
if (
|
|
125
|
-
!canSetSource &&
|
|
126
|
-
!canSetDestination &&
|
|
127
|
-
!canUpdateSource &&
|
|
128
|
-
!canUpdateDestination
|
|
129
|
-
) {
|
|
126
|
+
if (!writePlan.writesAny) {
|
|
130
127
|
return;
|
|
131
128
|
}
|
|
132
129
|
|
|
@@ -137,14 +134,17 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
137
134
|
? layoutAnchor.correctMeasurement(measured)
|
|
138
135
|
: measured;
|
|
139
136
|
|
|
140
|
-
const wantsDestinationWrite = canSetDestination || canUpdateDestination;
|
|
141
137
|
const destinationInViewport =
|
|
142
|
-
!wantsDestinationWrite ||
|
|
138
|
+
!writePlan.wantsDestinationWrite ||
|
|
143
139
|
!layoutAnchor ||
|
|
144
140
|
!layoutAnchor.isMeasurementInViewport ||
|
|
145
141
|
layoutAnchor.isMeasurementInViewport(correctedMeasured);
|
|
146
142
|
|
|
147
|
-
if (
|
|
143
|
+
if (
|
|
144
|
+
!destinationInViewport &&
|
|
145
|
+
!writePlan.captureSource &&
|
|
146
|
+
!writePlan.refreshSource
|
|
147
|
+
) {
|
|
148
148
|
return;
|
|
149
149
|
}
|
|
150
150
|
|
|
@@ -155,6 +155,13 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
155
155
|
const hasSnapshotChanged =
|
|
156
156
|
!existingSnapshot ||
|
|
157
157
|
!areMeasurementsEqual(existingSnapshot.bounds, correctedMeasured);
|
|
158
|
+
const shouldWriteSnapshot =
|
|
159
|
+
hasSnapshotChanged &&
|
|
160
|
+
(writePlan.registerSnapshot ||
|
|
161
|
+
writePlan.captureSource ||
|
|
162
|
+
writePlan.completeDestination ||
|
|
163
|
+
writePlan.refreshSource ||
|
|
164
|
+
writePlan.refreshDestination);
|
|
158
165
|
|
|
159
166
|
applyMeasuredBoundsWrites({
|
|
160
167
|
sharedBoundTag,
|
|
@@ -165,12 +172,15 @@ export const useBoundaryMeasureAndStore = (params: {
|
|
|
165
172
|
navigatorKey,
|
|
166
173
|
ancestorNavigatorKeys,
|
|
167
174
|
expectedSourceScreenKey,
|
|
168
|
-
shouldRegisterSnapshot:
|
|
169
|
-
shouldSetSource:
|
|
170
|
-
shouldUpdateSource:
|
|
175
|
+
shouldRegisterSnapshot: shouldWriteSnapshot,
|
|
176
|
+
shouldSetSource: writePlan.captureSource,
|
|
177
|
+
shouldUpdateSource: writePlan.refreshSource && hasSnapshotChanged,
|
|
171
178
|
shouldUpdateDestination:
|
|
172
|
-
|
|
173
|
-
|
|
179
|
+
writePlan.refreshDestination &&
|
|
180
|
+
destinationInViewport &&
|
|
181
|
+
hasSnapshotChanged,
|
|
182
|
+
shouldSetDestination:
|
|
183
|
+
writePlan.completeDestination && destinationInViewport,
|
|
174
184
|
});
|
|
175
185
|
},
|
|
176
186
|
);
|
package/src/shared/components/create-boundary-component/hooks/use-deferred-measurement-trigger.ts
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { useCallback } from "react";
|
|
2
|
+
import {
|
|
3
|
+
type SharedValue,
|
|
4
|
+
useAnimatedReaction,
|
|
5
|
+
useSharedValue,
|
|
6
|
+
} from "react-native-reanimated";
|
|
7
|
+
|
|
8
|
+
export const useDeferredMeasurementTrigger = (params: {
|
|
9
|
+
enabled: boolean;
|
|
10
|
+
isAnimating: SharedValue<number>;
|
|
11
|
+
canFlush?: () => boolean;
|
|
12
|
+
onFlush: () => void;
|
|
13
|
+
}) => {
|
|
14
|
+
const { enabled, isAnimating, canFlush, onFlush } = params;
|
|
15
|
+
const hasPendingMeasurement = useSharedValue(false);
|
|
16
|
+
|
|
17
|
+
const clearPendingMeasurement = useCallback(() => {
|
|
18
|
+
"worklet";
|
|
19
|
+
hasPendingMeasurement.value = false;
|
|
20
|
+
}, [hasPendingMeasurement]);
|
|
21
|
+
|
|
22
|
+
const queueOrFlushMeasurement = useCallback(() => {
|
|
23
|
+
"worklet";
|
|
24
|
+
if (!enabled) return;
|
|
25
|
+
|
|
26
|
+
if (isAnimating.value) {
|
|
27
|
+
hasPendingMeasurement.value = true;
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
hasPendingMeasurement.value = false;
|
|
32
|
+
onFlush();
|
|
33
|
+
}, [enabled, isAnimating, hasPendingMeasurement, onFlush]);
|
|
34
|
+
|
|
35
|
+
useAnimatedReaction(
|
|
36
|
+
() => {
|
|
37
|
+
"worklet";
|
|
38
|
+
if (!enabled) return false;
|
|
39
|
+
if (!hasPendingMeasurement.value) return false;
|
|
40
|
+
if (isAnimating.value) return false;
|
|
41
|
+
return canFlush ? canFlush() : true;
|
|
42
|
+
},
|
|
43
|
+
(shouldFlush, previousShouldFlush) => {
|
|
44
|
+
"worklet";
|
|
45
|
+
if (!enabled) return;
|
|
46
|
+
if (!shouldFlush || shouldFlush === previousShouldFlush) return;
|
|
47
|
+
|
|
48
|
+
hasPendingMeasurement.value = false;
|
|
49
|
+
onFlush();
|
|
50
|
+
},
|
|
51
|
+
[enabled, isAnimating, hasPendingMeasurement, canFlush, onFlush],
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
return {
|
|
55
|
+
clearPendingMeasurement,
|
|
56
|
+
queueOrFlushMeasurement,
|
|
57
|
+
};
|
|
58
|
+
};
|
package/src/shared/components/create-boundary-component/hooks/use-group-active-measurement.ts
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
|
-
import { useAnimatedReaction } from "react-native-reanimated";
|
|
2
|
-
import type { AnimationStore } from "../../../stores/animation.store";
|
|
1
|
+
import { type SharedValue, useAnimatedReaction } from "react-native-reanimated";
|
|
3
2
|
import { BoundStore } from "../../../stores/bounds";
|
|
4
3
|
import type { BoundaryId, MaybeMeasureAndStoreParams } from "../types";
|
|
4
|
+
import {
|
|
5
|
+
canFlushGroupActiveMeasurement,
|
|
6
|
+
resolveGroupActiveMeasurementAction,
|
|
7
|
+
} from "./helpers/measurement-rules";
|
|
8
|
+
import { useDeferredMeasurementTrigger } from "./use-deferred-measurement-trigger";
|
|
5
9
|
|
|
6
10
|
/**
|
|
7
11
|
* Watches the group's active id in the BoundStore.
|
|
@@ -15,7 +19,7 @@ export const useGroupActiveMeasurement = (params: {
|
|
|
15
19
|
group: string | undefined;
|
|
16
20
|
id: BoundaryId;
|
|
17
21
|
shouldUpdateDestination: boolean;
|
|
18
|
-
isAnimating:
|
|
22
|
+
isAnimating: SharedValue<number>;
|
|
19
23
|
maybeMeasureAndStore: (options: MaybeMeasureAndStoreParams) => void;
|
|
20
24
|
}) => {
|
|
21
25
|
const {
|
|
@@ -29,6 +33,24 @@ export const useGroupActiveMeasurement = (params: {
|
|
|
29
33
|
const idStr = String(id);
|
|
30
34
|
|
|
31
35
|
const allGroups = BoundStore.getGroups();
|
|
36
|
+
const { clearPendingMeasurement, queueOrFlushMeasurement } =
|
|
37
|
+
useDeferredMeasurementTrigger({
|
|
38
|
+
enabled,
|
|
39
|
+
isAnimating,
|
|
40
|
+
canFlush: () => {
|
|
41
|
+
"worklet";
|
|
42
|
+
return canFlushGroupActiveMeasurement({
|
|
43
|
+
enabled,
|
|
44
|
+
isEligible: !!group && shouldUpdateDestination,
|
|
45
|
+
memberId: idStr,
|
|
46
|
+
activeId: group ? (allGroups.value[group]?.activeId ?? null) : null,
|
|
47
|
+
});
|
|
48
|
+
},
|
|
49
|
+
onFlush: () => {
|
|
50
|
+
"worklet";
|
|
51
|
+
maybeMeasureAndStore({ intent: "refresh-destination" });
|
|
52
|
+
},
|
|
53
|
+
});
|
|
32
54
|
|
|
33
55
|
useAnimatedReaction(
|
|
34
56
|
() => {
|
|
@@ -39,12 +61,21 @@ export const useGroupActiveMeasurement = (params: {
|
|
|
39
61
|
},
|
|
40
62
|
(activeId, previousActiveId) => {
|
|
41
63
|
"worklet";
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
64
|
+
const action = resolveGroupActiveMeasurementAction({
|
|
65
|
+
enabled,
|
|
66
|
+
isEligible: !!group && shouldUpdateDestination,
|
|
67
|
+
memberId: idStr,
|
|
68
|
+
activeId,
|
|
69
|
+
previousActiveId,
|
|
70
|
+
});
|
|
45
71
|
|
|
46
|
-
if (
|
|
47
|
-
|
|
72
|
+
if (action === "clear-pending") {
|
|
73
|
+
clearPendingMeasurement();
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
if (action === "queue-or-flush") {
|
|
78
|
+
queueOrFlushMeasurement();
|
|
48
79
|
}
|
|
49
80
|
},
|
|
50
81
|
[
|
|
@@ -52,8 +83,8 @@ export const useGroupActiveMeasurement = (params: {
|
|
|
52
83
|
group,
|
|
53
84
|
idStr,
|
|
54
85
|
shouldUpdateDestination,
|
|
55
|
-
|
|
56
|
-
|
|
86
|
+
clearPendingMeasurement,
|
|
87
|
+
queueOrFlushMeasurement,
|
|
57
88
|
],
|
|
58
89
|
);
|
|
59
90
|
};
|