react-native-screen-transitions 3.7.1 → 3.8.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/commonjs/blank-stack/components/stack-view.js +2 -2
- package/lib/commonjs/blank-stack/components/stack-view.js.map +1 -1
- package/lib/commonjs/component-stack/components/stack-view.js +2 -2
- package/lib/commonjs/component-stack/components/stack-view.js.map +1 -1
- package/lib/commonjs/shared/adapters/with-screen-transitions/stack-layout.js +1 -10
- package/lib/commonjs/shared/adapters/with-screen-transitions/stack-layout.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-measurer.js +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-measurer.js.map +1 -1
- package/lib/commonjs/shared/components/create-transition-aware-component.js +7 -5
- package/lib/commonjs/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/commonjs/shared/components/overlay/variations/float-overlay.js +7 -12
- package/lib/commonjs/shared/components/overlay/variations/float-overlay.js.map +1 -1
- package/lib/commonjs/shared/components/scene-view.js +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js +7 -7
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js.map +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-transition-start-controller.js +2 -2
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-transition-start-controller.js.map +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/index.js +2 -2
- package/lib/commonjs/shared/components/screen-lifecycle/index.js.map +1 -1
- package/lib/commonjs/shared/constants.js +3 -13
- package/lib/commonjs/shared/constants.js.map +1 -1
- package/lib/commonjs/shared/hooks/navigation/use-screen-state.js +1 -3
- package/lib/commonjs/shared/hooks/navigation/use-screen-state.js.map +1 -1
- package/lib/commonjs/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.js +15 -12
- package/lib/commonjs/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/build-screen-transition-options.js +2 -6
- package/lib/commonjs/shared/providers/screen/animation/helpers/build-screen-transition-options.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state/gesture-progress.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state/index.js +7 -23
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state/index.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/selected-interpolator-options.js +14 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/selected-interpolator-options.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/use-build-transition-state.js +3 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/use-build-transition-state.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/gestures.provider.js +22 -9
- package/lib/commonjs/shared/providers/screen/gestures/gestures.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/compute-claimed-directions.js +2 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/compute-claimed-directions.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-activation-decision.js → activation/pan-activation-decision.js} +12 -6
- package/lib/commonjs/shared/providers/screen/gestures/pan/activation/pan-activation-decision.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-activation-rules.js → activation/pan-activation-rules.js} +12 -9
- package/lib/commonjs/shared/providers/screen/gestures/pan/activation/pan-activation-rules.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-activation.js → activation/use-pan-activation.js} +15 -10
- package/lib/commonjs/shared/providers/screen/gestures/pan/activation/use-pan-activation.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-lifecycle.js → behavior/pan-lifecycle.js} +29 -8
- package/lib/commonjs/shared/providers/screen/gestures/pan/behavior/pan-lifecycle.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-release.js → behavior/pan-release.js} +5 -5
- package/lib/commonjs/shared/providers/screen/gestures/pan/behavior/pan-release.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{pan-reset.js → behavior/pan-reset.js} +21 -11
- package/lib/commonjs/shared/providers/screen/gestures/pan/behavior/pan-reset.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{use-pan-behavior.js → behavior/use-pan-behavior.js} +34 -8
- package/lib/commonjs/shared/providers/screen/gestures/pan/behavior/use-pan-behavior.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pan/{build-pan-gesture.js → use-build-pan-gesture.js} +10 -8
- package/lib/commonjs/shared/providers/screen/gestures/pan/use-build-pan-gesture.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{pinch-activation.js → activation/use-pinch-activation.js} +12 -5
- package/lib/commonjs/shared/providers/screen/gestures/pinch/activation/use-pinch-activation.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{pinch-lifecycle.js → behavior/pinch-lifecycle.js} +7 -7
- package/lib/commonjs/shared/providers/screen/gestures/pinch/behavior/pinch-lifecycle.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{pinch-release.js → behavior/pinch-release.js} +4 -4
- package/lib/commonjs/shared/providers/screen/gestures/pinch/behavior/pinch-release.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{pinch-reset.js → behavior/pinch-reset.js} +6 -3
- package/lib/commonjs/shared/providers/screen/gestures/pinch/behavior/pinch-reset.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{use-pinch-behavior.js → behavior/use-pinch-behavior.js} +6 -5
- package/lib/commonjs/shared/providers/screen/gestures/pinch/behavior/use-pinch-behavior.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/pinch/{build-pinch-gesture.js → use-build-pinch-gesture.js} +9 -7
- package/lib/commonjs/shared/providers/screen/gestures/pinch/use-build-pinch-gesture.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.js +62 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.js +21 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.js +29 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.js +45 -0
- package/lib/commonjs/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/index.js +7 -0
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/index.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.js +40 -0
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.js +51 -13
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.js +74 -6
- package/lib/commonjs/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/directions.js +17 -5
- package/lib/commonjs/shared/providers/screen/gestures/shared/directions.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/policy.js +67 -2
- package/lib/commonjs/shared/providers/screen/gestures/shared/policy.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/reset.js +3 -12
- package/lib/commonjs/shared/providers/screen/gestures/shared/reset.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/runtime.js +1 -10
- package/lib/commonjs/shared/providers/screen/gestures/shared/runtime.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/snap-points.js +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/shared/snap-points.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/types.js +2 -0
- package/lib/commonjs/shared/providers/screen/gestures/types.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/options/helpers.js +60 -24
- package/lib/commonjs/shared/providers/screen/options/helpers.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/styles/components/{maybe-floating-container.js → floating-overlay-layer.js} +5 -5
- package/lib/commonjs/shared/providers/screen/styles/components/floating-overlay-layer.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/styles/styles.provider.js +3 -3
- package/lib/commonjs/shared/providers/screen/styles/styles.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state/managed-stack-controller.js → blank-stack-state/blank-stack-controller.js} +11 -11
- package/lib/commonjs/shared/providers/stack/blank-stack-state/blank-stack-controller.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state/helpers/build-managed-stack-state.js → blank-stack-state/helpers/build-blank-stack-state.js} +18 -18
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/build-blank-stack-state.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/derive-blank-stack-state.js +58 -0
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/derive-blank-stack-state.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/navigation/compose-descriptors.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/navigation/resolve-scene-neighbors.js.map +1 -0
- package/lib/commonjs/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/sync-routes-with-removed.js +6 -23
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/navigation/sync-routes-with-removed.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state/helpers/reconcile-managed-routes.js → blank-stack-state/helpers/reconcile-blank-stack-routes.js} +8 -8
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state/helpers/reconcile-managed-routes.js.map → blank-stack-state/helpers/reconcile-blank-stack-routes.js.map} +1 -1
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state/helpers/helpers.js → blank-stack-state/helpers/state-equality.js} +1 -1
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/state-equality.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/blank-stack-state/helpers/types.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/index.js +5 -5
- package/lib/commonjs/shared/providers/stack/blank-stack-state/index.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/{managed.provider.js → blank-stack.provider.js} +20 -27
- package/lib/commonjs/shared/providers/stack/blank-stack.provider.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/direct.provider.js +3 -13
- package/lib/commonjs/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/commonjs/shared/stores/animation.store.js +2 -0
- package/lib/commonjs/shared/stores/animation.store.js.map +1 -1
- package/lib/commonjs/shared/stores/gesture.store.js +5 -1
- package/lib/commonjs/shared/stores/gesture.store.js.map +1 -1
- package/lib/commonjs/shared/stores/scroll.store.js +49 -5
- package/lib/commonjs/shared/stores/scroll.store.js.map +1 -1
- package/lib/commonjs/shared/stores/system.store.js +1 -4
- package/lib/commonjs/shared/stores/system.store.js.map +1 -1
- package/lib/commonjs/shared/types/animation.types.js.map +1 -1
- package/lib/commonjs/shared/types/gesture.types.js +12 -0
- package/lib/commonjs/shared/types/gesture.types.js.map +1 -1
- package/lib/commonjs/shared/types/providers/blank-stack-provider.types.js +6 -0
- package/lib/commonjs/shared/types/providers/blank-stack-provider.types.js.map +1 -0
- package/lib/commonjs/shared/utils/animation/animate-to-progress.js +10 -4
- package/lib/commonjs/shared/utils/animation/animate-to-progress.js.map +1 -1
- package/lib/commonjs/shared/utils/animation/animate.js +22 -5
- package/lib/commonjs/shared/utils/animation/animate.js.map +1 -1
- package/lib/commonjs/shared/utils/animation/spring/index.js +13 -0
- package/lib/commonjs/shared/utils/animation/spring/index.js.map +1 -0
- package/lib/commonjs/shared/utils/animation/spring/spring.js +248 -0
- package/lib/commonjs/shared/utils/animation/spring/spring.js.map +1 -0
- package/lib/commonjs/shared/{types/providers/managed-stack.types.js → utils/animation/spring/springConfigs.js} +1 -1
- package/lib/commonjs/shared/utils/animation/spring/springConfigs.js.map +1 -0
- package/lib/commonjs/shared/utils/animation/spring/springUtils.js +313 -0
- package/lib/commonjs/shared/utils/animation/spring/springUtils.js.map +1 -0
- package/lib/commonjs/shared/utils/animation/state.js +2 -0
- package/lib/commonjs/shared/utils/animation/state.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/navigation/reveal/build.js +5 -5
- package/lib/commonjs/shared/utils/bounds/navigation/reveal/build.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/navigation/zoom/build.js +4 -4
- package/lib/commonjs/shared/utils/bounds/navigation/zoom/build.js.map +1 -1
- package/lib/module/blank-stack/components/stack-view.js +2 -2
- package/lib/module/blank-stack/components/stack-view.js.map +1 -1
- package/lib/module/component-stack/components/stack-view.js +2 -2
- package/lib/module/component-stack/components/stack-view.js.map +1 -1
- package/lib/module/shared/adapters/with-screen-transitions/stack-layout.js +1 -10
- package/lib/module/shared/adapters/with-screen-transitions/stack-layout.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-measurer.js +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-measurer.js.map +1 -1
- package/lib/module/shared/components/create-transition-aware-component.js +8 -6
- package/lib/module/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/module/shared/components/overlay/variations/float-overlay.js +7 -12
- package/lib/module/shared/components/overlay/variations/float-overlay.js.map +1 -1
- package/lib/module/shared/components/scene-view.js +1 -1
- package/lib/module/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js +7 -7
- package/lib/module/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js.map +1 -1
- package/lib/module/shared/components/screen-lifecycle/hooks/use-transition-start-controller.js +2 -2
- package/lib/module/shared/components/screen-lifecycle/hooks/use-transition-start-controller.js.map +1 -1
- package/lib/module/shared/components/screen-lifecycle/index.js +2 -2
- package/lib/module/shared/components/screen-lifecycle/index.js.map +1 -1
- package/lib/module/shared/constants.js +2 -12
- package/lib/module/shared/constants.js.map +1 -1
- package/lib/module/shared/hooks/navigation/use-screen-state.js +1 -3
- package/lib/module/shared/hooks/navigation/use-screen-state.js.map +1 -1
- package/lib/module/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.js +15 -12
- package/lib/module/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/build-screen-transition-options.js +2 -6
- package/lib/module/shared/providers/screen/animation/helpers/build-screen-transition-options.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state/gesture-progress.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state/index.js +8 -24
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state/index.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/selected-interpolator-options.js +14 -1
- package/lib/module/shared/providers/screen/animation/helpers/selected-interpolator-options.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/use-build-transition-state.js +3 -1
- package/lib/module/shared/providers/screen/animation/helpers/use-build-transition-state.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/gestures.provider.js +20 -7
- package/lib/module/shared/providers/screen/gestures/gestures.provider.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/ownership/compute-claimed-directions.js +2 -1
- package/lib/module/shared/providers/screen/gestures/ownership/compute-claimed-directions.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/pan/{pan-activation-decision.js → activation/pan-activation-decision.js} +12 -6
- package/lib/module/shared/providers/screen/gestures/pan/activation/pan-activation-decision.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{pan-activation-rules.js → activation/pan-activation-rules.js} +12 -9
- package/lib/module/shared/providers/screen/gestures/pan/activation/pan-activation-rules.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{pan-activation.js → activation/use-pan-activation.js} +15 -10
- package/lib/module/shared/providers/screen/gestures/pan/activation/use-pan-activation.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{pan-lifecycle.js → behavior/pan-lifecycle.js} +29 -8
- package/lib/module/shared/providers/screen/gestures/pan/behavior/pan-lifecycle.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{pan-release.js → behavior/pan-release.js} +5 -5
- package/lib/module/shared/providers/screen/gestures/pan/behavior/pan-release.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{pan-reset.js → behavior/pan-reset.js} +21 -11
- package/lib/module/shared/providers/screen/gestures/pan/behavior/pan-reset.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/behavior/use-pan-behavior.js +75 -0
- package/lib/module/shared/providers/screen/gestures/pan/behavior/use-pan-behavior.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pan/{build-pan-gesture.js → use-build-pan-gesture.js} +9 -7
- package/lib/module/shared/providers/screen/gestures/pan/use-build-pan-gesture.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{pinch-activation.js → activation/use-pinch-activation.js} +12 -5
- package/lib/module/shared/providers/screen/gestures/pinch/activation/use-pinch-activation.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{pinch-lifecycle.js → behavior/pinch-lifecycle.js} +7 -7
- package/lib/module/shared/providers/screen/gestures/pinch/behavior/pinch-lifecycle.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{pinch-release.js → behavior/pinch-release.js} +4 -4
- package/lib/module/shared/providers/screen/gestures/pinch/behavior/pinch-release.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{pinch-reset.js → behavior/pinch-reset.js} +6 -3
- package/lib/module/shared/providers/screen/gestures/pinch/behavior/pinch-reset.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{use-pinch-behavior.js → behavior/use-pinch-behavior.js} +6 -5
- package/lib/module/shared/providers/screen/gestures/pinch/behavior/use-pinch-behavior.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/pinch/{build-pinch-gesture.js → use-build-pinch-gesture.js} +8 -6
- package/lib/module/shared/providers/screen/gestures/pinch/use-build-pinch-gesture.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.js +57 -0
- package/lib/module/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.js +15 -0
- package/lib/module/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.js +24 -0
- package/lib/module/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.js +40 -0
- package/lib/module/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/index.js +1 -0
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/index.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.js +33 -0
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.js.map +1 -0
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.js +48 -12
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.js +76 -8
- package/lib/module/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/directions.js +14 -4
- package/lib/module/shared/providers/screen/gestures/shared/directions.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/policy.js +68 -3
- package/lib/module/shared/providers/screen/gestures/shared/policy.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/reset.js +4 -13
- package/lib/module/shared/providers/screen/gestures/shared/reset.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/runtime.js +1 -10
- package/lib/module/shared/providers/screen/gestures/shared/runtime.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/snap-points.js +1 -1
- package/lib/module/shared/providers/screen/gestures/shared/snap-points.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/types.js +2 -0
- package/lib/module/shared/providers/screen/gestures/types.js.map +1 -1
- package/lib/module/shared/providers/screen/options/helpers.js +60 -24
- package/lib/module/shared/providers/screen/options/helpers.js.map +1 -1
- package/lib/module/shared/providers/screen/styles/components/{maybe-floating-container.js → floating-overlay-layer.js} +4 -4
- package/lib/module/shared/providers/screen/styles/components/floating-overlay-layer.js.map +1 -0
- package/lib/module/shared/providers/screen/styles/styles.provider.js +3 -3
- package/lib/module/shared/providers/screen/styles/styles.provider.js.map +1 -1
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state/managed-stack-controller.js → blank-stack-state/blank-stack-controller.js} +9 -9
- package/lib/module/shared/providers/stack/blank-stack-state/blank-stack-controller.js.map +1 -0
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state/helpers/build-managed-stack-state.js → blank-stack-state/helpers/build-blank-stack-state.js} +10 -10
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/build-blank-stack-state.js.map +1 -0
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state/helpers/derive-managed-stack-state.js → blank-stack-state/helpers/derive-blank-stack-state.js} +7 -7
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/derive-blank-stack-state.js.map +1 -0
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/navigation/compose-descriptors.js.map +1 -0
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/navigation/resolve-scene-neighbors.js.map +1 -0
- package/lib/module/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/sync-routes-with-removed.js +6 -23
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/navigation/sync-routes-with-removed.js.map +1 -0
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state/helpers/reconcile-managed-routes.js → blank-stack-state/helpers/reconcile-blank-stack-routes.js} +5 -5
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/reconcile-blank-stack-routes.js.map +1 -0
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state/helpers/helpers.js → blank-stack-state/helpers/state-equality.js} +1 -1
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/state-equality.js.map +1 -0
- package/lib/module/shared/providers/stack/blank-stack-state/helpers/types.js.map +1 -0
- package/lib/module/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/index.js +3 -3
- package/lib/module/shared/providers/stack/blank-stack-state/index.js.map +1 -0
- package/lib/module/shared/providers/stack/{managed.provider.js → blank-stack.provider.js} +19 -26
- package/lib/module/shared/providers/stack/blank-stack.provider.js.map +1 -0
- package/lib/module/shared/providers/stack/direct.provider.js +3 -13
- package/lib/module/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/module/shared/stores/animation.store.js +2 -0
- package/lib/module/shared/stores/animation.store.js.map +1 -1
- package/lib/module/shared/stores/gesture.store.js +5 -1
- package/lib/module/shared/stores/gesture.store.js.map +1 -1
- package/lib/module/shared/stores/scroll.store.js +49 -5
- package/lib/module/shared/stores/scroll.store.js.map +1 -1
- package/lib/module/shared/stores/system.store.js +1 -4
- package/lib/module/shared/stores/system.store.js.map +1 -1
- package/lib/module/shared/types/animation.types.js.map +1 -1
- package/lib/module/shared/types/gesture.types.js +16 -0
- package/lib/module/shared/types/gesture.types.js.map +1 -1
- package/lib/module/shared/types/providers/blank-stack-provider.types.js +4 -0
- package/lib/module/shared/types/providers/blank-stack-provider.types.js.map +1 -0
- package/lib/module/shared/utils/animation/animate-to-progress.js +11 -5
- package/lib/module/shared/utils/animation/animate-to-progress.js.map +1 -1
- package/lib/module/shared/utils/animation/animate.js +21 -5
- package/lib/module/shared/utils/animation/animate.js.map +1 -1
- package/lib/module/shared/utils/animation/spring/index.js +4 -0
- package/lib/module/shared/utils/animation/spring/index.js.map +1 -0
- package/lib/module/shared/utils/animation/spring/spring.js +243 -0
- package/lib/module/shared/utils/animation/spring/spring.js.map +1 -0
- package/lib/module/shared/utils/animation/spring/springConfigs.js +4 -0
- package/lib/module/shared/utils/animation/spring/springConfigs.js.map +1 -0
- package/lib/module/shared/utils/animation/spring/springUtils.js +300 -0
- package/lib/module/shared/utils/animation/spring/springUtils.js.map +1 -0
- package/lib/module/shared/utils/animation/state.js +2 -0
- package/lib/module/shared/utils/animation/state.js.map +1 -0
- package/lib/module/shared/utils/bounds/navigation/reveal/build.js +5 -5
- package/lib/module/shared/utils/bounds/navigation/reveal/build.js.map +1 -1
- package/lib/module/shared/utils/bounds/navigation/zoom/build.js +4 -4
- package/lib/module/shared/utils/bounds/navigation/zoom/build.js.map +1 -1
- package/lib/typescript/blank-stack/components/stack-view.d.ts +1 -1
- package/lib/typescript/blank-stack/components/stack-view.d.ts.map +1 -1
- package/lib/typescript/component-stack/components/stack-view.d.ts +1 -1
- package/lib/typescript/component-stack/components/stack-view.d.ts.map +1 -1
- package/lib/typescript/shared/adapters/with-screen-transitions/stack-layout.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-transition-aware-component.d.ts.map +1 -1
- package/lib/typescript/shared/components/overlay/variations/float-overlay.d.ts.map +1 -1
- package/lib/typescript/shared/components/scene-view.d.ts +1 -1
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-close-transition-intent.d.ts +1 -1
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-close-transition-intent.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-transition-start-controller.d.ts +2 -2
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-transition-start-controller.d.ts.map +1 -1
- package/lib/typescript/shared/constants.d.ts +0 -9
- package/lib/typescript/shared/constants.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/navigation/use-screen-state.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts +0 -2
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts.map +1 -1
- package/lib/typescript/shared/index.d.ts +13 -13
- package/lib/typescript/shared/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/build-screen-transition-options.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state/types.d.ts +3 -6
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state/types.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/selected-interpolator-options.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/use-build-transition-state.d.ts +3 -2
- package/lib/typescript/shared/providers/screen/animation/helpers/use-build-transition-state.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/gestures.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/ownership/compute-claimed-directions.d.ts +2 -2
- package/lib/typescript/shared/providers/screen/gestures/ownership/compute-claimed-directions.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-activation-decision.d.ts → activation/pan-activation-decision.d.ts} +3 -3
- package/lib/typescript/shared/providers/screen/gestures/pan/activation/pan-activation-decision.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-activation-rules.d.ts → activation/pan-activation-rules.d.ts} +11 -11
- package/lib/typescript/shared/providers/screen/gestures/pan/activation/pan-activation-rules.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-activation.d.ts → activation/use-pan-activation.d.ts} +5 -4
- package/lib/typescript/shared/providers/screen/gestures/pan/activation/use-pan-activation.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-lifecycle.d.ts → behavior/pan-lifecycle.d.ts} +3 -2
- package/lib/typescript/shared/providers/screen/gestures/pan/behavior/pan-lifecycle.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-release.d.ts → behavior/pan-release.d.ts} +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/behavior/pan-release.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/{pan-reset.d.ts → behavior/pan-reset.d.ts} +4 -3
- package/lib/typescript/shared/providers/screen/gestures/pan/behavior/pan-reset.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/behavior/use-pan-behavior.d.ts +5 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/behavior/use-pan-behavior.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/use-build-pan-gesture.d.ts +11 -0
- package/lib/typescript/shared/providers/screen/gestures/pan/use-build-pan-gesture.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/{pinch-activation.d.ts → activation/use-pinch-activation.d.ts} +5 -4
- package/lib/typescript/shared/providers/screen/gestures/pinch/activation/use-pinch-activation.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/{pinch-lifecycle.d.ts → behavior/pinch-lifecycle.d.ts} +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/behavior/pinch-lifecycle.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/{pinch-release.d.ts → behavior/pinch-release.d.ts} +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/behavior/pinch-release.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/{pinch-reset.d.ts → behavior/pinch-reset.d.ts} +2 -2
- package/lib/typescript/shared/providers/screen/gestures/pinch/behavior/pinch-reset.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/behavior/use-pinch-behavior.d.ts +5 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/behavior/use-pinch-behavior.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/use-build-pinch-gesture.d.ts +9 -0
- package/lib/typescript/shared/providers/screen/gestures/pinch/use-build-pinch-gesture.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.d.ts +15 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.d.ts +4 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.d.ts +5 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.d.ts +9 -0
- package/lib/typescript/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/index.d.ts +1 -0
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.d.ts +12 -0
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.d.ts +5 -1
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.d.ts +4 -0
- package/lib/typescript/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/shared/directions.d.ts +8 -6
- package/lib/typescript/shared/providers/screen/gestures/shared/directions.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/shared/policy.d.ts +2 -2
- package/lib/typescript/shared/providers/screen/gestures/shared/policy.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/shared/reset.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/shared/runtime.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/types.d.ts +15 -5
- package/lib/typescript/shared/providers/screen/gestures/types.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/options/helpers.d.ts +2 -2
- package/lib/typescript/shared/providers/screen/options/helpers.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/options/types.d.ts +4 -3
- package/lib/typescript/shared/providers/screen/options/types.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/styles/components/floating-overlay-layer.d.ts +7 -0
- package/lib/typescript/shared/providers/screen/styles/components/floating-overlay-layer.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/blank-stack-controller.d.ts +13 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/blank-stack-controller.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/build-blank-stack-state.d.ts +13 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/build-blank-stack-state.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/derive-blank-stack-state.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/derive-blank-stack-state.d.ts.map +1 -0
- package/lib/typescript/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/compose-descriptors.d.ts +1 -1
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/navigation/compose-descriptors.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/navigation/resolve-scene-neighbors.d.ts.map +1 -0
- package/lib/typescript/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/sync-routes-with-removed.d.ts +2 -4
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/navigation/sync-routes-with-removed.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/reconcile-blank-stack-routes.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/reconcile-blank-stack-routes.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/{helpers/managed-stack-state/helpers/helpers.d.ts → blank-stack-state/helpers/state-equality.d.ts} +4 -4
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/state-equality.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/types.d.ts +39 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/helpers/types.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/index.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/blank-stack-state/index.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/blank-stack.provider.d.ts +8 -0
- package/lib/typescript/shared/providers/stack/blank-stack.provider.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/direct.provider.d.ts.map +1 -1
- package/lib/typescript/shared/stores/animation.store.d.ts +1 -0
- package/lib/typescript/shared/stores/animation.store.d.ts.map +1 -1
- package/lib/typescript/shared/stores/gesture.store.d.ts +2 -0
- package/lib/typescript/shared/stores/gesture.store.d.ts.map +1 -1
- package/lib/typescript/shared/stores/scroll.store.d.ts +15 -8
- package/lib/typescript/shared/stores/scroll.store.d.ts.map +1 -1
- package/lib/typescript/shared/stores/system.store.d.ts +1 -5
- package/lib/typescript/shared/stores/system.store.d.ts.map +1 -1
- package/lib/typescript/shared/types/animation.types.d.ts +12 -10
- package/lib/typescript/shared/types/animation.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/bounds.types.d.ts +1 -1
- package/lib/typescript/shared/types/gesture.types.d.ts +41 -1
- package/lib/typescript/shared/types/gesture.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/index.d.ts +1 -1
- package/lib/typescript/shared/types/index.d.ts.map +1 -1
- package/lib/typescript/shared/types/providers/{managed-stack.types.d.ts → blank-stack-provider.types.d.ts} +11 -11
- package/lib/typescript/shared/types/providers/blank-stack-provider.types.d.ts.map +1 -0
- package/lib/typescript/shared/types/screen.types.d.ts +14 -2
- 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/animation/animate.d.ts +8 -3
- package/lib/typescript/shared/utils/animation/animate.d.ts.map +1 -1
- package/lib/typescript/shared/utils/animation/spring/index.d.ts +3 -0
- package/lib/typescript/shared/utils/animation/spring/index.d.ts.map +1 -0
- package/lib/typescript/shared/utils/animation/spring/spring.d.ts +24 -0
- package/lib/typescript/shared/utils/animation/spring/spring.d.ts.map +1 -0
- package/lib/typescript/shared/utils/animation/spring/springConfigs.d.ts +46 -0
- package/lib/typescript/shared/utils/animation/spring/springConfigs.d.ts.map +1 -0
- package/lib/typescript/shared/utils/animation/spring/springUtils.d.ts +68 -0
- package/lib/typescript/shared/utils/animation/spring/springUtils.d.ts.map +1 -0
- package/lib/typescript/shared/utils/animation/state.d.ts +6 -0
- package/lib/typescript/shared/utils/animation/state.d.ts.map +1 -0
- package/lib/typescript/shared/utils/bounds/navigation/reveal/build.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/navigation/zoom/build.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/blank-stack/components/stack-view.tsx +2 -2
- package/src/component-stack/components/stack-view.tsx +2 -2
- package/src/shared/adapters/with-screen-transitions/stack-layout.tsx +0 -14
- package/src/shared/components/create-boundary-component/hooks/use-measurer.ts +1 -1
- package/src/shared/components/create-transition-aware-component.tsx +14 -6
- package/src/shared/components/overlay/variations/float-overlay.tsx +6 -18
- package/src/shared/components/scene-view.tsx +1 -1
- package/src/shared/components/screen-lifecycle/hooks/use-close-transition-intent.ts +11 -8
- package/src/shared/components/screen-lifecycle/hooks/use-transition-start-controller.ts +4 -4
- package/src/shared/components/screen-lifecycle/index.tsx +2 -2
- package/src/shared/constants.ts +1 -11
- package/src/shared/hooks/navigation/use-screen-state.ts +1 -7
- package/src/shared/hooks/navigation/use-stack.tsx +0 -2
- package/src/shared/index.ts +4 -0
- package/src/shared/providers/screen/animation/helpers/accessors/use-build-transition-accessor.ts +19 -16
- package/src/shared/providers/screen/animation/helpers/build-screen-transition-options.ts +2 -17
- package/src/shared/providers/screen/animation/helpers/hydrate-transition-state/gesture-progress.ts +3 -3
- package/src/shared/providers/screen/animation/helpers/hydrate-transition-state/index.ts +11 -51
- package/src/shared/providers/screen/animation/helpers/hydrate-transition-state/types.ts +3 -7
- package/src/shared/providers/screen/animation/helpers/pipeline.ts +1 -1
- package/src/shared/providers/screen/animation/helpers/selected-interpolator-options.ts +24 -1
- package/src/shared/providers/screen/animation/helpers/use-build-transition-state.ts +6 -5
- package/src/shared/providers/screen/gestures/gestures.provider.tsx +22 -5
- package/src/shared/providers/screen/gestures/ownership/compute-claimed-directions.ts +6 -9
- package/src/shared/providers/screen/gestures/pan/{pan-activation-decision.ts → activation/pan-activation-decision.ts} +17 -8
- package/src/shared/providers/screen/gestures/pan/{pan-activation-rules.ts → activation/pan-activation-rules.ts} +32 -25
- package/src/shared/providers/screen/gestures/pan/{pan-activation.ts → activation/use-pan-activation.ts} +23 -12
- package/src/shared/providers/screen/gestures/pan/{pan-lifecycle.ts → behavior/pan-lifecycle.ts} +46 -8
- package/src/shared/providers/screen/gestures/pan/{pan-release.ts → behavior/pan-release.ts} +6 -6
- package/src/shared/providers/screen/gestures/pan/{pan-reset.ts → behavior/pan-reset.ts} +22 -12
- package/src/shared/providers/screen/gestures/pan/{use-pan-behavior.ts → behavior/use-pan-behavior.ts} +43 -10
- package/src/shared/providers/screen/gestures/pan/{build-pan-gesture.ts → use-build-pan-gesture.ts} +15 -6
- package/src/shared/providers/screen/gestures/pinch/{pinch-activation.ts → activation/use-pinch-activation.ts} +17 -5
- package/src/shared/providers/screen/gestures/pinch/{pinch-lifecycle.ts → behavior/pinch-lifecycle.ts} +10 -8
- package/src/shared/providers/screen/gestures/pinch/{pinch-release.ts → behavior/pinch-release.ts} +5 -5
- package/src/shared/providers/screen/gestures/pinch/{pinch-reset.ts → behavior/pinch-reset.ts} +11 -5
- package/src/shared/providers/screen/gestures/pinch/{use-pinch-behavior.ts → behavior/use-pinch-behavior.ts} +16 -6
- package/src/shared/providers/screen/gestures/pinch/{build-pinch-gesture.ts → use-build-pinch-gesture.ts} +18 -6
- package/src/shared/providers/screen/gestures/rotation/activation/use-rotation-activation.ts +87 -0
- package/src/shared/providers/screen/gestures/rotation/behavior/rotation-lifecycle.ts +19 -0
- package/src/shared/providers/screen/gestures/rotation/behavior/use-rotation-behavior.ts +47 -0
- package/src/shared/providers/screen/gestures/rotation/use-build-rotation-gesture.ts +55 -0
- package/src/shared/providers/screen/gestures/scroll-coordination/index.ts +1 -0
- package/src/shared/providers/screen/gestures/scroll-coordination/scroll-metadata-owner.tsx +43 -0
- package/src/shared/providers/screen/gestures/scroll-coordination/update-scroll-gesture-state.ts +59 -4
- package/src/shared/providers/screen/gestures/scroll-coordination/use-scroll-gesture-coordination.ts +130 -8
- package/src/shared/providers/screen/gestures/shared/directions.ts +27 -13
- package/src/shared/providers/screen/gestures/shared/policy.ts +99 -5
- package/src/shared/providers/screen/gestures/shared/reset.ts +9 -17
- package/src/shared/providers/screen/gestures/shared/runtime.ts +1 -14
- package/src/shared/providers/screen/gestures/shared/snap-points.ts +1 -1
- package/src/shared/providers/screen/gestures/types.ts +22 -3
- package/src/shared/providers/screen/options/helpers.ts +85 -30
- package/src/shared/providers/screen/options/types.ts +6 -5
- package/src/shared/providers/screen/styles/components/{maybe-floating-container.tsx → floating-overlay-layer.tsx} +6 -6
- package/src/shared/providers/screen/styles/styles.provider.tsx +3 -3
- package/src/shared/providers/stack/{helpers/managed-stack-state/managed-stack-controller.ts → blank-stack-state/blank-stack-controller.ts} +22 -20
- package/src/shared/providers/stack/{helpers/managed-stack-state/helpers/build-managed-stack-state.ts → blank-stack-state/helpers/build-blank-stack-state.ts} +28 -25
- package/src/shared/providers/stack/{helpers/managed-stack-state/helpers/derive-managed-stack-state.ts → blank-stack-state/helpers/derive-blank-stack-state.ts} +13 -13
- package/src/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/compose-descriptors.ts +1 -1
- package/src/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/sync-routes-with-removed.ts +8 -40
- package/src/shared/providers/stack/{helpers/managed-stack-state/helpers/reconcile-managed-routes.ts → blank-stack-state/helpers/reconcile-blank-stack-routes.ts} +26 -22
- package/src/shared/providers/stack/{helpers/managed-stack-state/helpers/helpers.ts → blank-stack-state/helpers/state-equality.ts} +4 -4
- package/src/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/helpers/types.ts +16 -15
- package/src/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/index.ts +9 -9
- package/src/shared/providers/stack/blank-stack.provider.tsx +118 -0
- package/src/shared/providers/stack/direct.provider.tsx +38 -54
- package/src/shared/stores/animation.store.ts +3 -0
- package/src/shared/stores/gesture.store.ts +6 -0
- package/src/shared/stores/scroll.store.ts +80 -7
- package/src/shared/stores/system.store.ts +1 -9
- package/src/shared/types/animation.types.ts +12 -14
- package/src/shared/types/bounds.types.ts +1 -1
- package/src/shared/types/gesture.types.ts +51 -1
- package/src/shared/types/index.ts +8 -0
- package/src/shared/types/providers/{managed-stack.types.ts → blank-stack-provider.types.ts} +10 -10
- package/src/shared/types/screen.types.ts +15 -2
- package/src/shared/utils/animation/animate-to-progress.ts +18 -7
- package/src/shared/utils/animation/animate.ts +44 -21
- package/src/shared/utils/animation/spring/index.ts +2 -0
- package/src/shared/utils/animation/spring/spring.ts +347 -0
- package/src/shared/utils/animation/spring/springConfigs.ts +46 -0
- package/src/shared/utils/animation/spring/springUtils.ts +418 -0
- package/src/shared/utils/animation/state.ts +6 -0
- package/src/shared/utils/bounds/navigation/reveal/build.ts +5 -9
- package/src/shared/utils/bounds/navigation/zoom/build.ts +4 -6
- package/lib/commonjs/shared/hooks/navigation/use-closing-route-keys.js +0 -61
- package/lib/commonjs/shared/hooks/navigation/use-closing-route-keys.js.map +0 -1
- package/lib/commonjs/shared/hooks/navigation/use-optimistic-focused-index.js +0 -20
- package/lib/commonjs/shared/hooks/navigation/use-optimistic-focused-index.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.js +0 -29
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/build-pan-gesture.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-activation-decision.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-activation-rules.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-activation.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-lifecycle.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-release.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-reset.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/use-pan-behavior.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/build-pinch-gesture.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-activation.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-lifecycle.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-release.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-reset.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/use-pinch-behavior.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/styles/components/maybe-floating-container.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js +0 -58
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/types.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/index.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-closing-route-map.js +0 -30
- package/lib/commonjs/shared/providers/stack/helpers/use-closing-route-map.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-processed-routes.js +0 -58
- package/lib/commonjs/shared/providers/stack/helpers/use-processed-routes.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-stack-derived.js +0 -27
- package/lib/commonjs/shared/providers/stack/helpers/use-stack-derived.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/managed.provider.js.map +0 -1
- package/lib/commonjs/shared/types/providers/managed-stack.types.js.map +0 -1
- package/lib/commonjs/shared/utils/navigation/compose-descriptors.js.map +0 -1
- package/lib/commonjs/shared/utils/navigation/resolve-scene-neighbors.js.map +0 -1
- package/lib/commonjs/shared/utils/navigation/sync-routes-with-removed.js.map +0 -1
- package/lib/module/shared/hooks/navigation/use-closing-route-keys.js +0 -55
- package/lib/module/shared/hooks/navigation/use-closing-route-keys.js.map +0 -1
- package/lib/module/shared/hooks/navigation/use-optimistic-focused-index.js +0 -17
- package/lib/module/shared/hooks/navigation/use-optimistic-focused-index.js.map +0 -1
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.js +0 -22
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/build-pan-gesture.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-activation-decision.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-activation-rules.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-activation.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-lifecycle.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-release.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-reset.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pan/use-pan-behavior.js +0 -49
- package/lib/module/shared/providers/screen/gestures/pan/use-pan-behavior.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/build-pinch-gesture.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-activation.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-lifecycle.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-release.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-reset.js.map +0 -1
- package/lib/module/shared/providers/screen/gestures/pinch/use-pinch-behavior.js.map +0 -1
- package/lib/module/shared/providers/screen/styles/components/maybe-floating-container.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/types.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/index.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-closing-route-map.js +0 -25
- package/lib/module/shared/providers/stack/helpers/use-closing-route-map.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-processed-routes.js +0 -54
- package/lib/module/shared/providers/stack/helpers/use-processed-routes.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-stack-derived.js +0 -23
- package/lib/module/shared/providers/stack/helpers/use-stack-derived.js.map +0 -1
- package/lib/module/shared/providers/stack/managed.provider.js.map +0 -1
- package/lib/module/shared/types/providers/managed-stack.types.js +0 -4
- package/lib/module/shared/types/providers/managed-stack.types.js.map +0 -1
- package/lib/module/shared/utils/navigation/compose-descriptors.js.map +0 -1
- package/lib/module/shared/utils/navigation/resolve-scene-neighbors.js.map +0 -1
- package/lib/module/shared/utils/navigation/sync-routes-with-removed.js.map +0 -1
- package/lib/typescript/shared/hooks/navigation/use-closing-route-keys.d.ts +0 -8
- package/lib/typescript/shared/hooks/navigation/use-closing-route-keys.d.ts.map +0 -1
- package/lib/typescript/shared/hooks/navigation/use-optimistic-focused-index.d.ts +0 -7
- package/lib/typescript/shared/hooks/navigation/use-optimistic-focused-index.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.d.ts +0 -5
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/build-pan-gesture.d.ts +0 -10
- package/lib/typescript/shared/providers/screen/gestures/pan/build-pan-gesture.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-activation-decision.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-activation-rules.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-activation.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-lifecycle.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-release.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-reset.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/use-pan-behavior.d.ts +0 -5
- package/lib/typescript/shared/providers/screen/gestures/pan/use-pan-behavior.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/build-pinch-gesture.d.ts +0 -7
- package/lib/typescript/shared/providers/screen/gestures/pinch/build-pinch-gesture.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-activation.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-lifecycle.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-release.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-reset.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/use-pinch-behavior.d.ts +0 -5
- package/lib/typescript/shared/providers/screen/gestures/pinch/use-pinch-behavior.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/styles/components/maybe-floating-container.d.ts +0 -7
- package/lib/typescript/shared/providers/screen/styles/components/maybe-floating-container.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.d.ts +0 -13
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.d.ts +0 -12
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.d.ts +0 -12
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/types.d.ts +0 -39
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/types.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/index.d.ts +0 -12
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/index.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.d.ts +0 -13
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-closing-route-map.d.ts +0 -7
- package/lib/typescript/shared/providers/stack/helpers/use-closing-route-map.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-processed-routes.d.ts +0 -17
- package/lib/typescript/shared/providers/stack/helpers/use-processed-routes.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-stack-derived.d.ts +0 -18
- package/lib/typescript/shared/providers/stack/helpers/use-stack-derived.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/managed.provider.d.ts +0 -8
- package/lib/typescript/shared/providers/stack/managed.provider.d.ts.map +0 -1
- package/lib/typescript/shared/types/providers/managed-stack.types.d.ts.map +0 -1
- package/lib/typescript/shared/utils/navigation/compose-descriptors.d.ts.map +0 -1
- package/lib/typescript/shared/utils/navigation/resolve-scene-neighbors.d.ts.map +0 -1
- package/lib/typescript/shared/utils/navigation/sync-routes-with-removed.d.ts.map +0 -1
- package/src/shared/hooks/navigation/use-closing-route-keys.ts +0 -60
- package/src/shared/hooks/navigation/use-optimistic-focused-index.ts +0 -19
- package/src/shared/providers/screen/animation/helpers/hydrate-transition-state/settle.ts +0 -41
- package/src/shared/providers/stack/helpers/use-closing-route-map.ts +0 -28
- package/src/shared/providers/stack/helpers/use-processed-routes.ts +0 -85
- package/src/shared/providers/stack/helpers/use-stack-derived.ts +0 -34
- package/src/shared/providers/stack/managed.provider.tsx +0 -126
- /package/lib/commonjs/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/compose-descriptors.js +0 -0
- /package/lib/commonjs/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/resolve-scene-neighbors.js +0 -0
- /package/lib/commonjs/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/helpers/types.js +0 -0
- /package/lib/module/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/compose-descriptors.js +0 -0
- /package/lib/module/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/resolve-scene-neighbors.js +0 -0
- /package/lib/module/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/helpers/types.js +0 -0
- /package/lib/typescript/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/resolve-scene-neighbors.d.ts +0 -0
- /package/src/shared/{utils → providers/stack/blank-stack-state/helpers}/navigation/resolve-scene-neighbors.ts +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_reactNativeReanimated","require","_constants","_animate","setTransitionLifecycleFlags","animations","isClosing","markEntering","closing","set","TRUE","entering","FALSE","animateToProgress","target","spec","onAnimationFinish","targetProgress","emitWillAnimate","initialVelocity","value","config","close","open","isSpringConfig","effectiveConfig","velocity","progress","willAnimate","progressAnimating","startAnimation","shouldClearEnteringOnFinish","get","runOnJS","animate","finished","requestAnimationFrame","exports"],"sourceRoot":"../../../../../src","sources":["shared/utils/animation/animate-to-progress.ts"],"mappings":";;;;;;AAAA,IAAAA,sBAAA,GAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA;AAGA,IAAAE,QAAA,GAAAF,OAAA;AAoBA,MAAMG,2BAA2B,GAAGA,CACnCC,UAA6B,EAC7BC,SAAkB,EAClBC,YAAqB,KACjB;EACJ,SAAS;;EAET,IAAID,SAAS,EAAE;IACdD,UAAU,CAACG,OAAO,CAACC,GAAG,CAACC,eAAI,CAAC;IAC5BL,UAAU,CAACM,QAAQ,CAACF,GAAG,CAACG,gBAAK,CAAC;IAC9B;EACD;EAEA,IAAIL,YAAY,EAAE;IACjBF,UAAU,CAACM,QAAQ,CAACF,GAAG,CAACC,eAAI,CAAC;EAC9B;AACD,CAAC;AAEM,MAAMG,iBAAiB,GAAGA,CAAC;EACjCC,MAAM;EACNC,IAAI;EACJC,iBAAiB;EACjBX,UAAU;EACVY,cAAc;EACdC,eAAe,GAAG,IAAI;EACtBX,YAAY,GAAG,IAAI;EACnBY;AACuB,CAAC,KAAK;EAC7B,SAAS;;EAET;EACA,MAAMb,SAAS,GACdQ,MAAM,KAAK,OAAO,IAAK,OAAOA,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,CAAE;EACnE,MAAMM,KAAK,GAAG,OAAON,MAAM,KAAK,QAAQ,GAAGA,MAAM,GAAGA,MAAM,KAAK,MAAM,GAAG,CAAC,GAAG,CAAC;;EAE7E;EACA,MAAMO,MAAM,GAAGf,SAAS,GAAGS,IAAI,EAAEO,KAAK,GAAGP,IAAI,EAAEQ,IAAI;EAEnD,MAAMC,cAAc,
|
|
1
|
+
{"version":3,"names":["_reactNativeReanimated","require","_constants","_animate","setTransitionLifecycleFlags","animations","isClosing","markEntering","closing","set","TRUE","entering","FALSE","animateToProgress","target","spec","onAnimationFinish","targetProgress","emitWillAnimate","initialVelocity","value","config","close","open","isSpringConfig","isSpringAnimationConfig","effectiveConfig","velocity","progress","willAnimate","progressAnimating","progressSettled","startAnimation","shouldClearEnteringOnFinish","get","runOnJS","animate","state","settled","finished","requestAnimationFrame","exports"],"sourceRoot":"../../../../../src","sources":["shared/utils/animation/animate-to-progress.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -3,16 +3,33 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.animate = void 0;
|
|
6
|
+
exports.isSpringAnimationConfig = exports.animate = void 0;
|
|
7
7
|
var _reactNativeReanimated = require("react-native-reanimated");
|
|
8
|
+
var _spring = require("./spring");
|
|
9
|
+
const isSpringAnimationConfig = config => {
|
|
10
|
+
"worklet";
|
|
11
|
+
|
|
12
|
+
if (typeof config !== "object" || config === null) {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
return "stiffness" in config || "damping" in config || "mass" in config || "velocity" in config || "overshootClamping" in config || "energyThreshold" in config || "dampingRatio" in config || "clamp" in config;
|
|
16
|
+
};
|
|
17
|
+
exports.isSpringAnimationConfig = isSpringAnimationConfig;
|
|
8
18
|
const animate = (toValue, config, callback) => {
|
|
9
19
|
"worklet";
|
|
10
20
|
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
21
|
+
if (!isSpringAnimationConfig(config)) {
|
|
22
|
+
return (0, _reactNativeReanimated.withTiming)(toValue, config, finished => {
|
|
23
|
+
"worklet";
|
|
24
|
+
|
|
25
|
+
const didFinish = finished === true;
|
|
26
|
+
callback?.({
|
|
27
|
+
finished: didFinish,
|
|
28
|
+
settled: didFinish
|
|
29
|
+
});
|
|
30
|
+
});
|
|
14
31
|
}
|
|
15
|
-
return (0,
|
|
32
|
+
return (0, _spring.withInternalSpring)(toValue, config, callback);
|
|
16
33
|
};
|
|
17
34
|
exports.animate = animate;
|
|
18
35
|
//# sourceMappingURL=animate.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_reactNativeReanimated","require","
|
|
1
|
+
{"version":3,"names":["_reactNativeReanimated","require","_spring","isSpringAnimationConfig","config","exports","animate","toValue","callback","withTiming","finished","didFinish","settled","withInternalSpring"],"sourceRoot":"../../../../../src","sources":["shared/utils/animation/animate.ts"],"mappings":";;;;;;AACA,IAAAA,sBAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AASO,MAAME,uBAAuB,GACnCC,MAAyC,IACJ;EACrC,SAAS;;EACT,IAAI,OAAOA,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;IAClD,OAAO,KAAK;EACb;EAEA,OACC,WAAW,IAAIA,MAAM,IACrB,SAAS,IAAIA,MAAM,IACnB,MAAM,IAAIA,MAAM,IAChB,UAAU,IAAIA,MAAM,IACpB,mBAAmB,IAAIA,MAAM,IAC7B,iBAAiB,IAAIA,MAAM,IAC3B,cAAc,IAAIA,MAAM,IACxB,OAAO,IAAIA,MAAM;AAEnB,CAAC;AAACC,OAAA,CAAAF,uBAAA,GAAAA,uBAAA;AAEK,MAAMG,OAAO,GAAGA,CACtBC,OAAe,EACfH,MAA8B,EAC9BI,QAAiC,KAC7B;EACJ,SAAS;;EAET,IAAI,CAACL,uBAAuB,CAACC,MAAM,CAAC,EAAE;IACrC,OAAO,IAAAK,iCAAU,EAACF,OAAO,EAAEH,MAAM,EAAGM,QAAQ,IAAK;MAChD,SAAS;;MACT,MAAMC,SAAS,GAAGD,QAAQ,KAAK,IAAI;MACnCF,QAAQ,GAAG;QACVE,QAAQ,EAAEC,SAAS;QACnBC,OAAO,EAAED;MACV,CAAC,CAAC;IACH,CAAC,CAAC;EACH;EAEA,OAAO,IAAAE,0BAAkB,EAACN,OAAO,EAAEH,MAAM,EAAEI,QAAQ,CAAC;AACrD,CAAC;AAACH,OAAA,CAAAC,OAAA,GAAAA,OAAA","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "withInternalSpring", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _spring.withInternalSpring;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
var _spring = require("./spring");
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_spring","require"],"sourceRoot":"../../../../../../src","sources":["shared/utils/animation/spring/index.ts"],"mappings":";;;;;;;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA","ignoreList":[]}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.withInternalSpring = void 0;
|
|
7
|
+
var _springUtils = require("./springUtils");
|
|
8
|
+
const REACT_NATIVE_RUNTIME_KIND = 1;
|
|
9
|
+
const REDUCE_MOTION_SYSTEM = "system";
|
|
10
|
+
const REDUCE_MOTION_ALWAYS = "always";
|
|
11
|
+
const DEFAULT_SPRING_SETTLE_DISTANCE = 0.001;
|
|
12
|
+
const DEFAULT_SPRING_CONFIG = {
|
|
13
|
+
damping: 120,
|
|
14
|
+
mass: 4,
|
|
15
|
+
stiffness: 900,
|
|
16
|
+
duration: 550,
|
|
17
|
+
dampingRatio: 1,
|
|
18
|
+
overshootClamping: false,
|
|
19
|
+
energyThreshold: 6e-9,
|
|
20
|
+
velocity: 0,
|
|
21
|
+
reduceMotion: undefined,
|
|
22
|
+
clamp: undefined
|
|
23
|
+
};
|
|
24
|
+
const getRuntimeKind = () => {
|
|
25
|
+
"worklet";
|
|
26
|
+
|
|
27
|
+
return globalThis.__RUNTIME_KIND;
|
|
28
|
+
};
|
|
29
|
+
const getReduceMotionForAnimation = config => {
|
|
30
|
+
"worklet";
|
|
31
|
+
|
|
32
|
+
if (!config || config === REDUCE_MOTION_SYSTEM) {
|
|
33
|
+
return undefined;
|
|
34
|
+
}
|
|
35
|
+
return config === REDUCE_MOTION_ALWAYS;
|
|
36
|
+
};
|
|
37
|
+
const defineSpringAnimation = (_starting, factory) => {
|
|
38
|
+
"worklet";
|
|
39
|
+
|
|
40
|
+
const create = () => {
|
|
41
|
+
"worklet";
|
|
42
|
+
|
|
43
|
+
const animation = factory();
|
|
44
|
+
const baseOnStart = animation.onStart;
|
|
45
|
+
animation.onStart = (animation, value, timestamp, previousAnimation) => {
|
|
46
|
+
"worklet";
|
|
47
|
+
|
|
48
|
+
if (animation.reduceMotion) {
|
|
49
|
+
animation.current = animation.toValue;
|
|
50
|
+
animation.onFrame = () => true;
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
baseOnStart(animation, value, timestamp, previousAnimation);
|
|
54
|
+
};
|
|
55
|
+
return animation;
|
|
56
|
+
};
|
|
57
|
+
if (getRuntimeKind() !== REACT_NATIVE_RUNTIME_KIND) {
|
|
58
|
+
return create();
|
|
59
|
+
}
|
|
60
|
+
create.__isAnimationDefinition = true;
|
|
61
|
+
return create;
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* Internal numeric spring forked from Reanimated's `withSpring`.
|
|
65
|
+
*
|
|
66
|
+
* As of version 4.4, Reanimated resets the spring velocity to zero whenever it
|
|
67
|
+
* initially points away from the target (see
|
|
68
|
+
* https://github.com/software-mansion/react-native-reanimated/pull/9463).
|
|
69
|
+
* That's a reasonable fix for stale inherited velocity in Reanimated's public
|
|
70
|
+
* spring behavior, but our gesture release handoff relies on that
|
|
71
|
+
* away-from-target velocity on purpose. It's what preserves the visual
|
|
72
|
+
* dismissal tail controlled by `gestureReleaseVelocityScale`.
|
|
73
|
+
*
|
|
74
|
+
* We went with this fork rather than trying to recreate the velocity scale
|
|
75
|
+
* outside the spring, since that approach pushed too much state and timing
|
|
76
|
+
* logic into the transition layer, bloated the code, and made the handoff
|
|
77
|
+
* easier to get subtly wrong. Keeping the fork lets screen transitions hold on
|
|
78
|
+
* to the native spring handoff behavior while keeping our own surface small and
|
|
79
|
+
* easy to extend with callbacks tailored to the transition lifecycle.
|
|
80
|
+
*/
|
|
81
|
+
const withInternalSpring = (toValue, userConfig, callback) => {
|
|
82
|
+
"worklet";
|
|
83
|
+
|
|
84
|
+
return defineSpringAnimation(toValue, () => {
|
|
85
|
+
"worklet";
|
|
86
|
+
|
|
87
|
+
const config = (0, _springUtils.safeMergeConfigs)({
|
|
88
|
+
...DEFAULT_SPRING_CONFIG,
|
|
89
|
+
useDuration: !!(userConfig?.duration || userConfig?.dampingRatio),
|
|
90
|
+
skipAnimation: false,
|
|
91
|
+
settleDistance: DEFAULT_SPRING_SETTLE_DISTANCE
|
|
92
|
+
}, userConfig);
|
|
93
|
+
let settled = false;
|
|
94
|
+
const notifySettled = animation => {
|
|
95
|
+
"worklet";
|
|
96
|
+
|
|
97
|
+
if (settled) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
if (!(0, _springUtils.isAnimationSettledCalculation)(animation, config)) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
settled = true;
|
|
104
|
+
animation.settled = true;
|
|
105
|
+
callback?.({
|
|
106
|
+
finished: false,
|
|
107
|
+
settled: true
|
|
108
|
+
});
|
|
109
|
+
};
|
|
110
|
+
config.skipAnimation = !(0, _springUtils.checkIfConfigIsValid)(config);
|
|
111
|
+
if (config.duration === 0) {
|
|
112
|
+
config.skipAnimation = true;
|
|
113
|
+
}
|
|
114
|
+
function springOnFrame(animation, now) {
|
|
115
|
+
// eslint-disable-next-line @typescript-eslint/no-shadow
|
|
116
|
+
const {
|
|
117
|
+
toValue,
|
|
118
|
+
current
|
|
119
|
+
} = animation;
|
|
120
|
+
if (config.skipAnimation) {
|
|
121
|
+
animation.current = toValue;
|
|
122
|
+
animation.lastTimestamp = 0;
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
125
|
+
const {
|
|
126
|
+
lastTimestamp,
|
|
127
|
+
velocity
|
|
128
|
+
} = animation;
|
|
129
|
+
const deltaTime = Math.min(Math.max(now - lastTimestamp, 0), 64);
|
|
130
|
+
animation.lastTimestamp = now;
|
|
131
|
+
const t = deltaTime / 1000;
|
|
132
|
+
const v0 = velocity;
|
|
133
|
+
const x0 = current - toValue;
|
|
134
|
+
const {
|
|
135
|
+
zeta,
|
|
136
|
+
omega0,
|
|
137
|
+
omega1
|
|
138
|
+
} = animation;
|
|
139
|
+
const {
|
|
140
|
+
position: newPosition,
|
|
141
|
+
velocity: newVelocity
|
|
142
|
+
} = zeta < 1 ? (0, _springUtils.underDampedSpringCalculations)(animation, {
|
|
143
|
+
zeta,
|
|
144
|
+
v0,
|
|
145
|
+
x0,
|
|
146
|
+
omega0,
|
|
147
|
+
omega1,
|
|
148
|
+
t
|
|
149
|
+
}) : (0, _springUtils.criticallyDampedSpringCalculations)(animation, {
|
|
150
|
+
v0,
|
|
151
|
+
x0,
|
|
152
|
+
omega0,
|
|
153
|
+
t
|
|
154
|
+
});
|
|
155
|
+
animation.current = newPosition;
|
|
156
|
+
animation.velocity = newVelocity;
|
|
157
|
+
if ((0, _springUtils.isAnimationTerminatingCalculation)(animation, config)) {
|
|
158
|
+
animation.velocity = 0;
|
|
159
|
+
animation.current = toValue;
|
|
160
|
+
settled = true;
|
|
161
|
+
animation.settled = true;
|
|
162
|
+
// clear lastTimestamp to avoid using stale value by the next spring animation that starts after this one
|
|
163
|
+
animation.lastTimestamp = 0;
|
|
164
|
+
return true;
|
|
165
|
+
}
|
|
166
|
+
notifySettled(animation);
|
|
167
|
+
return false;
|
|
168
|
+
}
|
|
169
|
+
function isTriggeredTwice(previousAnimation, animation) {
|
|
170
|
+
return previousAnimation?.lastTimestamp && previousAnimation?.startTimestamp && previousAnimation?.toValue === animation.toValue && previousAnimation?.duration === animation.duration && previousAnimation?.dampingRatio === animation.dampingRatio;
|
|
171
|
+
}
|
|
172
|
+
function onStart(animation, value, now, previousAnimation) {
|
|
173
|
+
animation.current = value;
|
|
174
|
+
let stiffness = config.stiffness;
|
|
175
|
+
const triggeredTwice = isTriggeredTwice(previousAnimation, animation);
|
|
176
|
+
const duration = config.duration;
|
|
177
|
+
const x0 = triggeredTwice ?
|
|
178
|
+
// If animation is triggered twice we want to continue the previous animation
|
|
179
|
+
// form the previous starting point
|
|
180
|
+
previousAnimation?.startValue : value - animation.toValue;
|
|
181
|
+
animation.startValue = x0;
|
|
182
|
+
if (previousAnimation) {
|
|
183
|
+
animation.velocity = (triggeredTwice ? previousAnimation?.velocity : previousAnimation?.velocity + config.velocity) || 0;
|
|
184
|
+
} else {
|
|
185
|
+
animation.velocity = config.velocity || 0;
|
|
186
|
+
}
|
|
187
|
+
if (triggeredTwice) {
|
|
188
|
+
animation.zeta = previousAnimation?.zeta || 0;
|
|
189
|
+
animation.omega0 = previousAnimation?.omega0 || 0;
|
|
190
|
+
animation.omega1 = previousAnimation?.omega1 || 0;
|
|
191
|
+
} else {
|
|
192
|
+
if (config.useDuration) {
|
|
193
|
+
const actualDuration = triggeredTwice ?
|
|
194
|
+
// If animation is triggered twice we want to continue the previous animation
|
|
195
|
+
// so we need to include the time that already elapsed
|
|
196
|
+
duration - ((previousAnimation?.lastTimestamp || 0) - (previousAnimation?.startTimestamp || 0)) : duration;
|
|
197
|
+
config.duration = actualDuration;
|
|
198
|
+
stiffness = (0, _springUtils.calculateNewStiffnessToMatchDuration)(x0, config, animation.velocity);
|
|
199
|
+
config.stiffness = stiffness;
|
|
200
|
+
}
|
|
201
|
+
const {
|
|
202
|
+
zeta,
|
|
203
|
+
omega0,
|
|
204
|
+
omega1
|
|
205
|
+
} = (0, _springUtils.initialCalculations)(stiffness, config);
|
|
206
|
+
animation.zeta = zeta;
|
|
207
|
+
animation.omega0 = omega0;
|
|
208
|
+
animation.omega1 = omega1;
|
|
209
|
+
if (config.clamp !== undefined) {
|
|
210
|
+
animation.zeta = (0, _springUtils.scaleZetaToMatchClamps)(animation, config.clamp);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
const initialEnergy = (0, _springUtils.getEnergy)(x0, config.velocity, config.stiffness, config.mass);
|
|
214
|
+
animation.initialEnergy = initialEnergy;
|
|
215
|
+
animation.lastTimestamp = previousAnimation?.lastTimestamp || now;
|
|
216
|
+
animation.startTimestamp = triggeredTwice ? previousAnimation?.startTimestamp || now : now;
|
|
217
|
+
notifySettled(animation);
|
|
218
|
+
}
|
|
219
|
+
const animation = {
|
|
220
|
+
onFrame: springOnFrame,
|
|
221
|
+
onStart,
|
|
222
|
+
toValue,
|
|
223
|
+
velocity: config.velocity || 0,
|
|
224
|
+
current: toValue,
|
|
225
|
+
settled: false,
|
|
226
|
+
startValue: 0,
|
|
227
|
+
callback: finished => {
|
|
228
|
+
"worklet";
|
|
229
|
+
|
|
230
|
+
const didFinish = finished === true;
|
|
231
|
+
callback?.({
|
|
232
|
+
finished: didFinish,
|
|
233
|
+
settled: didFinish || settled
|
|
234
|
+
});
|
|
235
|
+
},
|
|
236
|
+
lastTimestamp: 0,
|
|
237
|
+
startTimestamp: 0,
|
|
238
|
+
zeta: 0,
|
|
239
|
+
omega0: 0,
|
|
240
|
+
omega1: 0,
|
|
241
|
+
initialEnergy: 0,
|
|
242
|
+
reduceMotion: getReduceMotionForAnimation(config.reduceMotion)
|
|
243
|
+
};
|
|
244
|
+
return animation;
|
|
245
|
+
});
|
|
246
|
+
};
|
|
247
|
+
exports.withInternalSpring = withInternalSpring;
|
|
248
|
+
//# sourceMappingURL=spring.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_springUtils","require","REACT_NATIVE_RUNTIME_KIND","REDUCE_MOTION_SYSTEM","REDUCE_MOTION_ALWAYS","DEFAULT_SPRING_SETTLE_DISTANCE","DEFAULT_SPRING_CONFIG","damping","mass","stiffness","duration","dampingRatio","overshootClamping","energyThreshold","velocity","reduceMotion","undefined","clamp","getRuntimeKind","globalThis","__RUNTIME_KIND","getReduceMotionForAnimation","config","defineSpringAnimation","_starting","factory","create","animation","baseOnStart","onStart","value","timestamp","previousAnimation","current","toValue","onFrame","__isAnimationDefinition","withInternalSpring","userConfig","callback","safeMergeConfigs","useDuration","skipAnimation","settleDistance","settled","notifySettled","isAnimationSettledCalculation","finished","checkIfConfigIsValid","springOnFrame","now","lastTimestamp","deltaTime","Math","min","max","t","v0","x0","zeta","omega0","omega1","position","newPosition","newVelocity","underDampedSpringCalculations","criticallyDampedSpringCalculations","isAnimationTerminatingCalculation","isTriggeredTwice","startTimestamp","triggeredTwice","startValue","actualDuration","calculateNewStiffnessToMatchDuration","initialCalculations","scaleZetaToMatchClamps","initialEnergy","getEnergy","didFinish","exports"],"sourceRoot":"../../../../../../src","sources":["shared/utils/animation/spring/spring.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../../../src","sources":["shared/utils/animation/spring/springConfigs.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.calculateNewStiffnessToMatchDuration = calculateNewStiffnessToMatchDuration;
|
|
7
|
+
exports.checkIfConfigIsValid = checkIfConfigIsValid;
|
|
8
|
+
exports.criticallyDampedSpringCalculations = criticallyDampedSpringCalculations;
|
|
9
|
+
exports.getEnergy = getEnergy;
|
|
10
|
+
exports.initialCalculations = initialCalculations;
|
|
11
|
+
exports.isAnimationSettledCalculation = isAnimationSettledCalculation;
|
|
12
|
+
exports.isAnimationTerminatingCalculation = isAnimationTerminatingCalculation;
|
|
13
|
+
exports.safeMergeConfigs = safeMergeConfigs;
|
|
14
|
+
exports.scaleZetaToMatchClamps = scaleZetaToMatchClamps;
|
|
15
|
+
exports.underDampedSpringCalculations = underDampedSpringCalculations;
|
|
16
|
+
// This type contains all the properties from SpringConfig, which are changed to be required,
|
|
17
|
+
// except for optional 'reduceMotion' and 'clamp'
|
|
18
|
+
|
|
19
|
+
function checkIfConfigIsValid(config) {
|
|
20
|
+
"worklet";
|
|
21
|
+
|
|
22
|
+
let errorMessage = "";
|
|
23
|
+
["stiffness", "damping", "dampingRatio", "mass", "energyThreshold"].forEach(prop => {
|
|
24
|
+
const value = config[prop];
|
|
25
|
+
if (value <= 0) {
|
|
26
|
+
errorMessage += `, ${prop} must be greater than zero but got ${value}`;
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
if (config.duration < 0) {
|
|
30
|
+
errorMessage += `, duration can't be negative, got ${config.duration}`;
|
|
31
|
+
}
|
|
32
|
+
if (config.clamp?.min && config.clamp?.max && config.clamp.min > config.clamp.max) {
|
|
33
|
+
errorMessage += `, clamp.min should be lower than clamp.max, got clamp: {min: ${config.clamp.min}, max: ${config.clamp.max}} `;
|
|
34
|
+
}
|
|
35
|
+
if (errorMessage !== "") {
|
|
36
|
+
console.warn(`Invalid spring config${errorMessage}`);
|
|
37
|
+
}
|
|
38
|
+
return errorMessage === "";
|
|
39
|
+
}
|
|
40
|
+
function safeMergeConfigs(defaults, userConfig) {
|
|
41
|
+
"worklet";
|
|
42
|
+
|
|
43
|
+
if (!userConfig) {
|
|
44
|
+
return defaults;
|
|
45
|
+
}
|
|
46
|
+
const filtered = Object.fromEntries(Object.entries(userConfig).filter(([, v]) => v !== undefined));
|
|
47
|
+
return {
|
|
48
|
+
...defaults,
|
|
49
|
+
...filtered
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
function bisectRoot({
|
|
53
|
+
min,
|
|
54
|
+
max,
|
|
55
|
+
func,
|
|
56
|
+
precision,
|
|
57
|
+
maxIterations = 20
|
|
58
|
+
}) {
|
|
59
|
+
"worklet";
|
|
60
|
+
|
|
61
|
+
const direction = func(max) >= func(min) ? 1 : -1;
|
|
62
|
+
let idx = maxIterations;
|
|
63
|
+
let current = (max + min) / 2;
|
|
64
|
+
while (Math.abs(func(current)) > precision && idx > 0) {
|
|
65
|
+
idx -= 1;
|
|
66
|
+
if (func(current) * direction < 0) {
|
|
67
|
+
min = current;
|
|
68
|
+
} else {
|
|
69
|
+
max = current;
|
|
70
|
+
}
|
|
71
|
+
current = (min + max) / 2;
|
|
72
|
+
}
|
|
73
|
+
return current;
|
|
74
|
+
}
|
|
75
|
+
function initialCalculations(stiffness = 0, config) {
|
|
76
|
+
"worklet";
|
|
77
|
+
|
|
78
|
+
if (config.skipAnimation) {
|
|
79
|
+
return {
|
|
80
|
+
zeta: 0,
|
|
81
|
+
omega0: 0,
|
|
82
|
+
omega1: 0
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
if (config.useDuration) {
|
|
86
|
+
const {
|
|
87
|
+
mass: m,
|
|
88
|
+
dampingRatio: zeta
|
|
89
|
+
} = config;
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Omega0 and omega1 denote angular frequency and natural angular frequency,
|
|
93
|
+
* see this link for formulas:
|
|
94
|
+
* https://courses.lumenlearning.com/suny-osuniversityphysics/chapter/15-5-damped-oscillations/
|
|
95
|
+
*/
|
|
96
|
+
const omega0 = Math.sqrt(stiffness / m);
|
|
97
|
+
const omega1 = zeta < 1 ? omega0 * Math.sqrt(1 - zeta ** 2) : 0;
|
|
98
|
+
return {
|
|
99
|
+
zeta,
|
|
100
|
+
omega0,
|
|
101
|
+
omega1
|
|
102
|
+
};
|
|
103
|
+
} else {
|
|
104
|
+
const {
|
|
105
|
+
damping: c,
|
|
106
|
+
mass: m,
|
|
107
|
+
stiffness: k
|
|
108
|
+
} = config;
|
|
109
|
+
const zeta = c / (2 * Math.sqrt(k * m)); // damping ratio
|
|
110
|
+
const omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)
|
|
111
|
+
const omega1 = zeta < 1 ? omega0 * Math.sqrt(1 - zeta ** 2) : 0; // exponential decay
|
|
112
|
+
|
|
113
|
+
return {
|
|
114
|
+
zeta,
|
|
115
|
+
omega0,
|
|
116
|
+
omega1
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* We make an assumption that we can manipulate zeta without changing duration
|
|
123
|
+
* of movement. According to theory this change is small and tests shows that we
|
|
124
|
+
* can indeed ignore it.
|
|
125
|
+
*/
|
|
126
|
+
function scaleZetaToMatchClamps(animation, clamp) {
|
|
127
|
+
"worklet";
|
|
128
|
+
|
|
129
|
+
const {
|
|
130
|
+
zeta,
|
|
131
|
+
toValue,
|
|
132
|
+
startValue
|
|
133
|
+
} = animation;
|
|
134
|
+
const toValueNum = Number(toValue);
|
|
135
|
+
if (startValue === 0) {
|
|
136
|
+
return zeta;
|
|
137
|
+
}
|
|
138
|
+
const [firstBound, secondBound] = startValue <= 0 ? [clamp.min, clamp.max] : [clamp.max, clamp.min];
|
|
139
|
+
|
|
140
|
+
/**
|
|
141
|
+
* The extrema we get from equation below are relative (we obtain a ratio), To
|
|
142
|
+
* get absolute extrema we convert it as follows:
|
|
143
|
+
*
|
|
144
|
+
* AbsoluteExtremum = startValue ± RelativeExtremum * (toValue - startValue)
|
|
145
|
+
* Where ± denotes:
|
|
146
|
+
*
|
|
147
|
+
* - If extremum is over the target
|
|
148
|
+
* - Otherwise
|
|
149
|
+
*/
|
|
150
|
+
|
|
151
|
+
const relativeExtremum1 = secondBound !== undefined ? Math.abs((secondBound - toValueNum) / startValue) : undefined;
|
|
152
|
+
const relativeExtremum2 = firstBound !== undefined ? Math.abs((firstBound - toValueNum) / startValue) : undefined;
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Use this formula http://hyperphysics.phy-astr.gsu.edu/hbase/oscda.html to
|
|
156
|
+
* calculate first two extrema. These extrema are located where cos = +- 1
|
|
157
|
+
*
|
|
158
|
+
* Therefore the first two extrema are:
|
|
159
|
+
*
|
|
160
|
+
* Math.exp(-zeta * Math.PI); (over the target)
|
|
161
|
+
* Math.exp(-zeta * 2 * Math.PI); (before the target)
|
|
162
|
+
*/
|
|
163
|
+
|
|
164
|
+
const newZeta1 = relativeExtremum1 !== undefined ? Math.abs(Math.log(relativeExtremum1) / Math.PI) : undefined;
|
|
165
|
+
const newZeta2 = relativeExtremum2 !== undefined ? Math.abs(Math.log(relativeExtremum2) / (2 * Math.PI)) : undefined;
|
|
166
|
+
const zetaSatisfyingClamp = [newZeta1, newZeta2].filter(x => x !== undefined);
|
|
167
|
+
// The bigger is zeta the smaller are bounces, we return the biggest one
|
|
168
|
+
// because it should satisfy all conditions
|
|
169
|
+
return Math.max(...zetaSatisfyingClamp, zeta);
|
|
170
|
+
}
|
|
171
|
+
function getEnergy(displacement, velocity, stiffness, mass) {
|
|
172
|
+
"worklet";
|
|
173
|
+
|
|
174
|
+
const potentialEnergy = 0.5 * stiffness * displacement ** 2;
|
|
175
|
+
const kineticEnergy = 0.5 * mass * velocity ** 2;
|
|
176
|
+
return potentialEnergy + kineticEnergy;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
/** Runs before initial */
|
|
180
|
+
function calculateNewStiffnessToMatchDuration(x0, config, v0) {
|
|
181
|
+
"worklet";
|
|
182
|
+
|
|
183
|
+
if (config.skipAnimation) {
|
|
184
|
+
return 0;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
* Use this formula:
|
|
189
|
+
* https://phys.libretexts.org/Bookshelves/University_Physics/Book%3A_University_Physics_(OpenStax)/Book%3A_University_Physics_I_-_Mechanics_Sound_Oscillations_and_Waves_(OpenStax)/15%3A_Oscillations/15.06%3A_Damped_Oscillations
|
|
190
|
+
* to find the asymptote and estimate the damping that gives us the expected
|
|
191
|
+
* duration
|
|
192
|
+
*
|
|
193
|
+
* ⎛ ⎛ c⎞ ⎞
|
|
194
|
+
* ⎜-⎜──⎟ ⋅ duration⎟
|
|
195
|
+
* ⎝ ⎝2m⎠ ⎠
|
|
196
|
+
* A ⋅ e = threshold
|
|
197
|
+
*/
|
|
198
|
+
const {
|
|
199
|
+
dampingRatio: zeta,
|
|
200
|
+
energyThreshold: threshold,
|
|
201
|
+
mass: m,
|
|
202
|
+
duration: targetDuration
|
|
203
|
+
} = config;
|
|
204
|
+
const energyDiffForStiffness = stiffness => {
|
|
205
|
+
"worklet";
|
|
206
|
+
|
|
207
|
+
const perceptualCoefficient = 1.5;
|
|
208
|
+
const MILLISECONDS_IN_SECOND = 1000;
|
|
209
|
+
const settlingDuration = targetDuration * perceptualCoefficient / MILLISECONDS_IN_SECOND;
|
|
210
|
+
const omega0 = Math.sqrt(stiffness / m) * zeta;
|
|
211
|
+
const xtk = (x0 + (v0 + x0 * omega0) * settlingDuration) * Math.exp(-omega0 * settlingDuration);
|
|
212
|
+
const vtk = (x0 + (v0 + x0 * omega0) * settlingDuration) * Math.exp(-omega0 * settlingDuration) * -omega0 + (v0 + x0 * omega0) * Math.exp(-omega0 * settlingDuration);
|
|
213
|
+
const e0 = getEnergy(x0, v0, stiffness, m);
|
|
214
|
+
const etk = getEnergy(xtk, vtk, stiffness, m);
|
|
215
|
+
const energyFraction = etk / e0;
|
|
216
|
+
return energyFraction - threshold;
|
|
217
|
+
};
|
|
218
|
+
const precision = config.energyThreshold * 1e-3; // Experimentally seems to be good enough.
|
|
219
|
+
|
|
220
|
+
// Bisection turns out to be much faster than Newton's method in our case
|
|
221
|
+
return bisectRoot({
|
|
222
|
+
min: Number.EPSILON,
|
|
223
|
+
max: 8e3 /* Stiffness for 8ms animation doesn't exceed 2e3, we add some safety margin on top of that. */,
|
|
224
|
+
func: energyDiffForStiffness,
|
|
225
|
+
precision,
|
|
226
|
+
maxIterations: 100
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
function criticallyDampedSpringCalculations(animation, precalculatedValues) {
|
|
230
|
+
"worklet";
|
|
231
|
+
|
|
232
|
+
const {
|
|
233
|
+
toValue
|
|
234
|
+
} = animation;
|
|
235
|
+
const {
|
|
236
|
+
v0,
|
|
237
|
+
x0,
|
|
238
|
+
omega0,
|
|
239
|
+
t
|
|
240
|
+
} = precalculatedValues;
|
|
241
|
+
const criticallyDampedEnvelope = Math.exp(-omega0 * t);
|
|
242
|
+
const criticallyDampedPosition = toValue + criticallyDampedEnvelope * (x0 + (v0 + omega0 * x0) * t);
|
|
243
|
+
const criticallyDampedVelocity = criticallyDampedEnvelope * -omega0 * (x0 + (v0 + omega0 * x0) * t) + criticallyDampedEnvelope * (v0 + omega0 * x0);
|
|
244
|
+
return {
|
|
245
|
+
position: criticallyDampedPosition,
|
|
246
|
+
velocity: criticallyDampedVelocity
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
function underDampedSpringCalculations(animation, precalculatedValues) {
|
|
250
|
+
"worklet";
|
|
251
|
+
|
|
252
|
+
const {
|
|
253
|
+
toValue
|
|
254
|
+
} = animation;
|
|
255
|
+
const {
|
|
256
|
+
zeta,
|
|
257
|
+
t,
|
|
258
|
+
omega0,
|
|
259
|
+
omega1,
|
|
260
|
+
x0,
|
|
261
|
+
v0
|
|
262
|
+
} = precalculatedValues;
|
|
263
|
+
const sin1 = Math.sin(omega1 * t);
|
|
264
|
+
const cos1 = Math.cos(omega1 * t);
|
|
265
|
+
|
|
266
|
+
// under damped
|
|
267
|
+
const underDampedEnvelope = Math.exp(-zeta * omega0 * t);
|
|
268
|
+
const underDampedFrag1 = underDampedEnvelope * (sin1 * ((v0 + zeta * omega0 * x0) / omega1) + x0 * cos1);
|
|
269
|
+
const underDampedPosition = toValue + underDampedFrag1;
|
|
270
|
+
// This looks crazy -- it's actually just the derivative of the oscillation function
|
|
271
|
+
const underDampedVelocity = -zeta * omega0 * underDampedFrag1 + underDampedEnvelope * (cos1 * (v0 + zeta * omega0 * x0) - omega1 * x0 * sin1);
|
|
272
|
+
return {
|
|
273
|
+
position: underDampedPosition,
|
|
274
|
+
velocity: underDampedVelocity
|
|
275
|
+
};
|
|
276
|
+
}
|
|
277
|
+
function isAnimationTerminatingCalculation(animation, config) {
|
|
278
|
+
"worklet";
|
|
279
|
+
|
|
280
|
+
const {
|
|
281
|
+
toValue,
|
|
282
|
+
velocity,
|
|
283
|
+
startValue,
|
|
284
|
+
current,
|
|
285
|
+
initialEnergy
|
|
286
|
+
} = animation;
|
|
287
|
+
if (config.overshootClamping) {
|
|
288
|
+
const leftBound = startValue >= 0 ? toValue : toValue + startValue;
|
|
289
|
+
const rightBound = leftBound + Math.abs(startValue);
|
|
290
|
+
if (current < leftBound || current > rightBound) {
|
|
291
|
+
return true;
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
const currentEnergy = getEnergy(toValue - current, velocity, config.stiffness, config.mass);
|
|
295
|
+
return initialEnergy === 0 || currentEnergy / initialEnergy <= config.energyThreshold;
|
|
296
|
+
}
|
|
297
|
+
function isAnimationSettledCalculation(animation, config) {
|
|
298
|
+
"worklet";
|
|
299
|
+
|
|
300
|
+
const {
|
|
301
|
+
toValue,
|
|
302
|
+
velocity,
|
|
303
|
+
current
|
|
304
|
+
} = animation;
|
|
305
|
+
const distance = Math.max(0, config.settleDistance);
|
|
306
|
+
if (distance === 0) {
|
|
307
|
+
return isAnimationTerminatingCalculation(animation, config);
|
|
308
|
+
}
|
|
309
|
+
const currentEnergy = getEnergy(toValue - current, velocity, config.stiffness, config.mass);
|
|
310
|
+
const maxSettledEnergy = getEnergy(distance, 0, config.stiffness, config.mass);
|
|
311
|
+
return currentEnergy <= maxSettledEnergy;
|
|
312
|
+
}
|
|
313
|
+
//# sourceMappingURL=springUtils.js.map
|