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,42 +1,42 @@
|
|
|
1
1
|
import { StackActions } from "@react-navigation/native";
|
|
2
|
-
import type {
|
|
2
|
+
import type { BlankStackProviderProps } from "../../../types/providers/blank-stack-provider.types";
|
|
3
3
|
import type {
|
|
4
4
|
BaseStackDescriptor,
|
|
5
5
|
BaseStackNavigation,
|
|
6
6
|
BaseStackRoute,
|
|
7
|
-
} from "
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
7
|
+
} from "../../../types/stack.types";
|
|
8
|
+
import { buildBlankStackState } from "./helpers/build-blank-stack-state";
|
|
9
|
+
import { deriveBlankStackState } from "./helpers/derive-blank-stack-state";
|
|
10
10
|
import type {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
BlankStackControllerSnapshot,
|
|
12
|
+
BlankStackController as BlankStackControllerType,
|
|
13
|
+
BlankStackDescriptorSources,
|
|
14
14
|
} from "./helpers/types";
|
|
15
15
|
|
|
16
|
-
export type {
|
|
16
|
+
export type { BlankStackController } from "./helpers/types";
|
|
17
17
|
|
|
18
18
|
/**
|
|
19
|
-
* Maintains the stack-local route snapshot used while
|
|
19
|
+
* Maintains the stack-local route snapshot used while blank stack transitions run.
|
|
20
20
|
*
|
|
21
21
|
* React Navigation remains the source of truth for settled routes, but it can
|
|
22
22
|
* remove descriptors before our close animation has finished. This controller
|
|
23
23
|
* keeps those closing routes locally until their lifecycle reports completion.
|
|
24
24
|
*/
|
|
25
|
-
export const
|
|
25
|
+
export const createBlankStackController = <
|
|
26
26
|
TDescriptor extends BaseStackDescriptor,
|
|
27
27
|
TNavigation extends BaseStackNavigation,
|
|
28
28
|
>(
|
|
29
|
-
initialProps:
|
|
30
|
-
):
|
|
29
|
+
initialProps: BlankStackProviderProps<TDescriptor, TNavigation>,
|
|
30
|
+
): BlankStackControllerType<TDescriptor, TNavigation> => {
|
|
31
31
|
const closingRouteKeys = new Set<string>();
|
|
32
32
|
let props = initialProps;
|
|
33
33
|
let previousRoutesSnapshot = initialProps.state.routes;
|
|
34
|
-
let snapshot:
|
|
35
|
-
state:
|
|
34
|
+
let snapshot: BlankStackControllerSnapshot<TDescriptor> = {
|
|
35
|
+
state: buildBlankStackState({
|
|
36
36
|
props,
|
|
37
37
|
routes: initialProps.state.routes,
|
|
38
38
|
descriptors:
|
|
39
|
-
initialProps.descriptors as
|
|
39
|
+
initialProps.descriptors as BlankStackDescriptorSources<TDescriptor>,
|
|
40
40
|
closingRouteKeys,
|
|
41
41
|
}),
|
|
42
42
|
};
|
|
@@ -55,15 +55,17 @@ export const createManagedStackController = <
|
|
|
55
55
|
};
|
|
56
56
|
};
|
|
57
57
|
|
|
58
|
-
const getSnapshot = ():
|
|
58
|
+
const getSnapshot = (): BlankStackControllerSnapshot<TDescriptor> => {
|
|
59
59
|
return snapshot;
|
|
60
60
|
};
|
|
61
61
|
|
|
62
|
-
const update = (
|
|
62
|
+
const update = (
|
|
63
|
+
nextProps: BlankStackProviderProps<TDescriptor, TNavigation>,
|
|
64
|
+
) => {
|
|
63
65
|
const lastRoutesSnapshot = previousRoutesSnapshot;
|
|
64
66
|
props = nextProps;
|
|
65
67
|
|
|
66
|
-
const nextState =
|
|
68
|
+
const nextState = deriveBlankStackState({
|
|
67
69
|
props,
|
|
68
70
|
current: snapshot.state,
|
|
69
71
|
previousRoutesSnapshot: lastRoutesSnapshot,
|
|
@@ -111,7 +113,7 @@ export const createManagedStackController = <
|
|
|
111
113
|
delete nextDescriptors[route.key];
|
|
112
114
|
|
|
113
115
|
snapshot = {
|
|
114
|
-
state:
|
|
116
|
+
state: buildBlankStackState({
|
|
115
117
|
props,
|
|
116
118
|
routes: nextRoutes,
|
|
117
119
|
descriptors: nextDescriptors,
|
|
@@ -138,7 +140,7 @@ export const createManagedStackController = <
|
|
|
138
140
|
|
|
139
141
|
closingRouteKeys.add(route.key);
|
|
140
142
|
snapshot = {
|
|
141
|
-
state:
|
|
143
|
+
state: buildBlankStackState({
|
|
142
144
|
props,
|
|
143
145
|
routes: current.routes,
|
|
144
146
|
descriptors: current.sourceDescriptors,
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { BlankStackProviderProps } from "../../../../types/providers/blank-stack-provider.types";
|
|
2
2
|
import type {
|
|
3
3
|
BaseStackDescriptor,
|
|
4
4
|
BaseStackNavigation,
|
|
5
5
|
BaseStackScene,
|
|
6
6
|
StackDescriptorSource,
|
|
7
7
|
StackSceneActivity,
|
|
8
|
-
} from "
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
8
|
+
} from "../../../../types/stack.types";
|
|
9
|
+
import { isOverlayVisible } from "../../../../utils/overlay/visibility";
|
|
10
|
+
import { resolveSceneNeighbors } from "./navigation/resolve-scene-neighbors";
|
|
11
11
|
import {
|
|
12
12
|
areDescriptorSourcesEquivalent,
|
|
13
13
|
areDescriptorsEqual,
|
|
@@ -15,22 +15,22 @@ import {
|
|
|
15
15
|
getRouteChildState,
|
|
16
16
|
routeKeyListsAreEqual,
|
|
17
17
|
setsAreEqual,
|
|
18
|
-
} from "./
|
|
18
|
+
} from "./state-equality";
|
|
19
19
|
import type {
|
|
20
|
+
BlankStackDescriptorSources,
|
|
21
|
+
BlankStackDescriptors,
|
|
22
|
+
BlankStackRoutes,
|
|
20
23
|
LocalRoutesState,
|
|
21
|
-
ManagedDescriptorSources,
|
|
22
|
-
ManagedDescriptors,
|
|
23
|
-
ManagedRoutes,
|
|
24
24
|
SceneActivityWindow,
|
|
25
25
|
} from "./types";
|
|
26
26
|
|
|
27
|
-
type
|
|
27
|
+
type BuildBlankStackStateParams<
|
|
28
28
|
TDescriptor extends BaseStackDescriptor,
|
|
29
29
|
TNavigation extends BaseStackNavigation,
|
|
30
30
|
> = {
|
|
31
|
-
props:
|
|
32
|
-
routes:
|
|
33
|
-
descriptors:
|
|
31
|
+
props: BlankStackProviderProps<TDescriptor, TNavigation>;
|
|
32
|
+
routes: BlankStackRoutes<TDescriptor>;
|
|
33
|
+
descriptors: BlankStackDescriptorSources<TDescriptor>;
|
|
34
34
|
closingRouteKeys: ReadonlySet<string>;
|
|
35
35
|
previousState?: LocalRoutesState<TDescriptor>;
|
|
36
36
|
};
|
|
@@ -83,7 +83,7 @@ const getSceneActivity = ({
|
|
|
83
83
|
};
|
|
84
84
|
|
|
85
85
|
const getNonClosingSceneIndices = <TDescriptor extends BaseStackDescriptor>(
|
|
86
|
-
routes:
|
|
86
|
+
routes: BlankStackRoutes<TDescriptor>,
|
|
87
87
|
closingRouteKeys: ReadonlySet<string>,
|
|
88
88
|
) => {
|
|
89
89
|
const indices: number[] = [];
|
|
@@ -105,7 +105,7 @@ const getSceneActivityWindow = <
|
|
|
105
105
|
props,
|
|
106
106
|
routes,
|
|
107
107
|
closingRouteKeys,
|
|
108
|
-
}:
|
|
108
|
+
}: BuildBlankStackStateParams<
|
|
109
109
|
TDescriptor,
|
|
110
110
|
TNavigation
|
|
111
111
|
>): SceneActivityWindow => {
|
|
@@ -161,14 +161,14 @@ const buildBaseScenes = <
|
|
|
161
161
|
closingRouteKeys,
|
|
162
162
|
previousState,
|
|
163
163
|
activityWindow,
|
|
164
|
-
}:
|
|
164
|
+
}: BuildBlankStackStateParams<TDescriptor, TNavigation> & {
|
|
165
165
|
activityWindow: SceneActivityWindow;
|
|
166
166
|
}) => {
|
|
167
167
|
const routeKeys: string[] = [];
|
|
168
168
|
const scenes: BaseStackScene<TDescriptor>[] = [];
|
|
169
169
|
const routeChildStates: Record<string, unknown> = {};
|
|
170
|
-
const sourceDescriptors = {} as
|
|
171
|
-
const
|
|
170
|
+
const sourceDescriptors = {} as BlankStackDescriptorSources<TDescriptor>;
|
|
171
|
+
const blankStackDescriptors = {} as BlankStackDescriptors<TDescriptor>;
|
|
172
172
|
let shouldShowFloatOverlay = false;
|
|
173
173
|
|
|
174
174
|
for (let sceneIndex = 0; sceneIndex < routes.length; sceneIndex++) {
|
|
@@ -215,7 +215,7 @@ const buildBaseScenes = <
|
|
|
215
215
|
routeKeys.push(route.key);
|
|
216
216
|
routeChildStates[route.key] = routeChildState;
|
|
217
217
|
sourceDescriptors[route.key] = sourceDescriptor;
|
|
218
|
-
|
|
218
|
+
blankStackDescriptors[route.key] = descriptor;
|
|
219
219
|
|
|
220
220
|
if (!shouldShowFloatOverlay) {
|
|
221
221
|
shouldShowFloatOverlay = isOverlayVisible(sourceDescriptor?.options);
|
|
@@ -231,7 +231,7 @@ const buildBaseScenes = <
|
|
|
231
231
|
scenes,
|
|
232
232
|
routeChildStates,
|
|
233
233
|
sourceDescriptors,
|
|
234
|
-
descriptors:
|
|
234
|
+
descriptors: blankStackDescriptors,
|
|
235
235
|
routeKeys,
|
|
236
236
|
shouldShowFloatOverlay,
|
|
237
237
|
};
|
|
@@ -244,7 +244,7 @@ const withSceneRelationships = <TDescriptor extends BaseStackDescriptor>({
|
|
|
244
244
|
previousState,
|
|
245
245
|
}: {
|
|
246
246
|
scenes: BaseStackScene<TDescriptor>[];
|
|
247
|
-
sourceDescriptors:
|
|
247
|
+
sourceDescriptors: BlankStackDescriptorSources<TDescriptor>;
|
|
248
248
|
closingRouteKeys: ReadonlySet<string>;
|
|
249
249
|
previousState?: LocalRoutesState<TDescriptor>;
|
|
250
250
|
}): BaseStackScene<TDescriptor>[] => {
|
|
@@ -308,11 +308,11 @@ const withSceneRelationships = <TDescriptor extends BaseStackDescriptor>({
|
|
|
308
308
|
return nextScenes;
|
|
309
309
|
};
|
|
310
310
|
|
|
311
|
-
export const
|
|
311
|
+
export const buildBlankStackState = <
|
|
312
312
|
TDescriptor extends BaseStackDescriptor,
|
|
313
313
|
TNavigation extends BaseStackNavigation,
|
|
314
314
|
>(
|
|
315
|
-
params:
|
|
315
|
+
params: BuildBlankStackStateParams<TDescriptor, TNavigation>,
|
|
316
316
|
): LocalRoutesState<TDescriptor> => {
|
|
317
317
|
const activityWindow = getSceneActivityWindow(params);
|
|
318
318
|
const focusedRouteKey =
|
|
@@ -322,7 +322,7 @@ export const buildManagedStackState = <
|
|
|
322
322
|
scenes: baseScenes,
|
|
323
323
|
routeChildStates,
|
|
324
324
|
sourceDescriptors,
|
|
325
|
-
descriptors:
|
|
325
|
+
descriptors: blankStackDescriptors,
|
|
326
326
|
routeKeys,
|
|
327
327
|
shouldShowFloatOverlay,
|
|
328
328
|
} = buildBaseScenes({
|
|
@@ -343,9 +343,12 @@ export const buildManagedStackState = <
|
|
|
343
343
|
routes: params.routes,
|
|
344
344
|
descriptors:
|
|
345
345
|
params.previousState &&
|
|
346
|
-
areDescriptorsEqual(
|
|
346
|
+
areDescriptorsEqual(
|
|
347
|
+
params.previousState.descriptors,
|
|
348
|
+
blankStackDescriptors,
|
|
349
|
+
)
|
|
347
350
|
? params.previousState.descriptors
|
|
348
|
-
:
|
|
351
|
+
: blankStackDescriptors,
|
|
349
352
|
sourceDescriptors:
|
|
350
353
|
params.previousState &&
|
|
351
354
|
areDescriptorsEqual(
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { BlankStackProviderProps } from "../../../../types/providers/blank-stack-provider.types";
|
|
2
2
|
import type {
|
|
3
3
|
BaseStackDescriptor,
|
|
4
4
|
BaseStackNavigation,
|
|
5
5
|
RouteWithKey,
|
|
6
|
-
} from "
|
|
7
|
-
import {
|
|
6
|
+
} from "../../../../types/stack.types";
|
|
7
|
+
import { buildBlankStackState } from "./build-blank-stack-state";
|
|
8
|
+
import { reconcileBlankStackRoutes } from "./reconcile-blank-stack-routes";
|
|
8
9
|
import {
|
|
9
10
|
areDescriptorSourceMapsEquivalent,
|
|
10
11
|
areDescriptorsEqual,
|
|
@@ -12,17 +13,16 @@ import {
|
|
|
12
13
|
getRouteChildStateMap,
|
|
13
14
|
routesHaveSameKeys,
|
|
14
15
|
setsAreEqual,
|
|
15
|
-
} from "./
|
|
16
|
-
import {
|
|
17
|
-
import type { LocalRoutesState, ManagedRoutes } from "./types";
|
|
16
|
+
} from "./state-equality";
|
|
17
|
+
import type { BlankStackRoutes, LocalRoutesState } from "./types";
|
|
18
18
|
|
|
19
|
-
type
|
|
19
|
+
type DeriveBlankStackStateParams<
|
|
20
20
|
TDescriptor extends BaseStackDescriptor,
|
|
21
21
|
TNavigation extends BaseStackNavigation,
|
|
22
22
|
> = {
|
|
23
|
-
props:
|
|
23
|
+
props: BlankStackProviderProps<TDescriptor, TNavigation>;
|
|
24
24
|
current: LocalRoutesState<TDescriptor>;
|
|
25
|
-
previousRoutesSnapshot:
|
|
25
|
+
previousRoutesSnapshot: BlankStackRoutes<TDescriptor>;
|
|
26
26
|
closingRouteKeys: Set<string>;
|
|
27
27
|
};
|
|
28
28
|
|
|
@@ -36,7 +36,7 @@ const routesAreIdentical = <Route extends RouteWithKey>(
|
|
|
36
36
|
return a.every((route, index) => route === b[index]);
|
|
37
37
|
};
|
|
38
38
|
|
|
39
|
-
export const
|
|
39
|
+
export const deriveBlankStackState = <
|
|
40
40
|
TDescriptor extends BaseStackDescriptor,
|
|
41
41
|
TNavigation extends BaseStackNavigation,
|
|
42
42
|
>({
|
|
@@ -44,7 +44,7 @@ export const deriveManagedStackState = <
|
|
|
44
44
|
current,
|
|
45
45
|
previousRoutesSnapshot,
|
|
46
46
|
closingRouteKeys,
|
|
47
|
-
}:
|
|
47
|
+
}: DeriveBlankStackStateParams<
|
|
48
48
|
TDescriptor,
|
|
49
49
|
TNavigation
|
|
50
50
|
>): LocalRoutesState<TDescriptor> => {
|
|
@@ -87,7 +87,7 @@ export const deriveManagedStackState = <
|
|
|
87
87
|
return current;
|
|
88
88
|
}
|
|
89
89
|
|
|
90
|
-
const result =
|
|
90
|
+
const result = reconcileBlankStackRoutes({
|
|
91
91
|
current,
|
|
92
92
|
previousRoutesSnapshot,
|
|
93
93
|
nextRoutesSnapshot,
|
|
@@ -109,7 +109,7 @@ export const deriveManagedStackState = <
|
|
|
109
109
|
return current;
|
|
110
110
|
}
|
|
111
111
|
|
|
112
|
-
return
|
|
112
|
+
return buildBlankStackState({
|
|
113
113
|
props,
|
|
114
114
|
routes: routesChanged ? result.routes : current.routes,
|
|
115
115
|
descriptors: descriptorsChanged
|
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import type { RouteWithKey } from "../../types/stack.types";
|
|
1
|
+
import type { RouteWithKey } from "../../../../../types/stack.types";
|
|
3
2
|
import { composeDescriptors } from "./compose-descriptors";
|
|
4
3
|
|
|
5
|
-
type ClosingRouteKeys = Set<string> | ReturnType<typeof useClosingRouteKeys>;
|
|
6
|
-
|
|
7
4
|
type SyncRoutesWithRemovedParams<
|
|
8
5
|
Route extends RouteWithKey,
|
|
9
6
|
DescriptorMap extends Record<string, unknown>,
|
|
@@ -12,36 +9,7 @@ type SyncRoutesWithRemovedParams<
|
|
|
12
9
|
prevDescriptors: DescriptorMap;
|
|
13
10
|
nextRoutes: Route[];
|
|
14
11
|
nextDescriptors: DescriptorMap;
|
|
15
|
-
closingRouteKeys:
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
const addClosingRouteKey = (
|
|
19
|
-
closingRouteKeys: ClosingRouteKeys,
|
|
20
|
-
key: string,
|
|
21
|
-
) => {
|
|
22
|
-
closingRouteKeys.add(key);
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const deleteClosingRouteKey = (
|
|
26
|
-
closingRouteKeys: ClosingRouteKeys,
|
|
27
|
-
key: string,
|
|
28
|
-
) => {
|
|
29
|
-
if (closingRouteKeys instanceof Set) {
|
|
30
|
-
closingRouteKeys.delete(key);
|
|
31
|
-
return;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
closingRouteKeys.remove(key);
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
const getClosingRouteKeyValues = (
|
|
38
|
-
closingRouteKeys: ClosingRouteKeys,
|
|
39
|
-
): Iterable<string> => {
|
|
40
|
-
if (closingRouteKeys instanceof Set) {
|
|
41
|
-
return closingRouteKeys;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return closingRouteKeys.ref.current;
|
|
12
|
+
closingRouteKeys: Set<string>;
|
|
45
13
|
};
|
|
46
14
|
|
|
47
15
|
/**
|
|
@@ -91,16 +59,16 @@ export const syncRoutesWithRemoved = <
|
|
|
91
59
|
|
|
92
60
|
if (nextRouteWasPresent && !previousRouteStillPresent) {
|
|
93
61
|
// Previous route was removed, mark as closing
|
|
94
|
-
|
|
62
|
+
closingRouteKeys.add(previousFocusedRoute.key);
|
|
95
63
|
|
|
96
64
|
derivedRoutes.push(previousFocusedRoute);
|
|
97
65
|
} else {
|
|
98
66
|
// Next route is now active, not closing
|
|
99
|
-
|
|
67
|
+
closingRouteKeys.delete(nextFocusedRoute.key);
|
|
100
68
|
|
|
101
69
|
if (!previousRouteStillPresent) {
|
|
102
70
|
// Previous route needs to be inserted for transition
|
|
103
|
-
|
|
71
|
+
closingRouteKeys.delete(previousFocusedRoute.key);
|
|
104
72
|
|
|
105
73
|
const insertIndex = Math.max(derivedRoutes.length - 1, 0);
|
|
106
74
|
derivedRoutes.splice(insertIndex, 0, previousFocusedRoute);
|
|
@@ -108,14 +76,14 @@ export const syncRoutesWithRemoved = <
|
|
|
108
76
|
}
|
|
109
77
|
} else if (nextFocusedRoute) {
|
|
110
78
|
// Same focused route, ensure it's not marked as closing
|
|
111
|
-
|
|
79
|
+
closingRouteKeys.delete(nextFocusedRoute.key);
|
|
112
80
|
}
|
|
113
81
|
|
|
114
82
|
// Clean up closing keys that are no longer in the route list
|
|
115
83
|
const activeKeys = new Set(derivedRoutes.map((route) => route.key));
|
|
116
|
-
for (const key of Array.from(
|
|
84
|
+
for (const key of Array.from(closingRouteKeys)) {
|
|
117
85
|
if (!activeKeys.has(key)) {
|
|
118
|
-
|
|
86
|
+
closingRouteKeys.delete(key);
|
|
119
87
|
}
|
|
120
88
|
}
|
|
121
89
|
|
|
@@ -1,24 +1,25 @@
|
|
|
1
1
|
import type {
|
|
2
2
|
BaseStackDescriptor,
|
|
3
3
|
RouteWithKey,
|
|
4
|
-
} from "
|
|
5
|
-
import { composeDescriptors } from "
|
|
6
|
-
import { syncRoutesWithRemoved } from "
|
|
7
|
-
import { routesHaveSameKeys } from "./
|
|
4
|
+
} from "../../../../types/stack.types";
|
|
5
|
+
import { composeDescriptors } from "./navigation/compose-descriptors";
|
|
6
|
+
import { syncRoutesWithRemoved } from "./navigation/sync-routes-with-removed";
|
|
7
|
+
import { routesHaveSameKeys } from "./state-equality";
|
|
8
8
|
import type {
|
|
9
|
+
BlankStackDescriptorSources,
|
|
10
|
+
BlankStackRoutes,
|
|
9
11
|
LocalRoutesState,
|
|
10
|
-
ManagedDescriptorSources,
|
|
11
|
-
ManagedRoutes,
|
|
12
12
|
ReconciledRoutes,
|
|
13
13
|
} from "./types";
|
|
14
14
|
|
|
15
|
-
type
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
15
|
+
type ReconcileBlankStackRoutesParams<TDescriptor extends BaseStackDescriptor> =
|
|
16
|
+
{
|
|
17
|
+
current: LocalRoutesState<TDescriptor>;
|
|
18
|
+
previousRoutesSnapshot: BlankStackRoutes<TDescriptor>;
|
|
19
|
+
nextRoutesSnapshot: BlankStackRoutes<TDescriptor>;
|
|
20
|
+
nextDescriptors: BlankStackDescriptorSources<TDescriptor>;
|
|
21
|
+
closingRouteKeys: Set<string>;
|
|
22
|
+
};
|
|
22
23
|
|
|
23
24
|
const alignRoutesWithLatest = <
|
|
24
25
|
Route extends RouteWithKey,
|
|
@@ -80,7 +81,7 @@ const acceptAlreadyClosingRouteRemovals = <
|
|
|
80
81
|
nextRoutesSnapshot,
|
|
81
82
|
nextDescriptors,
|
|
82
83
|
closingRouteKeys,
|
|
83
|
-
}:
|
|
84
|
+
}: ReconcileBlankStackRoutesParams<TDescriptor>): ReconciledRoutes<TDescriptor> | null => {
|
|
84
85
|
const nextRouteKeys = new Set(nextRoutesSnapshot.map((route) => route.key));
|
|
85
86
|
const acceptedRemovedKeys = new Set<string>();
|
|
86
87
|
|
|
@@ -116,10 +117,10 @@ const acceptAlreadyClosingRouteRemovals = <
|
|
|
116
117
|
const routes = [
|
|
117
118
|
...nextRoutesSnapshot,
|
|
118
119
|
...remainingClosingRoutes,
|
|
119
|
-
] as
|
|
120
|
+
] as BlankStackRoutes<TDescriptor>;
|
|
120
121
|
const descriptors = {
|
|
121
122
|
...nextDescriptors,
|
|
122
|
-
} as
|
|
123
|
+
} as BlankStackDescriptorSources<TDescriptor>;
|
|
123
124
|
|
|
124
125
|
for (const route of remainingClosingRoutes) {
|
|
125
126
|
const descriptor = current.sourceDescriptors[route.key];
|
|
@@ -134,8 +135,10 @@ const acceptAlreadyClosingRouteRemovals = <
|
|
|
134
135
|
};
|
|
135
136
|
};
|
|
136
137
|
|
|
137
|
-
export const
|
|
138
|
-
|
|
138
|
+
export const reconcileBlankStackRoutes = <
|
|
139
|
+
TDescriptor extends BaseStackDescriptor,
|
|
140
|
+
>(
|
|
141
|
+
params: ReconcileBlankStackRoutesParams<TDescriptor>,
|
|
139
142
|
): ReconciledRoutes<TDescriptor> => {
|
|
140
143
|
const {
|
|
141
144
|
current,
|
|
@@ -159,8 +162,9 @@ export const reconcileManagedRoutes = <TDescriptor extends BaseStackDescriptor>(
|
|
|
159
162
|
);
|
|
160
163
|
|
|
161
164
|
return {
|
|
162
|
-
routes: result.routes as
|
|
163
|
-
descriptors:
|
|
165
|
+
routes: result.routes as BlankStackRoutes<TDescriptor>,
|
|
166
|
+
descriptors:
|
|
167
|
+
result.descriptors as BlankStackDescriptorSources<TDescriptor>,
|
|
164
168
|
};
|
|
165
169
|
}
|
|
166
170
|
|
|
@@ -182,7 +186,7 @@ export const reconcileManagedRoutes = <TDescriptor extends BaseStackDescriptor>(
|
|
|
182
186
|
});
|
|
183
187
|
|
|
184
188
|
return {
|
|
185
|
-
routes: result.routes as
|
|
186
|
-
descriptors: result.descriptors as
|
|
189
|
+
routes: result.routes as BlankStackRoutes<TDescriptor>,
|
|
190
|
+
descriptors: result.descriptors as BlankStackDescriptorSources<TDescriptor>,
|
|
187
191
|
};
|
|
188
192
|
};
|
|
@@ -2,8 +2,8 @@ import type {
|
|
|
2
2
|
BaseStackDescriptor,
|
|
3
3
|
RouteWithKey,
|
|
4
4
|
StackDescriptorSource,
|
|
5
|
-
} from "
|
|
6
|
-
import type {
|
|
5
|
+
} from "../../../../types/stack.types";
|
|
6
|
+
import type { BlankStackDescriptorSources } from "./types";
|
|
7
7
|
|
|
8
8
|
export const areDescriptorsEqual = <
|
|
9
9
|
DescriptorMap extends Record<string, unknown>,
|
|
@@ -135,8 +135,8 @@ export const areDescriptorSourcesEquivalent = <
|
|
|
135
135
|
export const areDescriptorSourceMapsEquivalent = <
|
|
136
136
|
TDescriptor extends BaseStackDescriptor,
|
|
137
137
|
>(
|
|
138
|
-
previous:
|
|
139
|
-
next:
|
|
138
|
+
previous: BlankStackDescriptorSources<TDescriptor>,
|
|
139
|
+
next: BlankStackDescriptorSources<TDescriptor>,
|
|
140
140
|
): boolean => {
|
|
141
141
|
if (previous === next) return true;
|
|
142
142
|
|
|
@@ -1,25 +1,26 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { BlankStackProviderProps } from "../../../../types/providers/blank-stack-provider.types";
|
|
2
2
|
import type {
|
|
3
3
|
BaseStackDescriptor,
|
|
4
4
|
BaseStackNavigation,
|
|
5
5
|
BaseStackRoute,
|
|
6
6
|
BaseStackScene,
|
|
7
7
|
StackDescriptorSource,
|
|
8
|
-
} from "
|
|
8
|
+
} from "../../../../types/stack.types";
|
|
9
9
|
|
|
10
|
-
export type
|
|
10
|
+
export type BlankStackRoutes<TDescriptor extends BaseStackDescriptor> =
|
|
11
11
|
TDescriptor["route"][];
|
|
12
12
|
|
|
13
|
-
export type
|
|
13
|
+
export type BlankStackDescriptors<TDescriptor extends BaseStackDescriptor> =
|
|
14
14
|
Record<string, TDescriptor>;
|
|
15
15
|
|
|
16
|
-
export type
|
|
17
|
-
|
|
16
|
+
export type BlankStackDescriptorSources<
|
|
17
|
+
TDescriptor extends BaseStackDescriptor,
|
|
18
|
+
> = Record<string, StackDescriptorSource<TDescriptor>>;
|
|
18
19
|
|
|
19
20
|
export type LocalRoutesState<TDescriptor extends BaseStackDescriptor> = {
|
|
20
|
-
routes:
|
|
21
|
-
descriptors:
|
|
22
|
-
sourceDescriptors:
|
|
21
|
+
routes: BlankStackRoutes<TDescriptor>;
|
|
22
|
+
descriptors: BlankStackDescriptors<TDescriptor>;
|
|
23
|
+
sourceDescriptors: BlankStackDescriptorSources<TDescriptor>;
|
|
23
24
|
focusedRouteKey?: string;
|
|
24
25
|
routeChildStates: Record<string, unknown>;
|
|
25
26
|
scenes: BaseStackScene<TDescriptor>[];
|
|
@@ -28,26 +29,26 @@ export type LocalRoutesState<TDescriptor extends BaseStackDescriptor> = {
|
|
|
28
29
|
closingRouteKeys: ReadonlySet<string>;
|
|
29
30
|
};
|
|
30
31
|
|
|
31
|
-
export type
|
|
32
|
+
export type BlankStackControllerSnapshot<
|
|
32
33
|
TDescriptor extends BaseStackDescriptor,
|
|
33
34
|
> = {
|
|
34
35
|
state: LocalRoutesState<TDescriptor>;
|
|
35
36
|
};
|
|
36
37
|
|
|
37
|
-
export type
|
|
38
|
+
export type BlankStackController<
|
|
38
39
|
TDescriptor extends BaseStackDescriptor,
|
|
39
40
|
TNavigation extends BaseStackNavigation,
|
|
40
41
|
> = {
|
|
41
42
|
subscribe: (listener: () => void) => () => void;
|
|
42
|
-
getSnapshot: () =>
|
|
43
|
-
update: (props:
|
|
43
|
+
getSnapshot: () => BlankStackControllerSnapshot<TDescriptor>;
|
|
44
|
+
update: (props: BlankStackProviderProps<TDescriptor, TNavigation>) => void;
|
|
44
45
|
handleCloseRoute: (payload: { route: BaseStackRoute }) => void;
|
|
45
46
|
requestDismiss: (payload: { route: BaseStackRoute }) => boolean;
|
|
46
47
|
};
|
|
47
48
|
|
|
48
49
|
export type ReconciledRoutes<TDescriptor extends BaseStackDescriptor> = {
|
|
49
|
-
routes:
|
|
50
|
-
descriptors:
|
|
50
|
+
routes: BlankStackRoutes<TDescriptor>;
|
|
51
|
+
descriptors: BlankStackDescriptorSources<TDescriptor>;
|
|
51
52
|
};
|
|
52
53
|
|
|
53
54
|
export type SceneActivityWindow = {
|
package/src/shared/providers/stack/{helpers/managed-stack-state → blank-stack-state}/index.ts
RENAMED
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
import { useRef, useSyncExternalStore } from "react";
|
|
2
|
-
import type {
|
|
2
|
+
import type { BlankStackProviderProps } from "../../../types/providers/blank-stack-provider.types";
|
|
3
3
|
import type {
|
|
4
4
|
BaseStackDescriptor,
|
|
5
5
|
BaseStackNavigation,
|
|
6
|
-
} from "
|
|
6
|
+
} from "../../../types/stack.types";
|
|
7
7
|
import {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
} from "./
|
|
8
|
+
type BlankStackController,
|
|
9
|
+
createBlankStackController,
|
|
10
|
+
} from "./blank-stack-controller";
|
|
11
11
|
|
|
12
|
-
export const
|
|
12
|
+
export const useBlankStackState = <
|
|
13
13
|
TDescriptor extends BaseStackDescriptor,
|
|
14
14
|
TNavigation extends BaseStackNavigation,
|
|
15
15
|
>(
|
|
16
|
-
props:
|
|
16
|
+
props: BlankStackProviderProps<TDescriptor, TNavigation>,
|
|
17
17
|
) => {
|
|
18
18
|
const controllerRef = useRef<
|
|
19
|
-
|
|
19
|
+
BlankStackController<TDescriptor, TNavigation> | undefined
|
|
20
20
|
>(undefined);
|
|
21
21
|
|
|
22
22
|
if (!controllerRef.current) {
|
|
23
|
-
controllerRef.current =
|
|
23
|
+
controllerRef.current = createBlankStackController(props);
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
const controller = controllerRef.current;
|