react-native-screen-transitions 3.6.0-beta.0 → 3.7.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/lib/commonjs/blank-stack/components/stack-view.js +35 -39
- package/lib/commonjs/blank-stack/components/stack-view.js.map +1 -1
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js +7 -14
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/commonjs/component-stack/components/stack-view.js +4 -11
- package/lib/commonjs/component-stack/components/stack-view.js.map +1 -1
- package/lib/commonjs/component-stack/navigators/create-component-stack-navigator.js +1 -1
- package/lib/commonjs/native-stack/navigators/createNativeStackNavigator.js +6 -0
- package/lib/commonjs/native-stack/navigators/createNativeStackNavigator.js.map +1 -1
- package/lib/commonjs/shared/adapters/with-screen-transitions/context.js +28 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/context.js.map +1 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/index.js +75 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/index.js.map +1 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/options.js +103 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/options.js.map +1 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/stack-layout.js +143 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/stack-layout.js.map +1 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/types.js +6 -0
- package/lib/commonjs/shared/adapters/with-screen-transitions/types.js.map +1 -0
- package/lib/commonjs/shared/components/activity/helpers.js +9 -0
- package/lib/commonjs/shared/components/activity/helpers.js.map +1 -0
- package/lib/commonjs/shared/components/activity/index.js +20 -0
- package/lib/commonjs/shared/components/activity/index.js.map +1 -0
- package/lib/commonjs/shared/components/activity/variants/activity-container.js +29 -0
- package/lib/commonjs/shared/components/activity/variants/activity-container.js.map +1 -0
- package/lib/commonjs/shared/components/activity/variants/activity-screen.js +107 -0
- package/lib/commonjs/shared/components/activity/variants/activity-screen.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-measurer.js +10 -4
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-measurer.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/utils/measured-bounds.js +13 -1
- package/lib/commonjs/shared/components/create-boundary-component/utils/measured-bounds.js.map +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js +8 -17
- package/lib/commonjs/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js.map +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/index.js +1 -1
- package/lib/commonjs/shared/components/screen-lifecycle/index.js.map +1 -1
- package/lib/commonjs/shared/hooks/navigation/use-navigation-helpers.js +10 -4
- package/lib/commonjs/shared/hooks/navigation/use-navigation-helpers.js.map +1 -1
- package/lib/commonjs/shared/hooks/navigation/use-stack.js +63 -6
- package/lib/commonjs/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/commonjs/shared/index.js +8 -0
- package/lib/commonjs/shared/index.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/descriptors/descriptors.provider.js +18 -29
- package/lib/commonjs/shared/providers/screen/descriptors/descriptors.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/descriptors/index.js +6 -0
- package/lib/commonjs/shared/providers/screen/descriptors/index.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/resolve-ownership.js +2 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/resolve-ownership.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/use-walk-up-and-register-shadowing-claims.js +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/ownership/use-walk-up-and-register-shadowing-claims.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-lifecycle.js +4 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/pan-lifecycle.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/pan/use-pan-behavior.js +4 -3
- package/lib/commonjs/shared/providers/screen/gestures/pan/use-pan-behavior.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-lifecycle.js +4 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/pinch-lifecycle.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/gestures/pinch/use-pinch-behavior.js +4 -3
- package/lib/commonjs/shared/providers/screen/gestures/pinch/use-pinch-behavior.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/styles/hooks/use-maybe-block-visibility.js +16 -1
- package/lib/commonjs/shared/providers/screen/styles/hooks/use-maybe-block-visibility.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/direct.provider.js +4 -3
- package/lib/commonjs/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js +199 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js +62 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js +81 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.js +123 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/types.js +6 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/helpers/types.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/index.js +24 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/index.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js +131 -0
- package/lib/commonjs/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js.map +1 -0
- package/lib/commonjs/shared/providers/stack/managed.provider.js +18 -29
- package/lib/commonjs/shared/providers/stack/managed.provider.js.map +1 -1
- package/lib/commonjs/shared/types/stack.types.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/navigation/zoom/build.js +47 -50
- package/lib/commonjs/shared/utils/bounds/navigation/zoom/build.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/navigation/zoom/config.js +1 -1
- package/lib/commonjs/shared/utils/create-provider.js +99 -10
- package/lib/commonjs/shared/utils/create-provider.js.map +1 -1
- package/lib/commonjs/shared/utils/navigation/resolve-scene-neighbors.js +8 -5
- package/lib/commonjs/shared/utils/navigation/resolve-scene-neighbors.js.map +1 -1
- package/lib/commonjs/shared/utils/navigation/sync-routes-with-removed.js +23 -6
- package/lib/commonjs/shared/utils/navigation/sync-routes-with-removed.js.map +1 -1
- package/lib/commonjs/shared/utils/visibility-block-offset.js +13 -0
- package/lib/commonjs/shared/utils/visibility-block-offset.js.map +1 -0
- package/lib/module/blank-stack/components/stack-view.js +36 -40
- package/lib/module/blank-stack/components/stack-view.js.map +1 -1
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js +7 -14
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/module/component-stack/components/stack-view.js +4 -11
- package/lib/module/component-stack/components/stack-view.js.map +1 -1
- package/lib/module/component-stack/navigators/create-component-stack-navigator.js +1 -1
- package/lib/module/native-stack/navigators/createNativeStackNavigator.js +6 -0
- package/lib/module/native-stack/navigators/createNativeStackNavigator.js.map +1 -1
- package/lib/module/shared/adapters/with-screen-transitions/context.js +23 -0
- package/lib/module/shared/adapters/with-screen-transitions/context.js.map +1 -0
- package/lib/module/shared/adapters/with-screen-transitions/index.js +66 -0
- package/lib/module/shared/adapters/with-screen-transitions/index.js.map +1 -0
- package/lib/module/shared/adapters/with-screen-transitions/options.js +98 -0
- package/lib/module/shared/adapters/with-screen-transitions/options.js.map +1 -0
- package/lib/module/shared/adapters/with-screen-transitions/stack-layout.js +138 -0
- package/lib/module/shared/adapters/with-screen-transitions/stack-layout.js.map +1 -0
- package/lib/module/shared/adapters/with-screen-transitions/types.js +4 -0
- package/lib/module/shared/adapters/with-screen-transitions/types.js.map +1 -0
- package/lib/module/shared/components/activity/helpers.js +5 -0
- package/lib/module/shared/components/activity/helpers.js.map +1 -0
- package/lib/module/shared/components/activity/index.js +5 -0
- package/lib/module/shared/components/activity/index.js.map +1 -0
- package/lib/module/shared/components/activity/variants/activity-container.js +24 -0
- package/lib/module/shared/components/activity/variants/activity-container.js.map +1 -0
- package/lib/module/shared/components/activity/variants/activity-screen.js +103 -0
- package/lib/module/shared/components/activity/variants/activity-screen.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/hooks/use-measurer.js +11 -5
- package/lib/module/shared/components/create-boundary-component/hooks/use-measurer.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/utils/measured-bounds.js +11 -0
- package/lib/module/shared/components/create-boundary-component/utils/measured-bounds.js.map +1 -1
- package/lib/module/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js +8 -17
- package/lib/module/shared/components/screen-lifecycle/hooks/use-close-transition-intent.js.map +1 -1
- package/lib/module/shared/components/screen-lifecycle/index.js +1 -1
- package/lib/module/shared/components/screen-lifecycle/index.js.map +1 -1
- package/lib/module/shared/hooks/navigation/use-navigation-helpers.js +11 -5
- package/lib/module/shared/hooks/navigation/use-navigation-helpers.js.map +1 -1
- package/lib/module/shared/hooks/navigation/use-stack.js +63 -6
- package/lib/module/shared/hooks/navigation/use-stack.js.map +1 -1
- package/lib/module/shared/index.js +3 -0
- package/lib/module/shared/index.js.map +1 -1
- package/lib/module/shared/providers/screen/descriptors/descriptors.provider.js +17 -29
- package/lib/module/shared/providers/screen/descriptors/descriptors.provider.js.map +1 -1
- package/lib/module/shared/providers/screen/descriptors/index.js +1 -1
- package/lib/module/shared/providers/screen/descriptors/index.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/ownership/resolve-ownership.js +2 -1
- package/lib/module/shared/providers/screen/gestures/ownership/resolve-ownership.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/ownership/use-walk-up-and-register-shadowing-claims.js +2 -2
- package/lib/module/shared/providers/screen/gestures/ownership/use-walk-up-and-register-shadowing-claims.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/pan/pan-lifecycle.js +5 -2
- package/lib/module/shared/providers/screen/gestures/pan/pan-lifecycle.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/pan/use-pan-behavior.js +4 -3
- package/lib/module/shared/providers/screen/gestures/pan/use-pan-behavior.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-lifecycle.js +5 -2
- package/lib/module/shared/providers/screen/gestures/pinch/pinch-lifecycle.js.map +1 -1
- package/lib/module/shared/providers/screen/gestures/pinch/use-pinch-behavior.js +4 -3
- package/lib/module/shared/providers/screen/gestures/pinch/use-pinch-behavior.js.map +1 -1
- package/lib/module/shared/providers/screen/styles/hooks/use-maybe-block-visibility.js +16 -1
- package/lib/module/shared/providers/screen/styles/hooks/use-maybe-block-visibility.js.map +1 -1
- package/lib/module/shared/providers/stack/direct.provider.js +5 -4
- package/lib/module/shared/providers/stack/direct.provider.js.map +1 -1
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js +194 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js +57 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js +69 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.js +118 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/types.js +4 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/helpers/types.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/index.js +19 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/index.js.map +1 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js +126 -0
- package/lib/module/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.js.map +1 -0
- package/lib/module/shared/providers/stack/managed.provider.js +19 -30
- package/lib/module/shared/providers/stack/managed.provider.js.map +1 -1
- package/lib/module/shared/types/stack.types.js.map +1 -1
- package/lib/module/shared/utils/bounds/navigation/zoom/build.js +45 -48
- package/lib/module/shared/utils/bounds/navigation/zoom/build.js.map +1 -1
- package/lib/module/shared/utils/bounds/navigation/zoom/config.js +1 -1
- package/lib/module/shared/utils/create-provider.js +100 -11
- package/lib/module/shared/utils/create-provider.js.map +1 -1
- package/lib/module/shared/utils/navigation/resolve-scene-neighbors.js +8 -5
- package/lib/module/shared/utils/navigation/resolve-scene-neighbors.js.map +1 -1
- package/lib/module/shared/utils/navigation/sync-routes-with-removed.js +23 -6
- package/lib/module/shared/utils/navigation/sync-routes-with-removed.js.map +1 -1
- package/lib/module/shared/utils/visibility-block-offset.js +8 -0
- package/lib/module/shared/utils/visibility-block-offset.js.map +1 -0
- package/lib/typescript/blank-stack/components/stack-view.d.ts.map +1 -1
- package/lib/typescript/blank-stack/index.d.ts +1 -1
- package/lib/typescript/blank-stack/index.d.ts.map +1 -1
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts +4 -6
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts.map +1 -1
- package/lib/typescript/blank-stack/types.d.ts +41 -29
- package/lib/typescript/blank-stack/types.d.ts.map +1 -1
- package/lib/typescript/component-stack/components/stack-view.d.ts.map +1 -1
- package/lib/typescript/component-stack/navigators/create-component-stack-navigator.d.ts +1 -1
- package/lib/typescript/native-stack/navigators/createNativeStackNavigator.d.ts +5 -0
- package/lib/typescript/native-stack/navigators/createNativeStackNavigator.d.ts.map +1 -1
- package/lib/typescript/native-stack/types.d.ts +25 -0
- package/lib/typescript/native-stack/types.d.ts.map +1 -1
- package/lib/typescript/shared/adapters/with-screen-transitions/context.d.ts +15 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/context.d.ts.map +1 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/index.d.ts +11 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/index.d.ts.map +1 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/options.d.ts +16 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/options.d.ts.map +1 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/stack-layout.d.ts +12 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/stack-layout.d.ts.map +1 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/types.d.ts +24 -0
- package/lib/typescript/shared/adapters/with-screen-transitions/types.d.ts.map +1 -0
- package/lib/typescript/shared/components/activity/helpers.d.ts +4 -0
- package/lib/typescript/shared/components/activity/helpers.d.ts.map +1 -0
- package/lib/typescript/shared/components/activity/index.d.ts +3 -0
- package/lib/typescript/shared/components/activity/index.d.ts.map +1 -0
- package/lib/typescript/shared/components/activity/variants/activity-container.d.ts +6 -0
- package/lib/typescript/shared/components/activity/variants/activity-container.d.ts.map +1 -0
- package/lib/typescript/shared/components/activity/variants/activity-screen.d.ts +13 -0
- package/lib/typescript/shared/components/activity/variants/activity-screen.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-measurer.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/index.d.ts +2 -2
- package/lib/typescript/shared/components/create-boundary-component/utils/measured-bounds.d.ts +1 -0
- package/lib/typescript/shared/components/create-boundary-component/utils/measured-bounds.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-close-transition-intent.d.ts +1 -2
- package/lib/typescript/shared/components/screen-lifecycle/hooks/use-close-transition-intent.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/navigation/use-navigation-helpers.d.ts +1 -0
- package/lib/typescript/shared/hooks/navigation/use-navigation-helpers.d.ts.map +1 -1
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts +13 -1
- package/lib/typescript/shared/hooks/navigation/use-stack.d.ts.map +1 -1
- package/lib/typescript/shared/index.d.ts +15 -11
- package/lib/typescript/shared/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/descriptors/descriptors.provider.d.ts +11 -3
- package/lib/typescript/shared/providers/screen/descriptors/descriptors.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/descriptors/index.d.ts +1 -1
- package/lib/typescript/shared/providers/screen/descriptors/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/ownership/resolve-ownership.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-lifecycle.d.ts +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/pan-lifecycle.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pan/use-pan-behavior.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-lifecycle.d.ts +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/pinch-lifecycle.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/gestures/pinch/use-pinch-behavior.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/styles/hooks/use-maybe-block-visibility.d.ts +3 -1
- package/lib/typescript/shared/providers/screen/styles/hooks/use-maybe-block-visibility.d.ts.map +1 -1
- package/lib/typescript/shared/providers/stack/direct.provider.d.ts.map +1 -1
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.d.ts +13 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.d.ts +11 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/types.d.ts +40 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/helpers/types.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/index.d.ts +12 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/index.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.d.ts +13 -0
- package/lib/typescript/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.d.ts.map +1 -0
- package/lib/typescript/shared/providers/stack/managed.provider.d.ts.map +1 -1
- package/lib/typescript/shared/types/bounds.types.d.ts +27 -0
- package/lib/typescript/shared/types/bounds.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/index.d.ts +2 -2
- package/lib/typescript/shared/types/index.d.ts.map +1 -1
- package/lib/typescript/shared/types/providers/managed-stack.types.d.ts +3 -9
- package/lib/typescript/shared/types/providers/managed-stack.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/screen.types.d.ts +24 -0
- package/lib/typescript/shared/types/screen.types.d.ts.map +1 -1
- package/lib/typescript/shared/types/stack.types.d.ts +7 -0
- package/lib/typescript/shared/types/stack.types.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/navigation/zoom/build.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/navigation/zoom/config.d.ts +1 -1
- package/lib/typescript/shared/utils/create-provider.d.ts +17 -3
- package/lib/typescript/shared/utils/create-provider.d.ts.map +1 -1
- package/lib/typescript/shared/utils/navigation/resolve-scene-neighbors.d.ts +2 -1
- package/lib/typescript/shared/utils/navigation/resolve-scene-neighbors.d.ts.map +1 -1
- package/lib/typescript/shared/utils/navigation/sync-routes-with-removed.d.ts +2 -1
- package/lib/typescript/shared/utils/navigation/sync-routes-with-removed.d.ts.map +1 -1
- package/lib/typescript/shared/utils/visibility-block-offset.d.ts +2 -0
- package/lib/typescript/shared/utils/visibility-block-offset.d.ts.map +1 -0
- package/package.json +11 -1
- package/src/blank-stack/components/stack-view.tsx +54 -48
- package/src/blank-stack/index.ts +1 -0
- package/src/blank-stack/navigators/create-blank-stack-navigator.tsx +7 -15
- package/src/blank-stack/types.ts +44 -29
- package/src/component-stack/components/stack-view.tsx +4 -11
- package/src/component-stack/navigators/create-component-stack-navigator.tsx +1 -1
- package/src/native-stack/navigators/createNativeStackNavigator.tsx +5 -0
- package/src/native-stack/types.ts +25 -0
- package/src/shared/adapters/with-screen-transitions/context.tsx +42 -0
- package/src/shared/adapters/with-screen-transitions/index.tsx +155 -0
- package/src/shared/adapters/with-screen-transitions/options.ts +172 -0
- package/src/shared/adapters/with-screen-transitions/stack-layout.tsx +233 -0
- package/src/shared/adapters/with-screen-transitions/types.ts +28 -0
- package/src/shared/components/activity/helpers.ts +8 -0
- package/src/shared/components/activity/index.tsx +2 -0
- package/src/shared/components/activity/variants/activity-container.tsx +25 -0
- package/src/shared/components/activity/variants/activity-screen.tsx +133 -0
- package/src/shared/components/create-boundary-component/hooks/use-measurer.ts +23 -4
- package/src/shared/components/create-boundary-component/utils/measured-bounds.ts +15 -0
- package/src/shared/components/screen-lifecycle/hooks/use-close-transition-intent.ts +9 -26
- package/src/shared/components/screen-lifecycle/index.tsx +1 -1
- package/src/shared/hooks/navigation/use-navigation-helpers.ts +9 -3
- package/src/shared/hooks/navigation/use-stack.tsx +115 -6
- package/src/shared/index.ts +9 -0
- package/src/shared/providers/screen/descriptors/descriptors.provider.tsx +31 -31
- package/src/shared/providers/screen/descriptors/index.tsx +1 -0
- package/src/shared/providers/screen/gestures/ownership/resolve-ownership.ts +2 -1
- package/src/shared/providers/screen/gestures/ownership/use-walk-up-and-register-shadowing-claims.ts +2 -2
- package/src/shared/providers/screen/gestures/pan/pan-lifecycle.ts +7 -2
- package/src/shared/providers/screen/gestures/pan/use-pan-behavior.ts +10 -2
- package/src/shared/providers/screen/gestures/pinch/pinch-lifecycle.ts +7 -2
- package/src/shared/providers/screen/gestures/pinch/use-pinch-behavior.ts +8 -3
- package/src/shared/providers/screen/styles/hooks/use-maybe-block-visibility.tsx +17 -1
- package/src/shared/providers/stack/direct.provider.tsx +13 -4
- package/src/shared/providers/stack/helpers/managed-stack-state/helpers/build-managed-stack-state.ts +368 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/helpers/derive-managed-stack-state.ts +129 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/helpers/helpers.ts +139 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/helpers/reconcile-managed-routes.ts +198 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/helpers/types.ts +57 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/index.ts +40 -0
- package/src/shared/providers/stack/helpers/managed-stack-state/managed-stack-controller.ts +160 -0
- package/src/shared/providers/stack/managed.provider.tsx +23 -39
- package/src/shared/types/bounds.types.ts +27 -0
- package/src/shared/types/index.ts +3 -0
- package/src/shared/types/providers/managed-stack.types.ts +6 -8
- package/src/shared/types/screen.types.ts +25 -0
- package/src/shared/types/stack.types.ts +11 -0
- package/src/shared/utils/bounds/navigation/zoom/build.ts +62 -71
- package/src/shared/utils/bounds/navigation/zoom/config.ts +1 -1
- package/src/shared/utils/create-provider.tsx +183 -8
- package/src/shared/utils/navigation/resolve-scene-neighbors.ts +9 -4
- package/src/shared/utils/navigation/sync-routes-with-removed.ts +38 -7
- package/src/shared/utils/visibility-block-offset.ts +4 -0
- package/lib/commonjs/blank-stack/components/stack-view.native.js +0 -64
- package/lib/commonjs/blank-stack/components/stack-view.native.js.map +0 -1
- package/lib/commonjs/shared/components/native-screen-container.js +0 -42
- package/lib/commonjs/shared/components/native-screen-container.js.map +0 -1
- package/lib/commonjs/shared/components/native-screen.js +0 -125
- package/lib/commonjs/shared/components/native-screen.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.js +0 -51
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.js +0 -15
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.js +0 -14
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.js +0 -13
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.js.map +0 -1
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/index.js +0 -101
- package/lib/commonjs/shared/providers/stack/helpers/use-local-routes/index.js.map +0 -1
- package/lib/module/blank-stack/components/stack-view.native.js +0 -60
- package/lib/module/blank-stack/components/stack-view.native.js.map +0 -1
- package/lib/module/shared/components/native-screen-container.js +0 -37
- package/lib/module/shared/components/native-screen-container.js.map +0 -1
- package/lib/module/shared/components/native-screen.js +0 -119
- package/lib/module/shared/components/native-screen.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.js +0 -47
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.js +0 -10
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.js +0 -9
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.js +0 -8
- package/lib/module/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.js.map +0 -1
- package/lib/module/shared/providers/stack/helpers/use-local-routes/index.js +0 -95
- package/lib/module/shared/providers/stack/helpers/use-local-routes/index.js.map +0 -1
- package/lib/typescript/blank-stack/components/stack-view.native.d.ts +0 -3
- package/lib/typescript/blank-stack/components/stack-view.native.d.ts.map +0 -1
- package/lib/typescript/shared/components/native-screen-container.d.ts +0 -6
- package/lib/typescript/shared/components/native-screen-container.d.ts.map +0 -1
- package/lib/typescript/shared/components/native-screen.d.ts +0 -12
- package/lib/typescript/shared/components/native-screen.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.d.ts +0 -10
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.d.ts +0 -2
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.d.ts +0 -3
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.d.ts +0 -3
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.d.ts.map +0 -1
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/index.d.ts +0 -19
- package/lib/typescript/shared/providers/stack/helpers/use-local-routes/index.d.ts.map +0 -1
- package/src/blank-stack/components/stack-view.native.tsx +0 -74
- package/src/shared/components/native-screen-container.tsx +0 -33
- package/src/shared/components/native-screen.tsx +0 -176
- package/src/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.ts +0 -65
- package/src/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.ts +0 -15
- package/src/shared/providers/stack/helpers/use-local-routes/helpers/have-same-route-keys.ts +0 -12
- package/src/shared/providers/stack/helpers/use-local-routes/helpers/routes-are-identical.ts +0 -11
- package/src/shared/providers/stack/helpers/use-local-routes/index.ts +0 -147
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
import type * as React from "react";
|
|
2
|
-
import { StyleSheet } from "react-native";
|
|
3
|
-
import Animated, {
|
|
4
|
-
Extrapolation,
|
|
5
|
-
interpolate,
|
|
6
|
-
useAnimatedProps,
|
|
7
|
-
useDerivedValue,
|
|
8
|
-
useSharedValue,
|
|
9
|
-
} from "react-native-reanimated";
|
|
10
|
-
import { Screen as RNSScreen } from "react-native-screens";
|
|
11
|
-
import { EPSILON } from "../constants";
|
|
12
|
-
import { useStack } from "../hooks/navigation/use-stack";
|
|
13
|
-
import { useManagedStackContext } from "../providers/stack/managed.provider";
|
|
14
|
-
import { AnimationStore } from "../stores/animation.store";
|
|
15
|
-
|
|
16
|
-
const PASSTHROUGH = "passthrough";
|
|
17
|
-
|
|
18
|
-
interface ScreenProps {
|
|
19
|
-
routeKey: string;
|
|
20
|
-
index: number;
|
|
21
|
-
isPreloaded: boolean;
|
|
22
|
-
children: React.ReactNode;
|
|
23
|
-
freezeOnBlur?: boolean;
|
|
24
|
-
shouldFreeze?: boolean;
|
|
25
|
-
}
|
|
26
|
-
enum ScreenActivity {
|
|
27
|
-
INACTIVE = 0,
|
|
28
|
-
TRANSITIONING_OR_BELOW_TOP = 1,
|
|
29
|
-
ON_TOP = 2,
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const POINT_NONE = "none" as const;
|
|
33
|
-
const POINT_BOX_NONE = "box-none" as const;
|
|
34
|
-
|
|
35
|
-
const AnimatedNativeScreen = Animated.createAnimatedComponent(RNSScreen);
|
|
36
|
-
|
|
37
|
-
export const NativeScreen = ({
|
|
38
|
-
routeKey,
|
|
39
|
-
index,
|
|
40
|
-
isPreloaded,
|
|
41
|
-
children,
|
|
42
|
-
freezeOnBlur,
|
|
43
|
-
shouldFreeze,
|
|
44
|
-
}: ScreenProps) => {
|
|
45
|
-
const {
|
|
46
|
-
flags: { DISABLE_NATIVE_SCREENS = false },
|
|
47
|
-
routes,
|
|
48
|
-
optimisticFocusedIndex,
|
|
49
|
-
} = useStack();
|
|
50
|
-
const { activeScreensLimit, backdropBehaviors } = useManagedStackContext();
|
|
51
|
-
|
|
52
|
-
const routesLength = routes.length;
|
|
53
|
-
const topIndex = routesLength - 1;
|
|
54
|
-
const topRouteKey = routes[topIndex]?.key ?? routeKey;
|
|
55
|
-
|
|
56
|
-
const sceneClosing = AnimationStore.getValue(routeKey, "closing");
|
|
57
|
-
const topSceneProgress = AnimationStore.getValue(topRouteKey, "progress");
|
|
58
|
-
const topSceneClosing = AnimationStore.getValue(topRouteKey, "closing");
|
|
59
|
-
const screenActivity = useSharedValue<ScreenActivity>(
|
|
60
|
-
ScreenActivity.TRANSITIONING_OR_BELOW_TOP,
|
|
61
|
-
);
|
|
62
|
-
|
|
63
|
-
useDerivedValue(() => {
|
|
64
|
-
if (!topSceneProgress) {
|
|
65
|
-
screenActivity.set(ScreenActivity.TRANSITIONING_OR_BELOW_TOP);
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
if (index < routesLength - activeScreensLimit - 1 || isPreloaded) {
|
|
70
|
-
screenActivity.set(ScreenActivity.INACTIVE);
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
const focusedIndex = optimisticFocusedIndex.get();
|
|
75
|
-
const topIsClosing =
|
|
76
|
-
topSceneClosing.get() > 0 && focusedIndex >= 0 && focusedIndex < topIndex;
|
|
77
|
-
|
|
78
|
-
if (topIsClosing) {
|
|
79
|
-
const postCloseActiveStart = Math.max(
|
|
80
|
-
0,
|
|
81
|
-
focusedIndex - activeScreensLimit + 1,
|
|
82
|
-
);
|
|
83
|
-
const next =
|
|
84
|
-
index === topIndex
|
|
85
|
-
? ScreenActivity.ON_TOP
|
|
86
|
-
: index > focusedIndex || index >= postCloseActiveStart
|
|
87
|
-
? ScreenActivity.TRANSITIONING_OR_BELOW_TOP
|
|
88
|
-
: ScreenActivity.INACTIVE;
|
|
89
|
-
|
|
90
|
-
if (next !== screenActivity.get()) {
|
|
91
|
-
screenActivity.set(next);
|
|
92
|
-
}
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
const outputValue =
|
|
97
|
-
index === topIndex
|
|
98
|
-
? ScreenActivity.ON_TOP
|
|
99
|
-
: index >= routesLength - activeScreensLimit
|
|
100
|
-
? ScreenActivity.TRANSITIONING_OR_BELOW_TOP
|
|
101
|
-
: ScreenActivity.INACTIVE;
|
|
102
|
-
|
|
103
|
-
const v = interpolate(
|
|
104
|
-
topSceneProgress.get(),
|
|
105
|
-
[0, 1 - EPSILON, 1],
|
|
106
|
-
[1, 1, outputValue],
|
|
107
|
-
Extrapolation.CLAMP,
|
|
108
|
-
);
|
|
109
|
-
|
|
110
|
-
const next = Math.trunc(v) ?? ScreenActivity.TRANSITIONING_OR_BELOW_TOP;
|
|
111
|
-
|
|
112
|
-
if (next !== screenActivity.get()) {
|
|
113
|
-
screenActivity.set(next);
|
|
114
|
-
}
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
const animatedProps = useAnimatedProps(() => {
|
|
118
|
-
const activity = screenActivity.get();
|
|
119
|
-
const isClosing = sceneClosing.get() > 0;
|
|
120
|
-
const activeIndex = optimisticFocusedIndex.get();
|
|
121
|
-
const isActive = index === activeIndex;
|
|
122
|
-
|
|
123
|
-
// Check if the active screen allows passthrough to the screen below
|
|
124
|
-
const activeBackdrop = backdropBehaviors[activeIndex] ?? "block";
|
|
125
|
-
const activeAllowsPassthrough = activeBackdrop === PASSTHROUGH;
|
|
126
|
-
const isAllowedPassthroughBelow =
|
|
127
|
-
activeAllowsPassthrough && index === activeIndex - 1;
|
|
128
|
-
|
|
129
|
-
// Determine pointer events:
|
|
130
|
-
// - "none" if closing (immediately disable touches)
|
|
131
|
-
// - "box-none" if this is the active screen
|
|
132
|
-
// - "box-none" if the active screen allows passthrough and we're immediately below
|
|
133
|
-
// - "none" otherwise (block touches to non-active screens)
|
|
134
|
-
const pointerEvents =
|
|
135
|
-
isClosing || (!isActive && !isAllowedPassthroughBelow)
|
|
136
|
-
? POINT_NONE
|
|
137
|
-
: POINT_BOX_NONE;
|
|
138
|
-
|
|
139
|
-
if (!DISABLE_NATIVE_SCREENS) {
|
|
140
|
-
return {
|
|
141
|
-
activityState: activity,
|
|
142
|
-
shouldFreeze: activity === ScreenActivity.INACTIVE && shouldFreeze,
|
|
143
|
-
pointerEvents,
|
|
144
|
-
};
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
return {
|
|
148
|
-
pointerEvents,
|
|
149
|
-
};
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
if (DISABLE_NATIVE_SCREENS) {
|
|
153
|
-
return (
|
|
154
|
-
<Animated.View
|
|
155
|
-
// Keep a native boundary per screen when falling back to plain views.
|
|
156
|
-
// Android release builds can otherwise flatten sibling screens together.
|
|
157
|
-
collapsable={false}
|
|
158
|
-
style={StyleSheet.absoluteFill}
|
|
159
|
-
animatedProps={animatedProps}
|
|
160
|
-
>
|
|
161
|
-
{children}
|
|
162
|
-
</Animated.View>
|
|
163
|
-
);
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
return (
|
|
167
|
-
<AnimatedNativeScreen
|
|
168
|
-
enabled
|
|
169
|
-
style={StyleSheet.absoluteFill}
|
|
170
|
-
freezeOnBlur={freezeOnBlur}
|
|
171
|
-
animatedProps={animatedProps}
|
|
172
|
-
>
|
|
173
|
-
{children}
|
|
174
|
-
</AnimatedNativeScreen>
|
|
175
|
-
);
|
|
176
|
-
};
|
package/src/shared/providers/stack/helpers/use-local-routes/helpers/align-routes-with-latest.ts
DELETED
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import type { RouteWithKey } from "../../../../../types/stack.types";
|
|
2
|
-
import { composeDescriptors } from "../../../../../utils/navigation/compose-descriptors";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Aligns current routes with the latest route data while preserving references
|
|
6
|
-
* when possible for performance optimization
|
|
7
|
-
*/
|
|
8
|
-
export const alignRoutesWithLatest = <
|
|
9
|
-
Route extends RouteWithKey,
|
|
10
|
-
DescriptorMap extends Record<string, unknown>,
|
|
11
|
-
>(
|
|
12
|
-
currentRoutes: Route[],
|
|
13
|
-
currentDescriptors: DescriptorMap,
|
|
14
|
-
nextRoutes: Route[],
|
|
15
|
-
nextDescriptors: DescriptorMap,
|
|
16
|
-
): { routes: Route[]; descriptors: DescriptorMap } => {
|
|
17
|
-
// Early return for empty current routes
|
|
18
|
-
if (currentRoutes.length === 0) {
|
|
19
|
-
return {
|
|
20
|
-
routes: nextRoutes,
|
|
21
|
-
descriptors: composeDescriptors(
|
|
22
|
-
nextRoutes,
|
|
23
|
-
nextDescriptors,
|
|
24
|
-
currentDescriptors,
|
|
25
|
-
),
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
// Create lookup map for efficient route finding
|
|
30
|
-
const nextRouteLookup = new Map<string, Route>();
|
|
31
|
-
for (const route of nextRoutes) {
|
|
32
|
-
nextRouteLookup.set(route.key, route);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
// Track if any changes occurred
|
|
36
|
-
let didChange = currentRoutes.length !== nextRoutes.length;
|
|
37
|
-
|
|
38
|
-
// Align routes, updating references where needed
|
|
39
|
-
const alignedRoutes = currentRoutes.map((route) => {
|
|
40
|
-
const nextRoute = nextRouteLookup.get(route.key);
|
|
41
|
-
|
|
42
|
-
if (!nextRoute) {
|
|
43
|
-
return route; // Keep current route if not in next
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
if (nextRoute !== route) {
|
|
47
|
-
didChange = true;
|
|
48
|
-
return nextRoute; // Update to new route reference
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
return route; // Keep current route reference
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
// Only create new array if changes occurred
|
|
55
|
-
const routesResult = didChange ? alignedRoutes : currentRoutes;
|
|
56
|
-
|
|
57
|
-
return {
|
|
58
|
-
routes: routesResult,
|
|
59
|
-
descriptors: composeDescriptors(
|
|
60
|
-
routesResult,
|
|
61
|
-
nextDescriptors,
|
|
62
|
-
currentDescriptors,
|
|
63
|
-
),
|
|
64
|
-
};
|
|
65
|
-
};
|
package/src/shared/providers/stack/helpers/use-local-routes/helpers/are-descriptors-equal.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
export const areDescriptorsEqual = <
|
|
2
|
-
DescriptorMap extends Record<string, unknown>,
|
|
3
|
-
>(
|
|
4
|
-
a: DescriptorMap,
|
|
5
|
-
b: DescriptorMap,
|
|
6
|
-
): boolean => {
|
|
7
|
-
if (a === b) return true;
|
|
8
|
-
|
|
9
|
-
const aKeys = Object.keys(a);
|
|
10
|
-
const bKeys = Object.keys(b);
|
|
11
|
-
|
|
12
|
-
if (aKeys.length !== bKeys.length) return false;
|
|
13
|
-
|
|
14
|
-
return aKeys.every((key) => a[key] === b[key]);
|
|
15
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { RouteWithKey } from "../../../../../types/stack.types";
|
|
2
|
-
|
|
3
|
-
export const haveSameRouteKeys = <Route extends RouteWithKey>(
|
|
4
|
-
previous: Route[],
|
|
5
|
-
next: Route[],
|
|
6
|
-
): boolean => {
|
|
7
|
-
if (previous.length !== next.length) {
|
|
8
|
-
return false;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
return previous.every((route, index) => route?.key === next[index]?.key);
|
|
12
|
-
};
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { RouteWithKey } from "../../../../../types/stack.types";
|
|
2
|
-
|
|
3
|
-
export const routesAreIdentical = <Route extends RouteWithKey>(
|
|
4
|
-
a: Route[],
|
|
5
|
-
b: Route[],
|
|
6
|
-
): boolean => {
|
|
7
|
-
if (a === b) return true;
|
|
8
|
-
if (a.length !== b.length) return false;
|
|
9
|
-
|
|
10
|
-
return a.every((route, index) => route === b[index]);
|
|
11
|
-
};
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import { StackActions } from "@react-navigation/native";
|
|
2
|
-
import { useLayoutEffect, useRef, useState } from "react";
|
|
3
|
-
import { useClosingRouteKeys } from "../../../../hooks/navigation/use-closing-route-keys";
|
|
4
|
-
import { usePrevious } from "../../../../hooks/navigation/use-previous";
|
|
5
|
-
import useStableCallback from "../../../../hooks/use-stable-callback";
|
|
6
|
-
import type {
|
|
7
|
-
BaseStackDescriptor,
|
|
8
|
-
BaseStackNavigation,
|
|
9
|
-
BaseStackRoute,
|
|
10
|
-
} from "../../../../types/stack.types";
|
|
11
|
-
import { syncRoutesWithRemoved } from "../../../../utils/navigation/sync-routes-with-removed";
|
|
12
|
-
import type { ManagedStackProps } from "../../managed.provider";
|
|
13
|
-
import { alignRoutesWithLatest } from "./helpers/align-routes-with-latest";
|
|
14
|
-
import { areDescriptorsEqual } from "./helpers/are-descriptors-equal";
|
|
15
|
-
import { haveSameRouteKeys } from "./helpers/have-same-route-keys";
|
|
16
|
-
import { routesAreIdentical } from "./helpers/routes-are-identical";
|
|
17
|
-
|
|
18
|
-
export const useLocalRoutes = <
|
|
19
|
-
TDescriptor extends BaseStackDescriptor,
|
|
20
|
-
TNavigation extends BaseStackNavigation,
|
|
21
|
-
>(
|
|
22
|
-
props: ManagedStackProps<TDescriptor, TNavigation>,
|
|
23
|
-
) => {
|
|
24
|
-
type TRoute = TDescriptor["route"];
|
|
25
|
-
type TDescriptorMap = Record<string, TDescriptor>;
|
|
26
|
-
|
|
27
|
-
const previousRoutes = usePrevious(props.state.routes) ?? [];
|
|
28
|
-
const closingRouteKeys = useClosingRouteKeys();
|
|
29
|
-
|
|
30
|
-
const [localState, setLocalState] = useState(() => ({
|
|
31
|
-
routes: props.state.routes as TRoute[],
|
|
32
|
-
descriptors: props.descriptors as TDescriptorMap,
|
|
33
|
-
}));
|
|
34
|
-
const localStateRef = useRef(localState);
|
|
35
|
-
|
|
36
|
-
useLayoutEffect(() => {
|
|
37
|
-
const nextRoutesSnapshot = props.state.routes;
|
|
38
|
-
const previousRoutesSnapshot = previousRoutes;
|
|
39
|
-
const current = localStateRef.current;
|
|
40
|
-
|
|
41
|
-
const alreadyAligned =
|
|
42
|
-
routesAreIdentical(current.routes, nextRoutesSnapshot as TRoute[]) &&
|
|
43
|
-
areDescriptorsEqual(
|
|
44
|
-
current.descriptors,
|
|
45
|
-
props.descriptors as TDescriptorMap,
|
|
46
|
-
);
|
|
47
|
-
if (alreadyAligned) {
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const routeKeysUnchanged = haveSameRouteKeys(
|
|
52
|
-
previousRoutesSnapshot,
|
|
53
|
-
nextRoutesSnapshot,
|
|
54
|
-
);
|
|
55
|
-
|
|
56
|
-
let derivedRoutes: TRoute[];
|
|
57
|
-
let derivedDescriptors: TDescriptorMap;
|
|
58
|
-
|
|
59
|
-
if (routeKeysUnchanged) {
|
|
60
|
-
const result = alignRoutesWithLatest(
|
|
61
|
-
current.routes,
|
|
62
|
-
current.descriptors,
|
|
63
|
-
nextRoutesSnapshot,
|
|
64
|
-
props.descriptors,
|
|
65
|
-
);
|
|
66
|
-
|
|
67
|
-
derivedRoutes = result.routes as TRoute[];
|
|
68
|
-
derivedDescriptors = result.descriptors as TDescriptorMap;
|
|
69
|
-
} else {
|
|
70
|
-
const fallbackRoutes =
|
|
71
|
-
previousRoutesSnapshot.length > 0
|
|
72
|
-
? previousRoutesSnapshot
|
|
73
|
-
: current.routes;
|
|
74
|
-
|
|
75
|
-
const result = syncRoutesWithRemoved({
|
|
76
|
-
prevRoutes: fallbackRoutes,
|
|
77
|
-
prevDescriptors: current.descriptors,
|
|
78
|
-
nextRoutes: nextRoutesSnapshot,
|
|
79
|
-
nextDescriptors: props.descriptors,
|
|
80
|
-
closingRouteKeys,
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
derivedRoutes = result.routes as TRoute[];
|
|
84
|
-
derivedDescriptors = result.descriptors as TDescriptorMap;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
const routesChanged = !routesAreIdentical(current.routes, derivedRoutes);
|
|
88
|
-
const descriptorsChanged = !areDescriptorsEqual(
|
|
89
|
-
current.descriptors,
|
|
90
|
-
derivedDescriptors,
|
|
91
|
-
);
|
|
92
|
-
|
|
93
|
-
if (!routesChanged && !descriptorsChanged) {
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const nextLocalState = {
|
|
98
|
-
routes: routesChanged ? derivedRoutes : current.routes,
|
|
99
|
-
descriptors: descriptorsChanged
|
|
100
|
-
? derivedDescriptors
|
|
101
|
-
: current.descriptors,
|
|
102
|
-
};
|
|
103
|
-
localStateRef.current = nextLocalState;
|
|
104
|
-
setLocalState(nextLocalState);
|
|
105
|
-
}, [props.state.routes, props.descriptors, previousRoutes, closingRouteKeys]);
|
|
106
|
-
|
|
107
|
-
const handleCloseRoute = useStableCallback(
|
|
108
|
-
({ route }: { route: BaseStackRoute }) => {
|
|
109
|
-
if (props.state.routes.some((r) => r.key === route.key)) {
|
|
110
|
-
props.navigation.dispatch({
|
|
111
|
-
...StackActions.pop(),
|
|
112
|
-
source: route.key,
|
|
113
|
-
target: props.state.key,
|
|
114
|
-
});
|
|
115
|
-
return;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
closingRouteKeys.remove(route.key);
|
|
119
|
-
|
|
120
|
-
setLocalState((current) => {
|
|
121
|
-
if (!current.routes.some((candidate) => candidate.key === route.key)) {
|
|
122
|
-
return current;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
const nextRoutes = current.routes.filter(
|
|
126
|
-
(candidate) => candidate.key !== route.key,
|
|
127
|
-
);
|
|
128
|
-
|
|
129
|
-
const nextDescriptors = { ...current.descriptors };
|
|
130
|
-
delete nextDescriptors[route.key];
|
|
131
|
-
|
|
132
|
-
const nextState = {
|
|
133
|
-
routes: nextRoutes,
|
|
134
|
-
descriptors: nextDescriptors,
|
|
135
|
-
};
|
|
136
|
-
localStateRef.current = nextState;
|
|
137
|
-
return nextState;
|
|
138
|
-
});
|
|
139
|
-
},
|
|
140
|
-
);
|
|
141
|
-
|
|
142
|
-
return {
|
|
143
|
-
state: localState,
|
|
144
|
-
handleCloseRoute,
|
|
145
|
-
closingRouteKeys,
|
|
146
|
-
};
|
|
147
|
-
};
|