react-native-screen-transitions 3.4.0-alpha.5 → 3.4.0-alpha.7
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 +1058 -11
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js +27 -45
- package/lib/commonjs/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/commonjs/component-stack/navigators/create-component-stack-navigator.js +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/components/boundary-target.js +39 -0
- package/lib/commonjs/shared/components/create-boundary-component/components/boundary-target.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/create-boundary-component.js +232 -0
- package/lib/commonjs/shared/components/create-boundary-component/create-boundary-component.js.map +1 -0
- package/lib/commonjs/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js +2 -4
- package/lib/commonjs/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js +4 -3
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js +2 -1
- package/lib/commonjs/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/index.js +20 -214
- package/lib/commonjs/shared/components/create-boundary-component/index.js.map +1 -1
- package/lib/commonjs/shared/components/create-boundary-component/providers/boundary-owner.provider.js +63 -0
- package/lib/commonjs/shared/components/create-boundary-component/providers/boundary-owner.provider.js.map +1 -0
- package/lib/commonjs/shared/components/create-transition-aware-component.js +29 -7
- package/lib/commonjs/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/commonjs/shared/components/overlay/variations/float-overlay.js +1 -1
- package/lib/commonjs/shared/components/screen-container/hooks/use-backdrop-pointer-events.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/index.js +12 -8
- package/lib/commonjs/shared/components/screen-container/index.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/backdrop.js +8 -10
- package/lib/commonjs/shared/components/screen-container/layers/backdrop.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/content.js +7 -10
- package/lib/commonjs/shared/components/screen-container/layers/content.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/maybe-masked-navigation-container.js +4 -4
- package/lib/commonjs/shared/components/screen-container/layers/maybe-masked-navigation-container.js.map +1 -1
- package/lib/commonjs/shared/components/screen-container/layers/surface-container.js +4 -4
- package/lib/commonjs/shared/components/screen-container/layers/surface-container.js.map +1 -1
- package/lib/commonjs/shared/constants.js +4 -1
- package/lib/commonjs/shared/constants.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state.js +33 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/hydrate-transition-state.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js +2 -0
- package/lib/commonjs/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/animation/helpers/use-build-transition-state.js +1 -0
- package/lib/commonjs/shared/providers/screen/animation/helpers/use-build-transition-state.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/screen-composer.js +1 -1
- package/lib/commonjs/shared/providers/screen/screen-composer.js.map +1 -1
- package/lib/commonjs/shared/providers/screen/styles/helpers/build-resolved-style-map.js +144 -0
- package/lib/commonjs/shared/providers/screen/styles/helpers/build-resolved-style-map.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.js +28 -0
- package/lib/commonjs/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/styles/helpers/split-normalized-style-maps.js +39 -0
- package/lib/commonjs/shared/providers/screen/styles/helpers/split-normalized-style-maps.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/styles/index.js +25 -0
- package/lib/commonjs/shared/providers/screen/styles/index.js.map +1 -0
- package/lib/commonjs/shared/providers/screen/{styles.provider.js → styles/styles.provider.js} +47 -39
- package/lib/commonjs/shared/providers/screen/styles/styles.provider.js.map +1 -0
- package/lib/commonjs/shared/utils/bounds/helpers/compute-bounds-styles.js +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/compute-bounds-styles.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/helpers/style-composers.js +21 -10
- package/lib/commonjs/shared/utils/bounds/helpers/style-composers.js.map +1 -1
- package/lib/commonjs/shared/utils/bounds/zoom/build.js +57 -31
- package/lib/commonjs/shared/utils/bounds/zoom/build.js.map +1 -1
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js +27 -45
- package/lib/module/blank-stack/navigators/create-blank-stack-navigator.js.map +1 -1
- package/lib/module/component-stack/navigators/create-component-stack-navigator.js +1 -1
- package/lib/module/shared/components/create-boundary-component/components/boundary-target.js +34 -0
- package/lib/module/shared/components/create-boundary-component/components/boundary-target.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/create-boundary-component.js +227 -0
- package/lib/module/shared/components/create-boundary-component/create-boundary-component.js.map +1 -0
- package/lib/module/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js +2 -4
- package/lib/module/shared/components/create-boundary-component/hooks/helpers/measurement-rules.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js +4 -3
- package/lib/module/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js +2 -1
- package/lib/module/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/index.js +16 -213
- package/lib/module/shared/components/create-boundary-component/index.js.map +1 -1
- package/lib/module/shared/components/create-boundary-component/providers/boundary-owner.provider.js +56 -0
- package/lib/module/shared/components/create-boundary-component/providers/boundary-owner.provider.js.map +1 -0
- package/lib/module/shared/components/create-transition-aware-component.js +30 -8
- package/lib/module/shared/components/create-transition-aware-component.js.map +1 -1
- package/lib/module/shared/components/overlay/variations/float-overlay.js +1 -1
- package/lib/module/shared/components/overlay/variations/float-overlay.js.map +1 -1
- package/lib/module/shared/components/screen-container/hooks/use-backdrop-pointer-events.js.map +1 -1
- package/lib/module/shared/components/screen-container/index.js +12 -8
- package/lib/module/shared/components/screen-container/index.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/backdrop.js +8 -10
- package/lib/module/shared/components/screen-container/layers/backdrop.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/content.js +7 -10
- package/lib/module/shared/components/screen-container/layers/content.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/maybe-masked-navigation-container.js +4 -4
- package/lib/module/shared/components/screen-container/layers/maybe-masked-navigation-container.js.map +1 -1
- package/lib/module/shared/components/screen-container/layers/surface-container.js +4 -4
- package/lib/module/shared/components/screen-container/layers/surface-container.js.map +1 -1
- package/lib/module/shared/constants.js +4 -1
- package/lib/module/shared/constants.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state.js +32 -1
- package/lib/module/shared/providers/screen/animation/helpers/hydrate-transition-state.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js +2 -0
- package/lib/module/shared/providers/screen/animation/helpers/pipeline.js.map +1 -1
- package/lib/module/shared/providers/screen/animation/helpers/use-build-transition-state.js +1 -0
- package/lib/module/shared/providers/screen/animation/helpers/use-build-transition-state.js.map +1 -1
- package/lib/module/shared/providers/screen/screen-composer.js +1 -1
- package/lib/module/shared/providers/screen/screen-composer.js.map +1 -1
- package/lib/module/shared/providers/screen/styles/helpers/build-resolved-style-map.js +139 -0
- package/lib/module/shared/providers/screen/styles/helpers/build-resolved-style-map.js.map +1 -0
- package/lib/module/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.js +23 -0
- package/lib/module/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.js.map +1 -0
- package/lib/module/shared/providers/screen/styles/helpers/split-normalized-style-maps.js +34 -0
- package/lib/module/shared/providers/screen/styles/helpers/split-normalized-style-maps.js.map +1 -0
- package/lib/module/shared/providers/screen/styles/index.js +4 -0
- package/lib/module/shared/providers/screen/styles/index.js.map +1 -0
- package/lib/module/shared/providers/screen/{styles.provider.js → styles/styles.provider.js} +48 -40
- package/lib/module/shared/providers/screen/styles/styles.provider.js.map +1 -0
- package/lib/module/shared/utils/bounds/helpers/compute-bounds-styles.js +2 -2
- package/lib/module/shared/utils/bounds/helpers/compute-bounds-styles.js.map +1 -1
- package/lib/module/shared/utils/bounds/helpers/style-composers.js +21 -10
- package/lib/module/shared/utils/bounds/helpers/style-composers.js.map +1 -1
- package/lib/module/shared/utils/bounds/zoom/build.js +56 -29
- package/lib/module/shared/utils/bounds/zoom/build.js.map +1 -1
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts +9 -15
- package/lib/typescript/blank-stack/navigators/create-blank-stack-navigator.d.ts.map +1 -1
- package/lib/typescript/blank-stack/types.d.ts +6 -4
- package/lib/typescript/blank-stack/types.d.ts.map +1 -1
- package/lib/typescript/component-stack/navigators/create-component-stack-navigator.d.ts +1 -1
- package/lib/typescript/shared/components/create-boundary-component/components/boundary-target.d.ts +209 -0
- package/lib/typescript/shared/components/create-boundary-component/components/boundary-target.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/create-boundary-component.d.ts +8 -0
- package/lib/typescript/shared/components/create-boundary-component/create-boundary-component.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-boundary-component/hooks/helpers/measurement-rules.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.d.ts +2 -8
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.d.ts +0 -1
- package/lib/typescript/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/index.d.ts +216 -12
- package/lib/typescript/shared/components/create-boundary-component/index.d.ts.map +1 -1
- package/lib/typescript/shared/components/create-boundary-component/providers/boundary-owner.provider.d.ts +35 -0
- package/lib/typescript/shared/components/create-boundary-component/providers/boundary-owner.provider.d.ts.map +1 -0
- package/lib/typescript/shared/components/create-transition-aware-component.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/hooks/use-backdrop-pointer-events.d.ts +1 -1
- package/lib/typescript/shared/components/screen-container/hooks/use-backdrop-pointer-events.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/index.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/layers/backdrop.d.ts +5 -1
- package/lib/typescript/shared/components/screen-container/layers/backdrop.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/layers/content.d.ts +3 -1
- package/lib/typescript/shared/components/screen-container/layers/content.d.ts.map +1 -1
- package/lib/typescript/shared/components/screen-container/layers/maybe-masked-navigation-container.d.ts.map +1 -1
- package/lib/typescript/shared/constants.d.ts +1 -0
- package/lib/typescript/shared/constants.d.ts.map +1 -1
- package/lib/typescript/shared/index.d.ts +209 -2
- package/lib/typescript/shared/index.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state.d.ts +16 -0
- package/lib/typescript/shared/providers/screen/animation/helpers/hydrate-transition-state.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/pipeline.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/animation/helpers/use-build-transition-state.d.ts +1 -0
- package/lib/typescript/shared/providers/screen/animation/helpers/use-build-transition-state.d.ts.map +1 -1
- package/lib/typescript/shared/providers/screen/styles/helpers/build-resolved-style-map.d.ts +11 -0
- package/lib/typescript/shared/providers/screen/styles/helpers/build-resolved-style-map.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.d.ts +7 -0
- package/lib/typescript/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/styles/helpers/split-normalized-style-maps.d.ts +6 -0
- package/lib/typescript/shared/providers/screen/styles/helpers/split-normalized-style-maps.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/styles/index.d.ts +2 -0
- package/lib/typescript/shared/providers/screen/styles/index.d.ts.map +1 -0
- package/lib/typescript/shared/providers/screen/{styles.provider.d.ts → styles/styles.provider.d.ts} +3 -5
- package/lib/typescript/shared/providers/screen/styles/styles.provider.d.ts.map +1 -0
- package/lib/typescript/shared/types/animation.types.d.ts +16 -9
- package/lib/typescript/shared/types/animation.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/screen.types.d.ts +4 -5
- package/lib/typescript/shared/types/screen.types.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/compute-bounds-styles.d.ts +1 -11
- package/lib/typescript/shared/utils/bounds/helpers/compute-bounds-styles.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/helpers/style-composers.d.ts.map +1 -1
- package/lib/typescript/shared/utils/bounds/zoom/build.d.ts +1 -1
- package/lib/typescript/shared/utils/bounds/zoom/build.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/blank-stack/navigators/create-blank-stack-navigator.tsx +37 -80
- package/src/blank-stack/types.ts +7 -4
- package/src/component-stack/navigators/create-component-stack-navigator.tsx +1 -1
- package/src/shared/components/create-boundary-component/components/boundary-target.tsx +45 -0
- package/src/shared/components/create-boundary-component/create-boundary-component.tsx +282 -0
- package/src/shared/components/create-boundary-component/hooks/helpers/measurement-rules.ts +2 -7
- package/src/shared/components/create-boundary-component/hooks/use-boundary-measure-and-store.ts +6 -10
- package/src/shared/components/create-boundary-component/hooks/use-pending-destination-retry-measurement.ts +3 -2
- package/src/shared/components/create-boundary-component/index.tsx +16 -252
- package/src/shared/components/create-boundary-component/providers/boundary-owner.provider.tsx +109 -0
- package/src/shared/components/create-transition-aware-component.tsx +33 -5
- package/src/shared/components/overlay/variations/float-overlay.tsx +1 -1
- package/src/shared/components/screen-container/hooks/use-backdrop-pointer-events.ts +1 -2
- package/src/shared/components/screen-container/index.tsx +12 -6
- package/src/shared/components/screen-container/layers/backdrop.tsx +13 -7
- package/src/shared/components/screen-container/layers/content.tsx +47 -43
- package/src/shared/components/screen-container/layers/maybe-masked-navigation-container.tsx +6 -4
- package/src/shared/components/screen-container/layers/surface-container.tsx +4 -4
- package/src/shared/constants.ts +3 -0
- package/src/shared/index.ts +0 -1
- package/src/shared/providers/screen/animation/helpers/hydrate-transition-state.ts +49 -1
- package/src/shared/providers/screen/animation/helpers/pipeline.ts +2 -0
- package/src/shared/providers/screen/animation/helpers/use-build-transition-state.ts +2 -0
- package/src/shared/providers/screen/screen-composer.tsx +1 -1
- package/src/shared/providers/screen/styles/helpers/build-resolved-style-map.ts +185 -0
- package/src/shared/providers/screen/styles/helpers/resolve-interpolated-style-output.ts +31 -0
- package/src/shared/providers/screen/styles/helpers/split-normalized-style-maps.ts +44 -0
- package/src/shared/providers/screen/styles/index.tsx +5 -0
- package/src/shared/providers/screen/styles/styles.provider.tsx +173 -0
- package/src/shared/types/animation.types.ts +18 -10
- package/src/shared/types/index.ts +0 -1
- package/src/shared/types/screen.types.ts +5 -5
- package/src/shared/utils/bounds/helpers/compute-bounds-styles.ts +2 -1
- package/src/shared/utils/bounds/helpers/style-composers.ts +11 -0
- package/src/shared/utils/bounds/zoom/build.ts +94 -59
- package/lib/commonjs/shared/components/screen-container/deferred-visibility-host.js +0 -43
- package/lib/commonjs/shared/components/screen-container/deferred-visibility-host.js.map +0 -1
- package/lib/commonjs/shared/hooks/animation/use-associated-style.js +0 -234
- package/lib/commonjs/shared/hooks/animation/use-associated-style.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/helpers/resolve-interpolated-style-output.js +0 -50
- package/lib/commonjs/shared/providers/screen/helpers/resolve-interpolated-style-output.js.map +0 -1
- package/lib/commonjs/shared/providers/screen/styles.provider.js.map +0 -1
- package/lib/module/shared/components/screen-container/deferred-visibility-host.js +0 -38
- package/lib/module/shared/components/screen-container/deferred-visibility-host.js.map +0 -1
- package/lib/module/shared/hooks/animation/use-associated-style.js +0 -229
- package/lib/module/shared/hooks/animation/use-associated-style.js.map +0 -1
- package/lib/module/shared/providers/screen/helpers/resolve-interpolated-style-output.js +0 -44
- package/lib/module/shared/providers/screen/helpers/resolve-interpolated-style-output.js.map +0 -1
- package/lib/module/shared/providers/screen/styles.provider.js.map +0 -1
- package/lib/typescript/shared/components/screen-container/deferred-visibility-host.d.ts +0 -13
- package/lib/typescript/shared/components/screen-container/deferred-visibility-host.d.ts.map +0 -1
- package/lib/typescript/shared/hooks/animation/use-associated-style.d.ts +0 -32
- package/lib/typescript/shared/hooks/animation/use-associated-style.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/helpers/resolve-interpolated-style-output.d.ts +0 -14
- package/lib/typescript/shared/providers/screen/helpers/resolve-interpolated-style-output.d.ts.map +0 -1
- package/lib/typescript/shared/providers/screen/styles.provider.d.ts.map +0 -1
- package/src/shared/components/screen-container/deferred-visibility-host.tsx +0 -37
- package/src/shared/hooks/animation/use-associated-style.ts +0 -297
- package/src/shared/providers/screen/helpers/resolve-interpolated-style-output.ts +0 -61
- package/src/shared/providers/screen/styles.provider.tsx +0 -164
|
@@ -1,215 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import {
|
|
4
|
-
import { Pressable
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
import { BoundStore } from "../../stores/bounds";
|
|
11
|
-
import { prepareStyleForBounds } from "../../utils/bounds/helpers/styles";
|
|
12
|
-
import { useAutoSourceMeasurement } from "./hooks/use-auto-source-measurement";
|
|
13
|
-
import { useBoundaryMeasureAndStore } from "./hooks/use-boundary-measure-and-store";
|
|
14
|
-
import { useBoundaryPresence } from "./hooks/use-boundary-presence";
|
|
15
|
-
import { useGroupActiveMeasurement } from "./hooks/use-group-active-measurement";
|
|
16
|
-
import { useGroupActiveSourceMeasurement } from "./hooks/use-group-active-source-measurement";
|
|
17
|
-
import { useInitialLayoutHandler } from "./hooks/use-initial-layout-handler";
|
|
18
|
-
import { usePendingDestinationMeasurement } from "./hooks/use-pending-destination-measurement";
|
|
19
|
-
import { usePendingDestinationRetryMeasurement } from "./hooks/use-pending-destination-retry-measurement";
|
|
20
|
-
import { useScrollSettledMeasurement } from "./hooks/use-scroll-settled-measurement";
|
|
21
|
-
import { buildBoundaryMatchKey } from "./utils/build-boundary-match-key";
|
|
22
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
23
|
-
const setGroupSelectionOnUI = (group, id) => {
|
|
24
|
-
"worklet";
|
|
25
|
-
|
|
26
|
-
BoundStore.setGroupActiveId(group, id);
|
|
27
|
-
};
|
|
28
|
-
export function createBoundaryComponent(Wrapped, options = {}) {
|
|
29
|
-
const {
|
|
30
|
-
alreadyAnimated = false
|
|
31
|
-
} = options;
|
|
32
|
-
const AnimatedComponent = alreadyAnimated ? Wrapped : Animated.createAnimatedComponent(Wrapped);
|
|
33
|
-
const Inner = /*#__PURE__*/forwardRef((props, _ref) => {
|
|
34
|
-
const {
|
|
35
|
-
enabled = true,
|
|
36
|
-
group,
|
|
37
|
-
id,
|
|
38
|
-
anchor,
|
|
39
|
-
scaleMode,
|
|
40
|
-
target,
|
|
41
|
-
method,
|
|
42
|
-
style,
|
|
43
|
-
onPress,
|
|
44
|
-
...rest
|
|
45
|
-
} = props;
|
|
46
|
-
const sharedBoundTag = buildBoundaryMatchKey({
|
|
47
|
-
group,
|
|
48
|
-
id
|
|
49
|
-
});
|
|
50
|
-
const animatedRef = useAnimatedRef();
|
|
51
|
-
const {
|
|
52
|
-
previousScreenKey: preferredSourceScreenKey,
|
|
53
|
-
currentScreenKey,
|
|
54
|
-
nextScreenKey,
|
|
55
|
-
ancestorKeys,
|
|
56
|
-
navigatorKey,
|
|
57
|
-
ancestorNavigatorKeys,
|
|
58
|
-
hasConfiguredInterpolator
|
|
59
|
-
} = useDescriptorDerivations();
|
|
60
|
-
const runtimeEnabled = enabled && hasConfiguredInterpolator;
|
|
61
|
-
const hasNextScreen = !!nextScreenKey;
|
|
62
|
-
const shouldUpdateDestination = !hasNextScreen;
|
|
63
|
-
const layoutAnchor = useLayoutAnchorContext();
|
|
64
|
-
const boundaryConfig = useMemo(() => {
|
|
65
|
-
if (anchor === undefined && scaleMode === undefined && target === undefined && method === undefined) {
|
|
66
|
-
return undefined;
|
|
67
|
-
}
|
|
68
|
-
return {
|
|
69
|
-
anchor,
|
|
70
|
-
scaleMode,
|
|
71
|
-
target,
|
|
72
|
-
method
|
|
73
|
-
};
|
|
74
|
-
}, [anchor, scaleMode, target, method]);
|
|
75
|
-
const isAnimating = AnimationStore.getValue(currentScreenKey, "animating");
|
|
76
|
-
const progress = AnimationStore.getValue(currentScreenKey, "progress");
|
|
77
|
-
const preparedStyles = useMemo(() => prepareStyleForBounds(style), [style]);
|
|
78
|
-
const {
|
|
79
|
-
associatedStyles
|
|
80
|
-
} = useAssociatedStyles({
|
|
81
|
-
id: sharedBoundTag,
|
|
82
|
-
resetTransformOnUnset: true
|
|
83
|
-
});
|
|
84
|
-
const maybeMeasureAndStore = useBoundaryMeasureAndStore({
|
|
85
|
-
enabled,
|
|
86
|
-
sharedBoundTag,
|
|
87
|
-
preferredSourceScreenKey,
|
|
88
|
-
currentScreenKey,
|
|
89
|
-
ancestorKeys,
|
|
90
|
-
navigatorKey,
|
|
91
|
-
ancestorNavigatorKeys,
|
|
92
|
-
isAnimating,
|
|
93
|
-
preparedStyles,
|
|
94
|
-
animatedRef,
|
|
95
|
-
layoutAnchor
|
|
96
|
-
});
|
|
97
|
-
const shouldRunDestinationEffects = runtimeEnabled && !hasNextScreen;
|
|
98
|
-
|
|
99
|
-
// Register/unregister this boundary in the presence map so source/destination
|
|
100
|
-
// matching can resolve across screens (including ancestor relationships).
|
|
101
|
-
useBoundaryPresence({
|
|
102
|
-
enabled: runtimeEnabled,
|
|
103
|
-
sharedBoundTag,
|
|
104
|
-
currentScreenKey,
|
|
105
|
-
ancestorKeys,
|
|
106
|
-
navigatorKey,
|
|
107
|
-
ancestorNavigatorKeys,
|
|
108
|
-
boundaryConfig
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
// On the source screen, capture source bounds when a matching destination
|
|
112
|
-
// appears on the next screen.
|
|
113
|
-
useAutoSourceMeasurement({
|
|
114
|
-
enabled: runtimeEnabled,
|
|
115
|
-
sharedBoundTag,
|
|
116
|
-
nextScreenKey,
|
|
117
|
-
maybeMeasureAndStore
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
// Primary destination capture: once a pending source link exists for this tag,
|
|
121
|
-
// measure destination bounds and complete the pair.
|
|
122
|
-
usePendingDestinationMeasurement({
|
|
123
|
-
sharedBoundTag,
|
|
124
|
-
enabled: shouldRunDestinationEffects,
|
|
125
|
-
expectedSourceScreenKey: preferredSourceScreenKey,
|
|
126
|
-
maybeMeasureAndStore
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
// Reliability fallback: retry destination capture during transition progress
|
|
130
|
-
// when the initial pending-destination attempt happens before layout is ready.
|
|
131
|
-
usePendingDestinationRetryMeasurement({
|
|
132
|
-
sharedBoundTag,
|
|
133
|
-
enabled: shouldRunDestinationEffects,
|
|
134
|
-
currentScreenKey,
|
|
135
|
-
expectedSourceScreenKey: preferredSourceScreenKey,
|
|
136
|
-
progress,
|
|
137
|
-
animating: isAnimating,
|
|
138
|
-
maybeMeasureAndStore
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
// Grouped boundaries (e.g. paged/detail UIs): re-measure when this boundary
|
|
142
|
-
// becomes the active member so destination bounds stay accurate.
|
|
143
|
-
useGroupActiveMeasurement({
|
|
144
|
-
enabled: runtimeEnabled,
|
|
145
|
-
group,
|
|
146
|
-
id,
|
|
147
|
-
currentScreenKey,
|
|
148
|
-
shouldUpdateDestination,
|
|
149
|
-
maybeMeasureAndStore
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
// Source-side grouped retargeting: when an unfocused/source boundary
|
|
153
|
-
// becomes the active member, refresh its snapshot and source link so
|
|
154
|
-
// close transitions do not use stale pre-scroll geometry.
|
|
155
|
-
useGroupActiveSourceMeasurement({
|
|
156
|
-
enabled: runtimeEnabled,
|
|
157
|
-
group,
|
|
158
|
-
id,
|
|
159
|
-
hasNextScreen,
|
|
160
|
-
isAnimating,
|
|
161
|
-
maybeMeasureAndStore
|
|
162
|
-
});
|
|
163
|
-
|
|
164
|
-
// While idle on source screens, re-measure after scroll settles so a later
|
|
165
|
-
// close transition starts from up-to-date source geometry.
|
|
166
|
-
useScrollSettledMeasurement({
|
|
167
|
-
enabled: runtimeEnabled,
|
|
168
|
-
group,
|
|
169
|
-
hasNextScreen,
|
|
170
|
-
isAnimating,
|
|
171
|
-
maybeMeasureAndStore
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
// Destination mount-time capture path: onLayout schedules a one-time UI-thread
|
|
175
|
-
// initial measurement when transitions are active.
|
|
176
|
-
useInitialLayoutHandler({
|
|
177
|
-
enabled: runtimeEnabled,
|
|
178
|
-
sharedBoundTag,
|
|
179
|
-
currentScreenKey,
|
|
180
|
-
ancestorKeys,
|
|
181
|
-
expectedSourceScreenKey: preferredSourceScreenKey,
|
|
182
|
-
maybeMeasureAndStore
|
|
183
|
-
});
|
|
184
|
-
const handlePress = useCallback((...args) => {
|
|
185
|
-
// Press path has priority: capture source before user onPress/navigation.
|
|
186
|
-
if (group) {
|
|
187
|
-
runOnUI(setGroupSelectionOnUI)(group, String(id));
|
|
188
|
-
}
|
|
189
|
-
runOnUI(maybeMeasureAndStore)({
|
|
190
|
-
intent: "capture-source"
|
|
191
|
-
});
|
|
192
|
-
if (typeof onPress === "function") {
|
|
193
|
-
onPress(...args);
|
|
194
|
-
}
|
|
195
|
-
}, [group, id, maybeMeasureAndStore, onPress]);
|
|
196
|
-
const resolvedOnPress = typeof onPress === "function" ? handlePress : undefined;
|
|
197
|
-
return /*#__PURE__*/_jsx(AnimatedComponent, {
|
|
198
|
-
...rest,
|
|
199
|
-
ref: animatedRef,
|
|
200
|
-
style: [style, enabled ? associatedStyles : undefined],
|
|
201
|
-
onPress: resolvedOnPress,
|
|
202
|
-
collapsable: false
|
|
203
|
-
});
|
|
204
|
-
});
|
|
205
|
-
return /*#__PURE__*/memo(Inner);
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
// Pre-built boundary component variants
|
|
209
|
-
const BoundaryView = createBoundaryComponent(RNView);
|
|
3
|
+
import { View } from "react-native";
|
|
4
|
+
import { Pressable } from "react-native-gesture-handler";
|
|
5
|
+
import { BoundaryTarget } from "./components/boundary-target";
|
|
6
|
+
import { createBoundaryComponent } from "./create-boundary-component";
|
|
7
|
+
export { createBoundaryComponent };
|
|
8
|
+
const BoundaryView = createBoundaryComponent(View);
|
|
9
|
+
const BoundaryTrigger = createBoundaryComponent(Pressable);
|
|
210
10
|
BoundaryView.displayName = "Transition.Boundary.View";
|
|
211
|
-
|
|
212
|
-
|
|
11
|
+
BoundaryTrigger.displayName = "Transition.Boundary.Trigger";
|
|
12
|
+
BoundaryTarget.displayName = "Transition.Boundary.Target";
|
|
213
13
|
|
|
214
14
|
/**
|
|
215
15
|
* Shared-boundary components.
|
|
@@ -219,19 +19,22 @@ BoundaryPressable.displayName = "Transition.Boundary.Pressable";
|
|
|
219
19
|
* 2. Destination screen captures bounds for the same tag.
|
|
220
20
|
* 3. The link is updated as layout changes (group-active + scroll-settled paths).
|
|
221
21
|
*
|
|
222
|
-
*
|
|
223
|
-
* - When a boundary has `onPress` (typically `Boundary.
|
|
22
|
+
* Trigger behavior:
|
|
23
|
+
* - When a boundary has `onPress` (typically `Boundary.Trigger`), source
|
|
224
24
|
* measurement runs before the user callback. This gives navigation transitions
|
|
225
25
|
* fresh source geometry on the first frame.
|
|
226
26
|
*
|
|
227
27
|
* Use:
|
|
228
28
|
* - `Boundary.View` for passive/shared elements.
|
|
229
|
-
* - `Boundary.
|
|
29
|
+
* - `Boundary.Trigger` for tappable elements that start navigation.
|
|
30
|
+
* - `Boundary.Target` to measure a nested descendant instead of the owner.
|
|
230
31
|
*/
|
|
231
32
|
export const Boundary = {
|
|
232
33
|
/** Passive boundary wrapper (no built-in press semantics). */
|
|
233
34
|
View: BoundaryView,
|
|
234
35
|
/** Pressable boundary wrapper with press-priority source capture. */
|
|
235
|
-
|
|
36
|
+
Trigger: BoundaryTrigger,
|
|
37
|
+
/** Optional nested measurement override inside a boundary owner. */
|
|
38
|
+
Target: BoundaryTarget
|
|
236
39
|
};
|
|
237
40
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["View","Pressable","BoundaryTarget","createBoundaryComponent","BoundaryView","BoundaryTrigger","displayName","Boundary","Trigger","Target"],"sourceRoot":"../../../../../src","sources":["shared/components/create-boundary-component/index.tsx"],"mappings":";;AAAA,SAASA,IAAI,QAAQ,cAAc;AACnC,SAASC,SAAS,QAAQ,8BAA8B;AACxD,SAASC,cAAc,QAAQ,8BAA8B;AAC7D,SAASC,uBAAuB,QAAQ,6BAA6B;AAErE,SAASA,uBAAuB;AAEhC,MAAMC,YAAY,GAAGD,uBAAuB,CAACH,IAAI,CAAC;AAClD,MAAMK,eAAe,GAAGF,uBAAuB,CAACF,SAAS,CAAC;AAC1DG,YAAY,CAACE,WAAW,GAAG,0BAA0B;AACrDD,eAAe,CAACC,WAAW,GAAG,6BAA6B;AAC3DJ,cAAc,CAACI,WAAW,GAAG,4BAA4B;;AAEzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,QAAQ,GAAG;EACvB;EACAP,IAAI,EAAEI,YAAY;EAClB;EACAI,OAAO,EAAEH,eAAe;EACxB;EACAI,MAAM,EAAEP;AACT,CAAC","ignoreList":[]}
|
package/lib/module/shared/components/create-boundary-component/providers/boundary-owner.provider.js
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { createContext, useCallback, useContext, useMemo, useRef, useState } from "react";
|
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
|
+
const BoundaryOwnerContext = /*#__PURE__*/createContext(null);
|
|
6
|
+
const MULTIPLE_TARGETS_WARNING = "[react-native-screen-transitions] Multiple Boundary.Target elements were rendered under the same boundary owner. The first registered target will be measured.";
|
|
7
|
+
export const TARGET_OUTSIDE_OWNER_WARNING = "[react-native-screen-transitions] Boundary.Target must be rendered inside a Boundary owner (Boundary.View, Boundary.Trigger, or a component created by createBoundaryComponent).";
|
|
8
|
+
export const BoundaryOwnerProvider = props => {
|
|
9
|
+
const {
|
|
10
|
+
value,
|
|
11
|
+
children
|
|
12
|
+
} = props;
|
|
13
|
+
return /*#__PURE__*/_jsx(BoundaryOwnerContext.Provider, {
|
|
14
|
+
value: value,
|
|
15
|
+
children: children
|
|
16
|
+
});
|
|
17
|
+
};
|
|
18
|
+
export const useBoundaryOwnerContext = () => {
|
|
19
|
+
return useContext(BoundaryOwnerContext);
|
|
20
|
+
};
|
|
21
|
+
export const useBoundaryOwner = params => {
|
|
22
|
+
const {
|
|
23
|
+
ownerRef,
|
|
24
|
+
associatedTargetStyles
|
|
25
|
+
} = params;
|
|
26
|
+
const warnedAboutMultipleTargetsRef = useRef(false);
|
|
27
|
+
const [targetRefs, setTargetRefs] = useState([]);
|
|
28
|
+
const registerTargetRef = useCallback(targetRef => {
|
|
29
|
+
setTargetRefs(prev => {
|
|
30
|
+
if (prev.includes(targetRef)) {
|
|
31
|
+
return prev;
|
|
32
|
+
}
|
|
33
|
+
if (__DEV__ && prev.length > 0 && !warnedAboutMultipleTargetsRef.current) {
|
|
34
|
+
warnedAboutMultipleTargetsRef.current = true;
|
|
35
|
+
console.warn(MULTIPLE_TARGETS_WARNING);
|
|
36
|
+
}
|
|
37
|
+
return [...prev, targetRef];
|
|
38
|
+
});
|
|
39
|
+
}, []);
|
|
40
|
+
const unregisterTargetRef = useCallback(targetRef => {
|
|
41
|
+
setTargetRefs(prev => prev.filter(existingRef => existingRef !== targetRef));
|
|
42
|
+
}, []);
|
|
43
|
+
const contextValue = useMemo(() => ({
|
|
44
|
+
ownerRef,
|
|
45
|
+
registerTargetRef,
|
|
46
|
+
unregisterTargetRef,
|
|
47
|
+
activeTargetRef: targetRefs[0] ?? null,
|
|
48
|
+
associatedTargetStyles
|
|
49
|
+
}), [ownerRef, registerTargetRef, unregisterTargetRef, targetRefs, associatedTargetStyles]);
|
|
50
|
+
return {
|
|
51
|
+
contextValue,
|
|
52
|
+
hasActiveTarget: targetRefs.length > 0,
|
|
53
|
+
measuredRef: targetRefs[0] ?? ownerRef
|
|
54
|
+
};
|
|
55
|
+
};
|
|
56
|
+
//# sourceMappingURL=boundary-owner.provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createContext","useCallback","useContext","useMemo","useRef","useState","jsx","_jsx","BoundaryOwnerContext","MULTIPLE_TARGETS_WARNING","TARGET_OUTSIDE_OWNER_WARNING","BoundaryOwnerProvider","props","value","children","Provider","useBoundaryOwnerContext","useBoundaryOwner","params","ownerRef","associatedTargetStyles","warnedAboutMultipleTargetsRef","targetRefs","setTargetRefs","registerTargetRef","targetRef","prev","includes","__DEV__","length","current","console","warn","unregisterTargetRef","filter","existingRef","contextValue","activeTargetRef","hasActiveTarget","measuredRef"],"sourceRoot":"../../../../../../src","sources":["shared/components/create-boundary-component/providers/boundary-owner.provider.tsx"],"mappings":";;AACA,SACCA,aAAa,EAEbC,WAAW,EACXC,UAAU,EACVC,OAAO,EACPC,MAAM,EACNC,QAAQ,QACF,OAAO;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAiBf,MAAMC,oBAAoB,gBAAGR,aAAa,CACzC,IACD,CAAC;AAED,MAAMS,wBAAwB,GAC7B,gKAAgK;AAEjK,OAAO,MAAMC,4BAA4B,GACxC,kLAAkL;AAEnL,OAAO,MAAMC,qBAAqB,GAAIC,KAGrC,IAAK;EACL,MAAM;IAAEC,KAAK;IAAEC;EAAS,CAAC,GAAGF,KAAK;EAEjC,oBACCL,IAAA,CAACC,oBAAoB,CAACO,QAAQ;IAACF,KAAK,EAAEA,KAAM;IAAAC,QAAA,EAC1CA;EAAQ,CACqB,CAAC;AAElC,CAAC;AAED,OAAO,MAAME,uBAAuB,GAAGA,CAAA,KAAM;EAC5C,OAAOd,UAAU,CAACM,oBAAoB,CAAC;AACxC,CAAC;AAED,OAAO,MAAMS,gBAAgB,GAAIC,MAGhC,IAAK;EACL,MAAM;IAAEC,QAAQ;IAAEC;EAAuB,CAAC,GAAGF,MAAM;EACnD,MAAMG,6BAA6B,GAAGjB,MAAM,CAAC,KAAK,CAAC;EACnD,MAAM,CAACkB,UAAU,EAAEC,aAAa,CAAC,GAAGlB,QAAQ,CAAsB,EAAE,CAAC;EAErE,MAAMmB,iBAAiB,GAAGvB,WAAW,CAAEwB,SAA4B,IAAK;IACvEF,aAAa,CAAEG,IAAI,IAAK;MACvB,IAAIA,IAAI,CAACC,QAAQ,CAACF,SAAS,CAAC,EAAE;QAC7B,OAAOC,IAAI;MACZ;MAEA,IACCE,OAAO,IACPF,IAAI,CAACG,MAAM,GAAG,CAAC,IACf,CAACR,6BAA6B,CAACS,OAAO,EACrC;QACDT,6BAA6B,CAACS,OAAO,GAAG,IAAI;QAC5CC,OAAO,CAACC,IAAI,CAACvB,wBAAwB,CAAC;MACvC;MAEA,OAAO,CAAC,GAAGiB,IAAI,EAAED,SAAS,CAAC;IAC5B,CAAC,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMQ,mBAAmB,GAAGhC,WAAW,CAAEwB,SAA4B,IAAK;IACzEF,aAAa,CAAEG,IAAI,IAClBA,IAAI,CAACQ,MAAM,CAAEC,WAAW,IAAKA,WAAW,KAAKV,SAAS,CACvD,CAAC;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMW,YAAY,GAAGjC,OAAO,CAC3B,OAAO;IACNgB,QAAQ;IACRK,iBAAiB;IACjBS,mBAAmB;IACnBI,eAAe,EAAEf,UAAU,CAAC,CAAC,CAAC,IAAI,IAAI;IACtCF;EACD,CAAC,CAAC,EACF,CACCD,QAAQ,EACRK,iBAAiB,EACjBS,mBAAmB,EACnBX,UAAU,EACVF,sBAAsB,CAExB,CAAC;EAED,OAAO;IACNgB,YAAY;IACZE,eAAe,EAAEhB,UAAU,CAACO,MAAM,GAAG,CAAC;IACtCU,WAAW,EAAEjB,UAAU,CAAC,CAAC,CAAC,IAAIH;EAC/B,CAAC;AACF,CAAC","ignoreList":[]}
|
|
@@ -4,10 +4,11 @@
|
|
|
4
4
|
|
|
5
5
|
import { forwardRef, memo, useCallback } from "react";
|
|
6
6
|
import { GestureDetector } from "react-native-gesture-handler";
|
|
7
|
-
import Animated, { runOnUI, useAnimatedRef, useComposedEventHandler, useSharedValue } from "react-native-reanimated";
|
|
8
|
-
import {
|
|
7
|
+
import Animated, { runOnUI, useAnimatedProps, useAnimatedRef, useAnimatedStyle, useComposedEventHandler, useSharedValue } from "react-native-reanimated";
|
|
8
|
+
import { NO_PROPS, NO_STYLES } from "../constants";
|
|
9
9
|
import { useScrollRegistry } from "../hooks/gestures/use-scroll-registry";
|
|
10
10
|
import { RegisterBoundsProvider } from "../providers/register-bounds.provider";
|
|
11
|
+
import { useScreenStyles } from "../providers/screen/styles";
|
|
11
12
|
import { ScrollSettleProvider } from "../providers/scroll-settle.provider";
|
|
12
13
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
14
|
export function createTransitionAwareComponent(Wrapped, options = {}) {
|
|
@@ -95,12 +96,33 @@ export function createTransitionAwareComponent(Wrapped, options = {}) {
|
|
|
95
96
|
} = props;
|
|
96
97
|
const animatedRef = useAnimatedRef();
|
|
97
98
|
const {
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
99
|
+
elementStylesMap
|
|
100
|
+
} = useScreenStyles();
|
|
101
|
+
const associatedId = sharedBoundTag || styleId;
|
|
102
|
+
const associatedStyles = useAnimatedStyle(() => {
|
|
103
|
+
"worklet";
|
|
104
|
+
|
|
105
|
+
if (!associatedId) {
|
|
106
|
+
return {
|
|
107
|
+
opacity: 1
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
const baseStyle = elementStylesMap.value[associatedId]?.style ?? NO_STYLES;
|
|
111
|
+
if ("opacity" in baseStyle) {
|
|
112
|
+
return baseStyle;
|
|
113
|
+
}
|
|
114
|
+
return {
|
|
115
|
+
...baseStyle,
|
|
116
|
+
opacity: 1
|
|
117
|
+
};
|
|
118
|
+
});
|
|
119
|
+
const associatedProps = useAnimatedProps(() => {
|
|
120
|
+
"worklet";
|
|
121
|
+
|
|
122
|
+
if (!associatedId) {
|
|
123
|
+
return NO_PROPS;
|
|
124
|
+
}
|
|
125
|
+
return elementStylesMap.value[associatedId]?.props ?? NO_PROPS;
|
|
104
126
|
});
|
|
105
127
|
return /*#__PURE__*/_jsx(RegisterBoundsProvider, {
|
|
106
128
|
animatedRef: animatedRef,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["forwardRef","memo","useCallback","GestureDetector","Animated","runOnUI","useAnimatedRef","useComposedEventHandler","useSharedValue","
|
|
1
|
+
{"version":3,"names":["forwardRef","memo","useCallback","GestureDetector","Animated","runOnUI","useAnimatedProps","useAnimatedRef","useAnimatedStyle","useComposedEventHandler","useSharedValue","NO_PROPS","NO_STYLES","useScrollRegistry","RegisterBoundsProvider","useScreenStyles","ScrollSettleProvider","jsx","_jsx","createTransitionAwareComponent","Wrapped","options","isScrollable","alreadyAnimated","AnimatedComponent","createAnimatedComponent","ScrollableInner","props","ref","remeasureOnFocus","_remeasureOnFocus","onScroll","userOnScroll","onMomentumScrollEnd","userOnMomentumScrollEnd","onScrollEndDrag","userOnScrollEndDrag","scrollableProps","settledSignal","emitScrollSettled","value","scrollDirection","horizontal","scrollHandler","onContentSizeChange","onLayout","nativeGesture","direction","composedScrollHandler","handleMomentumScrollEnd","event","handleScrollEndDrag","velocityX","Math","abs","nativeEvent","velocity","x","velocityY","y","scrollableComponent","scrollEventThrottle","children","gesture","Inner","_","style","sharedBoundTag","styleId","onPress","rest","animatedRef","elementStylesMap","associatedId","associatedStyles","opacity","baseStyle","associatedProps","captureActiveOnPress","handleInitialLayout","animatedProps","collapsable"],"sourceRoot":"../../../../src","sources":["shared/components/create-transition-aware-component.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -6,7 +6,7 @@ import { useOptimisticFocusedIndex } from "../../../hooks/navigation/use-optimis
|
|
|
6
6
|
import { useStack } from "../../../hooks/navigation/use-stack";
|
|
7
7
|
import { ScreenAnimationProvider } from "../../../providers/screen/animation";
|
|
8
8
|
import { DescriptorsProvider } from "../../../providers/screen/descriptors";
|
|
9
|
-
import { ScreenStylesProvider } from "../../../providers/screen/styles
|
|
9
|
+
import { ScreenStylesProvider } from "../../../providers/screen/styles";
|
|
10
10
|
import { getActiveFloatOverlay } from "../helpers/get-active-overlay";
|
|
11
11
|
import { OverlayHost } from "./overlay-host";
|
|
12
12
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useMemo","snapDescriptorToIndex","useOptimisticFocusedIndex","useStack","ScreenAnimationProvider","DescriptorsProvider","ScreenStylesProvider","getActiveFloatOverlay","OverlayHost","jsx","_jsx","FloatOverlay","scenes","optimisticFocusedIndex","flags","routes","routeKeys","focusedIndex","length","activeOverlay","TRANSITIONS_ALWAYS_ON","overlayData","scene","overlayIndex","previous","descriptor","current","next","focusedScene","focusedDescriptor","overlayScreenState","index","indexOf","route","key","options","focusedRoute","meta","navigation","snapTo","children"],"sourceRoot":"../../../../../../src","sources":["shared/components/overlay/variations/float-overlay.tsx"],"mappings":";;AAAA,SAASA,OAAO,QAAQ,OAAO;AAC/B,SAASC,qBAAqB,QAAQ,4BAA4B;AAClE,SAASC,yBAAyB,QAAQ,wDAAwD;AAClG,SAASC,QAAQ,QAAQ,qCAAqC;AAC9D,SAASC,uBAAuB,QAAQ,qCAAqC;AAE7E,SAASC,mBAAmB,QAAQ,uCAAuC;AAC3E,SAASC,oBAAoB,QAAQ,
|
|
1
|
+
{"version":3,"names":["useMemo","snapDescriptorToIndex","useOptimisticFocusedIndex","useStack","ScreenAnimationProvider","DescriptorsProvider","ScreenStylesProvider","getActiveFloatOverlay","OverlayHost","jsx","_jsx","FloatOverlay","scenes","optimisticFocusedIndex","flags","routes","routeKeys","focusedIndex","length","activeOverlay","TRANSITIONS_ALWAYS_ON","overlayData","scene","overlayIndex","previous","descriptor","current","next","focusedScene","focusedDescriptor","overlayScreenState","index","indexOf","route","key","options","focusedRoute","meta","navigation","snapTo","children"],"sourceRoot":"../../../../../../src","sources":["shared/components/overlay/variations/float-overlay.tsx"],"mappings":"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","ignoreList":[]}
|
package/lib/module/shared/components/screen-container/hooks/use-backdrop-pointer-events.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useDescriptors","useStackCoreContext","StackType","useBackdropPointerEvents","current","flags","isComponentStack","STACK_TYPE","COMPONENT","backdropBehavior","options","pointerEvents","undefined","isBackdropActive"],"sourceRoot":"../../../../../../src","sources":["shared/components/screen-container/hooks/use-backdrop-pointer-events.ts"],"mappings":";;AAAA,SAASA,cAAc,QAAQ,uCAAuC;AACtE,SAASC,mBAAmB,QAAQ,wCAAwC;
|
|
1
|
+
{"version":3,"names":["useDescriptors","useStackCoreContext","StackType","useBackdropPointerEvents","current","flags","isComponentStack","STACK_TYPE","COMPONENT","backdropBehavior","options","pointerEvents","undefined","isBackdropActive"],"sourceRoot":"../../../../../../src","sources":["shared/components/screen-container/hooks/use-backdrop-pointer-events.ts"],"mappings":";;AAAA,SAASA,cAAc,QAAQ,uCAAuC;AACtE,SAASC,mBAAmB,QAAQ,wCAAwC;AAE5E,SAASC,SAAS,QAAQ,4BAA4B;AAQtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,wBAAwBA,CAAA,EAAgC;EACvE,MAAM;IAAEC;EAAQ,CAAC,GAAGJ,cAAc,CAAC,CAAC;EACpC,MAAM;IAAEK;EAAM,CAAC,GAAGJ,mBAAmB,CAAC,CAAC;EAEvC,MAAMK,gBAAgB,GAAGD,KAAK,CAACE,UAAU,KAAKL,SAAS,CAACM,SAAS;EACjE,MAAMC,gBAAkC,GACvCL,OAAO,CAACM,OAAO,CAACD,gBAAgB,KAC/BH,gBAAgB,GAAG,aAAa,GAAG,OAAO,CAAC;EAE7C,MAAMK,aAAa,GAClBF,gBAAgB,KAAK,aAAa,GAAG,UAAU,GAAGG,SAAS;EAE5D,MAAMC,gBAAgB,GACrBJ,gBAAgB,KAAK,SAAS,IAAIA,gBAAgB,KAAK,UAAU;EAElE,OAAO;IAAEE,aAAa;IAAEF,gBAAgB;IAAEI;EAAiB,CAAC;AAC7D","ignoreList":[]}
|
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
import { memo } from "react";
|
|
4
4
|
import { StyleSheet, View } from "react-native";
|
|
5
|
-
import { DeferredVisibilityHost } from "./deferred-visibility-host";
|
|
6
5
|
import { useBackdropPointerEvents } from "./hooks/use-backdrop-pointer-events";
|
|
7
6
|
import { BackdropLayer } from "./layers/backdrop";
|
|
8
7
|
import { ContentLayer } from "./layers/content";
|
|
@@ -11,16 +10,21 @@ export const ScreenContainer = /*#__PURE__*/memo(({
|
|
|
11
10
|
children
|
|
12
11
|
}) => {
|
|
13
12
|
const {
|
|
14
|
-
pointerEvents
|
|
13
|
+
pointerEvents,
|
|
14
|
+
isBackdropActive,
|
|
15
|
+
backdropBehavior
|
|
15
16
|
} = useBackdropPointerEvents();
|
|
16
|
-
return /*#__PURE__*/
|
|
17
|
+
return /*#__PURE__*/_jsxs(View, {
|
|
17
18
|
style: styles.container,
|
|
18
19
|
pointerEvents: pointerEvents,
|
|
19
|
-
children: /*#__PURE__*/
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
children: [/*#__PURE__*/_jsx(BackdropLayer, {
|
|
21
|
+
isBackdropActive: isBackdropActive,
|
|
22
|
+
backdropBehavior: backdropBehavior
|
|
23
|
+
}), /*#__PURE__*/_jsx(ContentLayer, {
|
|
24
|
+
pointerEvents: pointerEvents,
|
|
25
|
+
isBackdropActive: isBackdropActive,
|
|
26
|
+
children: children
|
|
27
|
+
})]
|
|
24
28
|
});
|
|
25
29
|
});
|
|
26
30
|
const styles = StyleSheet.create({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["memo","StyleSheet","View","
|
|
1
|
+
{"version":3,"names":["memo","StyleSheet","View","useBackdropPointerEvents","BackdropLayer","ContentLayer","jsx","_jsx","jsxs","_jsxs","ScreenContainer","children","pointerEvents","isBackdropActive","backdropBehavior","style","styles","container","create","flex"],"sourceRoot":"../../../../../src","sources":["shared/components/screen-container/index.tsx"],"mappings":";;AAAA,SAASA,IAAI,QAAQ,OAAO;AAC5B,SAASC,UAAU,EAAEC,IAAI,QAAQ,cAAc;AAC/C,SAASC,wBAAwB,QAAQ,qCAAqC;AAC9E,SAASC,aAAa,QAAQ,mBAAmB;AACjD,SAASC,YAAY,QAAQ,kBAAkB;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAMhD,OAAO,MAAMC,eAAe,gBAAGV,IAAI,CAAC,CAAC;EAAEW;AAAgB,CAAC,KAAK;EAC5D,MAAM;IAAEC,aAAa;IAAEC,gBAAgB;IAAEC;EAAiB,CAAC,GAC1DX,wBAAwB,CAAC,CAAC;EAE3B,oBACCM,KAAA,CAACP,IAAI;IAACa,KAAK,EAAEC,MAAM,CAACC,SAAU;IAACL,aAAa,EAAEA,aAAc;IAAAD,QAAA,gBAC3DJ,IAAA,CAACH,aAAa;MACbS,gBAAgB,EAAEA,gBAAiB;MACnCC,gBAAgB,EAAEA;IAAiB,CACnC,CAAC,eACFP,IAAA,CAACF,YAAY;MACZO,aAAa,EAAEA,aAAc;MAC7BC,gBAAgB,EAAEA,gBAAiB;MAAAF,QAAA,EAElCA;IAAQ,CACI,CAAC;EAAA,CACV,CAAC;AAET,CAAC,CAAC;AAEF,MAAMK,MAAM,GAAGf,UAAU,CAACiB,MAAM,CAAC;EAChCD,SAAS,EAAE;IACVE,IAAI,EAAE;EACP;AACD,CAAC,CAAC","ignoreList":[]}
|
|
@@ -7,17 +7,19 @@ import { DefaultSnapSpec } from "../../../configs/specs";
|
|
|
7
7
|
import { NO_PROPS, NO_STYLES } from "../../../constants";
|
|
8
8
|
import { useNavigationHelpers } from "../../../hooks/navigation/use-navigation-helpers";
|
|
9
9
|
import { useDescriptors } from "../../../providers/screen/descriptors";
|
|
10
|
-
import { useScreenStyles } from "../../../providers/screen/styles
|
|
10
|
+
import { useScreenStyles } from "../../../providers/screen/styles";
|
|
11
11
|
import { AnimationStore } from "../../../stores/animation.store";
|
|
12
12
|
import { GestureStore } from "../../../stores/gesture.store";
|
|
13
13
|
import { SystemStore } from "../../../stores/system.store";
|
|
14
14
|
import { animateToProgress } from "../../../utils/animation/animate-to-progress";
|
|
15
15
|
import { findCollapseTarget } from "../../../utils/gesture/find-collapse-target";
|
|
16
|
-
import { useBackdropPointerEvents } from "../hooks/use-backdrop-pointer-events";
|
|
17
16
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
18
|
-
export const BackdropLayer = /*#__PURE__*/memo(function BackdropLayer(
|
|
17
|
+
export const BackdropLayer = /*#__PURE__*/memo(function BackdropLayer({
|
|
18
|
+
backdropBehavior,
|
|
19
|
+
isBackdropActive
|
|
20
|
+
}) {
|
|
19
21
|
const {
|
|
20
|
-
|
|
22
|
+
layerStylesMap
|
|
21
23
|
} = useScreenStyles();
|
|
22
24
|
const {
|
|
23
25
|
current
|
|
@@ -25,10 +27,6 @@ export const BackdropLayer = /*#__PURE__*/memo(function BackdropLayer() {
|
|
|
25
27
|
const {
|
|
26
28
|
dismissScreen
|
|
27
29
|
} = useNavigationHelpers();
|
|
28
|
-
const {
|
|
29
|
-
isBackdropActive,
|
|
30
|
-
backdropBehavior
|
|
31
|
-
} = useBackdropPointerEvents();
|
|
32
30
|
const BackdropComponent = current.options.backdropComponent;
|
|
33
31
|
const routeKey = current.route.key;
|
|
34
32
|
const animations = AnimationStore.getBag(routeKey);
|
|
@@ -80,12 +78,12 @@ export const BackdropLayer = /*#__PURE__*/memo(function BackdropLayer() {
|
|
|
80
78
|
const animatedBackdropStyle = useAnimatedStyle(() => {
|
|
81
79
|
"worklet";
|
|
82
80
|
|
|
83
|
-
return
|
|
81
|
+
return layerStylesMap.value.backdrop?.style ?? NO_STYLES;
|
|
84
82
|
});
|
|
85
83
|
const animatedBackdropProps = useAnimatedProps(() => {
|
|
86
84
|
"worklet";
|
|
87
85
|
|
|
88
|
-
return
|
|
86
|
+
return layerStylesMap.value.backdrop?.props ?? NO_PROPS;
|
|
89
87
|
});
|
|
90
88
|
return /*#__PURE__*/_jsxs(Pressable, {
|
|
91
89
|
style: StyleSheet.absoluteFillObject,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["memo","useCallback","useMemo","Pressable","StyleSheet","Animated","runOnUI","useAnimatedProps","useAnimatedStyle","DefaultSnapSpec","NO_PROPS","NO_STYLES","useNavigationHelpers","useDescriptors","useScreenStyles","AnimationStore","GestureStore","SystemStore","animateToProgress","findCollapseTarget","
|
|
1
|
+
{"version":3,"names":["memo","useCallback","useMemo","Pressable","StyleSheet","Animated","runOnUI","useAnimatedProps","useAnimatedStyle","DefaultSnapSpec","NO_PROPS","NO_STYLES","useNavigationHelpers","useDescriptors","useScreenStyles","AnimationStore","GestureStore","SystemStore","animateToProgress","findCollapseTarget","jsx","_jsx","jsxs","_jsxs","BackdropLayer","backdropBehavior","isBackdropActive","layerStylesMap","current","dismissScreen","BackdropComponent","options","backdropComponent","routeKey","route","key","animations","getBag","targetProgressValue","getValue","resolvedAutoSnapPointValue","AnimatedBackdropComponent","createAnimatedComponent","handleBackdropPress","rawSnapPoints","snapPoints","canDismiss","gestureEnabled","length","gestures","transitionSpec","resolvedSnaps","map","point","value","filter","target","shouldDismiss","progress","dismissing","spec","open","expand","close","collapse","targetProgress","onAnimationFinish","undefined","animatedBackdropStyle","backdrop","style","animatedBackdropProps","props","absoluteFillObject","pointerEvents","onPress","children","animatedProps","View"],"sourceRoot":"../../../../../../src","sources":["shared/components/screen-container/layers/backdrop.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -8,26 +8,23 @@ import Animated, { useAnimatedProps, useAnimatedStyle } from "react-native-reani
|
|
|
8
8
|
import { NO_PROPS, NO_STYLES } from "../../../constants";
|
|
9
9
|
import { useGestureContext } from "../../../providers/gestures";
|
|
10
10
|
import { useDescriptors } from "../../../providers/screen/descriptors";
|
|
11
|
-
import { useScreenStyles } from "../../../providers/screen/styles
|
|
11
|
+
import { useScreenStyles } from "../../../providers/screen/styles";
|
|
12
12
|
import { resolveNavigationMaskEnabled } from "../../../utils/resolve-screen-transition-options";
|
|
13
|
-
import { useBackdropPointerEvents } from "../hooks/use-backdrop-pointer-events";
|
|
14
13
|
import { useContentLayout } from "../hooks/use-content-layout";
|
|
15
14
|
import { MaybeMaskedNavigationContainer } from "./maybe-masked-navigation-container";
|
|
16
15
|
import { SurfaceContainer } from "./surface-container";
|
|
17
16
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
18
17
|
export const ContentLayer = /*#__PURE__*/memo(({
|
|
19
|
-
children
|
|
18
|
+
children,
|
|
19
|
+
pointerEvents,
|
|
20
|
+
isBackdropActive
|
|
20
21
|
}) => {
|
|
21
22
|
const {
|
|
22
|
-
|
|
23
|
+
layerStylesMap
|
|
23
24
|
} = useScreenStyles();
|
|
24
25
|
const {
|
|
25
26
|
current
|
|
26
27
|
} = useDescriptors();
|
|
27
|
-
const {
|
|
28
|
-
pointerEvents,
|
|
29
|
-
isBackdropActive
|
|
30
|
-
} = useBackdropPointerEvents();
|
|
31
28
|
const gestureContext = useGestureContext();
|
|
32
29
|
const isNavigationMaskEnabled = resolveNavigationMaskEnabled(current.options);
|
|
33
30
|
const contentPointerEvents = isBackdropActive ? "box-none" : pointerEvents;
|
|
@@ -36,12 +33,12 @@ export const ContentLayer = /*#__PURE__*/memo(({
|
|
|
36
33
|
const animatedContentStyle = useAnimatedStyle(() => {
|
|
37
34
|
"worklet";
|
|
38
35
|
|
|
39
|
-
return
|
|
36
|
+
return layerStylesMap.value.content?.style || NO_STYLES;
|
|
40
37
|
});
|
|
41
38
|
const animatedContentProps = useAnimatedProps(() => {
|
|
42
39
|
"worklet";
|
|
43
40
|
|
|
44
|
-
return
|
|
41
|
+
return layerStylesMap.value.content?.props ?? NO_PROPS;
|
|
45
42
|
});
|
|
46
43
|
return /*#__PURE__*/_jsx(GestureDetector, {
|
|
47
44
|
gesture: gestureContext.panGesture,
|