expo-router 7.0.0-canary-20251031-b135dff → 7.0.0-canary-20251118-4ca99d5
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/build/Route.d.ts +2 -0
- package/build/Route.d.ts.map +1 -1
- package/build/Route.js.map +1 -1
- package/build/color/android.attr.types.d.ts +142 -0
- package/build/color/android.attr.types.d.ts.map +1 -0
- package/build/color/android.attr.types.js +3 -0
- package/build/color/android.attr.types.js.map +1 -0
- package/build/color/android.color.types.d.ts +1278 -0
- package/build/color/android.color.types.d.ts.map +1 -0
- package/build/color/android.color.types.js +3 -0
- package/build/color/android.color.types.js.map +1 -0
- package/build/color/android.dynamic.types.d.ts +384 -0
- package/build/color/android.dynamic.types.d.ts.map +1 -0
- package/build/color/android.dynamic.types.js +3 -0
- package/build/color/android.dynamic.types.js.map +1 -0
- package/build/color/android.material.types.d.ts +291 -0
- package/build/color/android.material.types.d.ts.map +1 -0
- package/build/color/android.material.types.js +3 -0
- package/build/color/android.material.types.js.map +1 -0
- package/build/color/index.d.ts +35 -0
- package/build/color/index.d.ts.map +1 -0
- package/build/color/index.js +71 -0
- package/build/color/index.js.map +1 -0
- package/build/color/ios.types.d.ts +156 -0
- package/build/color/ios.types.d.ts.map +1 -0
- package/build/color/ios.types.js +3 -0
- package/build/color/ios.types.js.map +1 -0
- package/build/color/materialColor.android.d.ts +4 -0
- package/build/color/materialColor.android.d.ts.map +1 -0
- package/build/color/materialColor.android.js +28 -0
- package/build/color/materialColor.android.js.map +1 -0
- package/build/color/materialColor.d.ts +4 -0
- package/build/color/materialColor.d.ts.map +1 -0
- package/build/color/materialColor.js +11 -0
- package/build/color/materialColor.js.map +1 -0
- package/build/exports.d.ts +2 -0
- package/build/exports.d.ts.map +1 -1
- package/build/exports.js +7 -1
- package/build/exports.js.map +1 -1
- package/build/layouts/DrawerClient.d.ts +4 -2
- package/build/layouts/DrawerClient.d.ts.map +1 -1
- package/build/layouts/Stack.d.ts.map +1 -1
- package/build/layouts/Stack.js +3 -2
- package/build/layouts/Stack.js.map +1 -1
- package/build/layouts/Stack.web.d.ts.map +1 -1
- package/build/layouts/Stack.web.js +3 -2
- package/build/layouts/Stack.web.js.map +1 -1
- package/build/layouts/StackClient.d.ts +18 -10
- package/build/layouts/StackClient.d.ts.map +1 -1
- package/build/layouts/StackClient.js +95 -5
- package/build/layouts/StackClient.js.map +1 -1
- package/build/layouts/TabsClient.d.ts +6 -3
- package/build/layouts/TabsClient.d.ts.map +1 -1
- package/build/layouts/stack-utils/StackHeaderBackButton.d.ts +14 -0
- package/build/layouts/stack-utils/StackHeaderBackButton.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderBackButton.js +19 -0
- package/build/layouts/stack-utils/StackHeaderBackButton.js.map +1 -0
- package/build/layouts/stack-utils/StackHeaderComponent.d.ts +22 -0
- package/build/layouts/stack-utils/StackHeaderComponent.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderComponent.js +67 -0
- package/build/layouts/stack-utils/StackHeaderComponent.js.map +1 -0
- package/build/layouts/stack-utils/StackHeaderLeft.d.ts +9 -0
- package/build/layouts/stack-utils/StackHeaderLeft.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderLeft.js +17 -0
- package/build/layouts/stack-utils/StackHeaderLeft.js.map +1 -0
- package/build/layouts/stack-utils/StackHeaderRight.d.ts +9 -0
- package/build/layouts/stack-utils/StackHeaderRight.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderRight.js +17 -0
- package/build/layouts/stack-utils/StackHeaderRight.js.map +1 -0
- package/build/layouts/stack-utils/StackHeaderSearchBar.d.ts +7 -0
- package/build/layouts/stack-utils/StackHeaderSearchBar.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderSearchBar.js +16 -0
- package/build/layouts/stack-utils/StackHeaderSearchBar.js.map +1 -0
- package/build/layouts/stack-utils/StackHeaderTitle.d.ts +22 -0
- package/build/layouts/stack-utils/StackHeaderTitle.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackHeaderTitle.js +41 -0
- package/build/layouts/stack-utils/StackHeaderTitle.js.map +1 -0
- package/build/layouts/stack-utils/StackScreen.d.ts +9 -0
- package/build/layouts/stack-utils/StackScreen.d.ts.map +1 -0
- package/build/layouts/stack-utils/StackScreen.js +34 -0
- package/build/layouts/stack-utils/StackScreen.js.map +1 -0
- package/build/layouts/stack-utils/index.d.ts +17 -0
- package/build/layouts/stack-utils/index.d.ts.map +1 -0
- package/build/layouts/stack-utils/index.js +28 -0
- package/build/layouts/stack-utils/index.js.map +1 -0
- package/build/layouts/stack-utils/utils.d.ts +3 -0
- package/build/layouts/stack-utils/utils.d.ts.map +1 -0
- package/build/layouts/stack-utils/utils.js +8 -0
- package/build/layouts/stack-utils/utils.js.map +1 -0
- package/build/layouts/withLayoutContext.js +1 -1
- package/build/layouts/withLayoutContext.js.map +1 -1
- package/build/loaders/utils.d.ts +9 -0
- package/build/loaders/utils.d.ts.map +1 -1
- package/build/loaders/utils.js +16 -2
- package/build/loaders/utils.js.map +1 -1
- package/build/native-tabs/NativeBottomTabsNavigator.d.ts.map +1 -1
- package/build/native-tabs/NativeBottomTabsNavigator.js.map +1 -1
- package/build/native-tabs/NativeTabTrigger.d.ts +9 -7
- package/build/native-tabs/NativeTabTrigger.d.ts.map +1 -1
- package/build/native-tabs/NativeTabTrigger.js +25 -64
- package/build/native-tabs/NativeTabTrigger.js.map +1 -1
- package/build/native-tabs/NativeTabs.d.ts +4 -1
- package/build/native-tabs/NativeTabs.d.ts.map +1 -1
- package/build/native-tabs/NativeTabsView.d.ts.map +1 -1
- package/build/native-tabs/NativeTabsView.js +8 -3
- package/build/native-tabs/NativeTabsView.js.map +1 -1
- package/build/native-tabs/common/elements.d.ts +28 -90
- package/build/native-tabs/common/elements.d.ts.map +1 -1
- package/build/native-tabs/common/elements.js +16 -18
- package/build/native-tabs/common/elements.js.map +1 -1
- package/build/native-tabs/index.d.ts +1 -2
- package/build/native-tabs/index.d.ts.map +1 -1
- package/build/native-tabs/index.js +1 -3
- package/build/native-tabs/index.js.map +1 -1
- package/build/native-tabs/types.d.ts +20 -170
- package/build/native-tabs/types.d.ts.map +1 -1
- package/build/native-tabs/types.js.map +1 -1
- package/build/native-tabs/utils/icon.d.ts +3 -3
- package/build/native-tabs/utils/icon.d.ts.map +1 -1
- package/build/native-tabs/utils/icon.js +22 -13
- package/build/native-tabs/utils/icon.js.map +1 -1
- package/build/primitives/elements.d.ts +18 -0
- package/build/primitives/elements.d.ts.map +1 -0
- package/build/primitives/elements.js +31 -0
- package/build/primitives/elements.js.map +1 -0
- package/build/primitives/index.d.ts +5 -0
- package/build/primitives/index.d.ts.map +1 -0
- package/build/primitives/index.js +26 -0
- package/build/primitives/index.js.map +1 -0
- package/build/primitives/menu.d.ts +12 -0
- package/build/primitives/menu.d.ts.map +1 -0
- package/build/primitives/menu.js +28 -0
- package/build/primitives/menu.js.map +1 -0
- package/build/{primitives.d.ts → primitives/navigation.d.ts} +1 -1
- package/build/primitives/navigation.d.ts.map +1 -0
- package/build/{primitives.js → primitives/navigation.js} +1 -1
- package/build/primitives/navigation.js.map +1 -0
- package/build/primitives/types.d.ts +26 -0
- package/build/primitives/types.d.ts.map +1 -0
- package/build/primitives/types.js +3 -0
- package/build/primitives/types.js.map +1 -0
- package/build/split-view/elements.js +4 -4
- package/build/split-view/elements.js.map +1 -1
- package/build/split-view/split-view.d.ts +1 -1
- package/build/split-view/split-view.d.ts.map +1 -1
- package/build/split-view/split-view.js +5 -5
- package/build/split-view/split-view.js.map +1 -1
- package/expo-module.config.json +10 -1
- package/ios/{ExpoHead.podspec → ExpoRouter.podspec} +1 -1
- package/package.json +14 -14
- package/build/native-tabs/NativeTabsTriggerTabBar.d.ts +0 -24
- package/build/native-tabs/NativeTabsTriggerTabBar.d.ts.map +0 -1
- package/build/native-tabs/NativeTabsTriggerTabBar.js +0 -28
- package/build/native-tabs/NativeTabsTriggerTabBar.js.map +0 -1
- package/build/primitives.d.ts.map +0 -1
- package/build/primitives.js.map +0 -1
- package/node/getExpoConstantsManifest.js +0 -163
|
@@ -3,7 +3,7 @@ import { ParamListBase, TabNavigationState } from '@react-navigation/native';
|
|
|
3
3
|
import React, { ComponentProps } from 'react';
|
|
4
4
|
import { Href } from '../types';
|
|
5
5
|
import { Protected } from '../views/Protected';
|
|
6
|
-
declare const BottomTabNavigator: React.ComponentType<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "
|
|
6
|
+
declare const BottomTabNavigator: React.ComponentType<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "screenOptions" | "screenListeners" | "screenLayout" | "UNSTABLE_router" | "UNSTABLE_routeNamesChangeBehavior"> & import("@react-navigation/native").DefaultRouterOptions<string> & {
|
|
7
7
|
children: React.ReactNode;
|
|
8
8
|
layout?: ((props: {
|
|
9
9
|
state: TabNavigationState<ParamListBase>;
|
|
@@ -45,6 +45,7 @@ declare const BottomTabNavigator: React.ComponentType<Omit<import("@react-naviga
|
|
|
45
45
|
source?: string;
|
|
46
46
|
target?: string;
|
|
47
47
|
}>>(original: import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>) => Partial<import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>>) | undefined;
|
|
48
|
+
UNSTABLE_routeNamesChangeBehavior?: "firstMatch" | "lastUnhandled";
|
|
48
49
|
} & {
|
|
49
50
|
id?: undefined;
|
|
50
51
|
}>;
|
|
@@ -52,7 +53,7 @@ export type BottomTabNavigator = typeof BottomTabNavigator;
|
|
|
52
53
|
type TabsProps = BottomTabNavigationOptions & {
|
|
53
54
|
href?: Href | null;
|
|
54
55
|
};
|
|
55
|
-
declare const ExpoTabs: React.ForwardRefExoticComponent<Omit<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "
|
|
56
|
+
declare const ExpoTabs: React.ForwardRefExoticComponent<Omit<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "screenOptions" | "screenListeners" | "screenLayout" | "UNSTABLE_router" | "UNSTABLE_routeNamesChangeBehavior"> & import("@react-navigation/native").DefaultRouterOptions<string> & {
|
|
56
57
|
children: React.ReactNode;
|
|
57
58
|
layout?: ((props: {
|
|
58
59
|
state: TabNavigationState<ParamListBase>;
|
|
@@ -94,9 +95,10 @@ declare const ExpoTabs: React.ForwardRefExoticComponent<Omit<Omit<import("@react
|
|
|
94
95
|
source?: string;
|
|
95
96
|
target?: string;
|
|
96
97
|
}>>(original: import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>) => Partial<import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>>) | undefined;
|
|
98
|
+
UNSTABLE_routeNamesChangeBehavior?: "firstMatch" | "lastUnhandled";
|
|
97
99
|
} & {
|
|
98
100
|
id?: undefined;
|
|
99
|
-
}, "children"> & Partial<Pick<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "
|
|
101
|
+
}, "children"> & Partial<Pick<Omit<import("@react-navigation/bottom-tabs").BottomTabNavigatorProps, "children" | "layout" | "initialRouteName" | "id" | "screenOptions" | "screenListeners" | "screenLayout" | "UNSTABLE_router" | "UNSTABLE_routeNamesChangeBehavior"> & import("@react-navigation/native").DefaultRouterOptions<string> & {
|
|
100
102
|
children: React.ReactNode;
|
|
101
103
|
layout?: ((props: {
|
|
102
104
|
state: TabNavigationState<ParamListBase>;
|
|
@@ -138,6 +140,7 @@ declare const ExpoTabs: React.ForwardRefExoticComponent<Omit<Omit<import("@react
|
|
|
138
140
|
source?: string;
|
|
139
141
|
target?: string;
|
|
140
142
|
}>>(original: import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>) => Partial<import("@react-navigation/native").Router<TabNavigationState<ParamListBase>, Action>>) | undefined;
|
|
143
|
+
UNSTABLE_routeNamesChangeBehavior?: "firstMatch" | "lastUnhandled";
|
|
141
144
|
} & {
|
|
142
145
|
id?: undefined;
|
|
143
146
|
}, "children">> & React.RefAttributes<unknown>> & {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabsClient.d.ts","sourceRoot":"","sources":["../../src/layouts/TabsClient.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,2BAA2B,EAC3B,0BAA0B,EAE3B,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,KAAK,EAAE,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAK9C,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhC,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAG/C,QAAA,MAAM,kBAAkB
|
|
1
|
+
{"version":3,"file":"TabsClient.d.ts","sourceRoot":"","sources":["../../src/layouts/TabsClient.tsx"],"names":[],"mappings":"AAEA,OAAO,EACL,2BAA2B,EAC3B,0BAA0B,EAE3B,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,KAAK,EAAE,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAK9C,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhC,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAG/C,QAAA,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAAuC,CAAC;AAEhE,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC;AAE3D,KAAK,SAAS,GAAG,0BAA0B,GAAG;IAAE,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,CAAA;CAAE,CAAC;AAErE,QAAA,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0CZ,CAAC;AAEH,QAAA,MAAM,IAAI,WACA,cAAc,CAAC,OAAO,QAAQ,CAAC;;;CAOxC,CAAC;AAEF,eAAe,IAAI,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import type { ImageSourcePropType } from 'react-native';
|
|
3
|
+
import type { ScreenStackHeaderConfigProps } from 'react-native-screens';
|
|
4
|
+
export interface StackHeaderBackButtonProps {
|
|
5
|
+
children?: string;
|
|
6
|
+
style?: NativeStackNavigationOptions['headerBackTitleStyle'];
|
|
7
|
+
withMenu?: boolean;
|
|
8
|
+
displayMode?: ScreenStackHeaderConfigProps['backButtonDisplayMode'];
|
|
9
|
+
hidden?: boolean;
|
|
10
|
+
src?: ImageSourcePropType;
|
|
11
|
+
}
|
|
12
|
+
export declare function StackHeaderBackButton(props: StackHeaderBackButtonProps): null;
|
|
13
|
+
export declare function appendStackHeaderBackButtonPropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderBackButtonProps): NativeStackNavigationOptions;
|
|
14
|
+
//# sourceMappingURL=StackHeaderBackButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderBackButton.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderBackButton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACxD,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,sBAAsB,CAAC;AAEzE,MAAM,WAAW,0BAA0B;IACzC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,4BAA4B,CAAC,sBAAsB,CAAC,CAAC;IAC7D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,4BAA4B,CAAC,uBAAuB,CAAC,CAAC;IACpE,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,GAAG,CAAC,EAAE,mBAAmB,CAAC;CAC3B;AAED,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,QAEtE;AAED,wBAAgB,yCAAyC,CACvD,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,0BAA0B,GAChC,4BAA4B,CAU9B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderBackButton = StackHeaderBackButton;
|
|
4
|
+
exports.appendStackHeaderBackButtonPropsToOptions = appendStackHeaderBackButtonPropsToOptions;
|
|
5
|
+
function StackHeaderBackButton(props) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
function appendStackHeaderBackButtonPropsToOptions(options, props) {
|
|
9
|
+
return {
|
|
10
|
+
...options,
|
|
11
|
+
headerBackTitle: props.children,
|
|
12
|
+
headerBackTitleStyle: props.style,
|
|
13
|
+
headerBackImageSource: props.src,
|
|
14
|
+
headerBackButtonDisplayMode: props.displayMode,
|
|
15
|
+
headerBackButtonMenuEnabled: props.withMenu,
|
|
16
|
+
headerBackVisible: !props.hidden,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=StackHeaderBackButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderBackButton.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderBackButton.tsx"],"names":[],"mappings":";;AAaA,sDAEC;AAED,8FAaC;AAjBD,SAAgB,qBAAqB,CAAC,KAAiC;IACrE,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,yCAAyC,CACvD,OAAqC,EACrC,KAAiC;IAEjC,OAAO;QACL,GAAG,OAAO;QACV,eAAe,EAAE,KAAK,CAAC,QAAQ;QAC/B,oBAAoB,EAAE,KAAK,CAAC,KAAK;QACjC,qBAAqB,EAAE,KAAK,CAAC,GAAG;QAChC,2BAA2B,EAAE,KAAK,CAAC,WAAW;QAC9C,2BAA2B,EAAE,KAAK,CAAC,QAAQ;QAC3C,iBAAiB,EAAE,CAAC,KAAK,CAAC,MAAM;KACjC,CAAC;AACJ,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport type { ImageSourcePropType } from 'react-native';\nimport type { ScreenStackHeaderConfigProps } from 'react-native-screens';\n\nexport interface StackHeaderBackButtonProps {\n children?: string;\n style?: NativeStackNavigationOptions['headerBackTitleStyle'];\n withMenu?: boolean;\n displayMode?: ScreenStackHeaderConfigProps['backButtonDisplayMode'];\n hidden?: boolean;\n src?: ImageSourcePropType;\n}\n\nexport function StackHeaderBackButton(props: StackHeaderBackButtonProps) {\n return null;\n}\n\nexport function appendStackHeaderBackButtonPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderBackButtonProps\n): NativeStackNavigationOptions {\n return {\n ...options,\n headerBackTitle: props.children,\n headerBackTitleStyle: props.style,\n headerBackImageSource: props.src,\n headerBackButtonDisplayMode: props.displayMode,\n headerBackButtonMenuEnabled: props.withMenu,\n headerBackVisible: !props.hidden,\n };\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import { type ReactNode } from 'react';
|
|
3
|
+
import { type ColorValue, type StyleProp } from 'react-native';
|
|
4
|
+
import type { ScreenStackHeaderConfigProps } from 'react-native-screens';
|
|
5
|
+
export interface StackHeaderProps {
|
|
6
|
+
children?: ReactNode;
|
|
7
|
+
hidden?: boolean;
|
|
8
|
+
asChild?: boolean;
|
|
9
|
+
blurEffect?: ScreenStackHeaderConfigProps['blurEffect'];
|
|
10
|
+
style?: StyleProp<{
|
|
11
|
+
color?: ColorValue;
|
|
12
|
+
backgroundColor?: ScreenStackHeaderConfigProps['backgroundColor'];
|
|
13
|
+
shadowColor?: undefined | 'transparent';
|
|
14
|
+
}>;
|
|
15
|
+
largeStyle?: StyleProp<{
|
|
16
|
+
backgroundColor?: ScreenStackHeaderConfigProps['largeTitleBackgroundColor'];
|
|
17
|
+
shadowColor?: undefined | 'transparent';
|
|
18
|
+
}>;
|
|
19
|
+
}
|
|
20
|
+
export declare function StackHeaderComponent(props: StackHeaderProps): null;
|
|
21
|
+
export declare function appendStackHeaderPropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderProps): NativeStackNavigationOptions;
|
|
22
|
+
//# sourceMappingURL=StackHeaderComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderComponent.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderComponent.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EAA4B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AACjE,OAAO,EAAc,KAAK,UAAU,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAC3E,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,sBAAsB,CAAC;AAezE,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,UAAU,CAAC,EAAE,4BAA4B,CAAC,YAAY,CAAC,CAAC;IACxD,KAAK,CAAC,EAAE,SAAS,CAAC;QAChB,KAAK,CAAC,EAAE,UAAU,CAAC;QACnB,eAAe,CAAC,EAAE,4BAA4B,CAAC,iBAAiB,CAAC,CAAC;QAClE,WAAW,CAAC,EAAE,SAAS,GAAG,aAAa,CAAC;KACzC,CAAC,CAAC;IACH,UAAU,CAAC,EAAE,SAAS,CAAC;QACrB,eAAe,CAAC,EAAE,4BAA4B,CAAC,2BAA2B,CAAC,CAAC;QAC5E,WAAW,CAAC,EAAE,SAAS,GAAG,aAAa,CAAC;KACzC,CAAC,CAAC;CACJ;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,gBAAgB,QAE3D;AAED,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,gBAAgB,GACtB,4BAA4B,CAqD9B"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderComponent = StackHeaderComponent;
|
|
4
|
+
exports.appendStackHeaderPropsToOptions = appendStackHeaderPropsToOptions;
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const react_native_1 = require("react-native");
|
|
7
|
+
const StackHeaderBackButton_1 = require("./StackHeaderBackButton");
|
|
8
|
+
const StackHeaderLeft_1 = require("./StackHeaderLeft");
|
|
9
|
+
const StackHeaderRight_1 = require("./StackHeaderRight");
|
|
10
|
+
const StackHeaderSearchBar_1 = require("./StackHeaderSearchBar");
|
|
11
|
+
const StackHeaderTitle_1 = require("./StackHeaderTitle");
|
|
12
|
+
const utils_1 = require("./utils");
|
|
13
|
+
function StackHeaderComponent(props) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
function appendStackHeaderPropsToOptions(options, props) {
|
|
17
|
+
const flattenedStyle = react_native_1.StyleSheet.flatten(props.style);
|
|
18
|
+
const flattenedLargeStyle = react_native_1.StyleSheet.flatten(props.largeStyle);
|
|
19
|
+
if (props.hidden) {
|
|
20
|
+
return { ...options, headerShown: false };
|
|
21
|
+
}
|
|
22
|
+
if (props.asChild) {
|
|
23
|
+
return { ...options, header: () => props.children };
|
|
24
|
+
}
|
|
25
|
+
let updatedOptions = {
|
|
26
|
+
...options,
|
|
27
|
+
headerShown: !props.hidden,
|
|
28
|
+
headerBlurEffect: props.blurEffect,
|
|
29
|
+
headerStyle: {
|
|
30
|
+
backgroundColor: flattenedStyle?.backgroundColor,
|
|
31
|
+
},
|
|
32
|
+
headerLargeStyle: {
|
|
33
|
+
backgroundColor: flattenedLargeStyle?.backgroundColor,
|
|
34
|
+
},
|
|
35
|
+
headerShadowVisible: flattenedStyle?.shadowColor !== 'transparent',
|
|
36
|
+
headerLargeTitleShadowVisible: flattenedLargeStyle?.shadowColor !== 'transparent',
|
|
37
|
+
};
|
|
38
|
+
function appendChildOptions(child, options) {
|
|
39
|
+
let updatedOptions = options;
|
|
40
|
+
if ((0, utils_1.isChildOfType)(child, StackHeaderTitle_1.StackHeaderTitle)) {
|
|
41
|
+
updatedOptions = (0, StackHeaderTitle_1.appendStackHeaderTitlePropsToOptions)(updatedOptions, child.props);
|
|
42
|
+
}
|
|
43
|
+
else if ((0, utils_1.isChildOfType)(child, StackHeaderLeft_1.StackHeaderLeft)) {
|
|
44
|
+
updatedOptions = (0, StackHeaderLeft_1.appendStackHeaderLeftPropsToOptions)(updatedOptions, child.props);
|
|
45
|
+
}
|
|
46
|
+
else if ((0, utils_1.isChildOfType)(child, StackHeaderRight_1.StackHeaderRight)) {
|
|
47
|
+
updatedOptions = (0, StackHeaderRight_1.appendStackHeaderRightPropsToOptions)(updatedOptions, child.props);
|
|
48
|
+
}
|
|
49
|
+
else if ((0, utils_1.isChildOfType)(child, StackHeaderBackButton_1.StackHeaderBackButton)) {
|
|
50
|
+
updatedOptions = (0, StackHeaderBackButton_1.appendStackHeaderBackButtonPropsToOptions)(updatedOptions, child.props);
|
|
51
|
+
}
|
|
52
|
+
else if ((0, utils_1.isChildOfType)(child, StackHeaderSearchBar_1.StackHeaderSearchBar)) {
|
|
53
|
+
updatedOptions = (0, StackHeaderSearchBar_1.appendStackHeaderSearchBarPropsToOptions)(updatedOptions, child.props);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
console.warn(`Warning: Unknown child element passed to Stack.Header: ${child.type.name ?? child.type}`);
|
|
57
|
+
}
|
|
58
|
+
return updatedOptions;
|
|
59
|
+
}
|
|
60
|
+
react_1.Children.forEach(props.children, (child) => {
|
|
61
|
+
if ((0, react_1.isValidElement)(child)) {
|
|
62
|
+
updatedOptions = appendChildOptions(child, updatedOptions);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
return updatedOptions;
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=StackHeaderComponent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderComponent.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderComponent.tsx"],"names":[],"mappings":";;AAkCA,oDAEC;AAED,0EAwDC;AA7FD,iCAAiE;AACjE,+CAA2E;AAG3E,mEAGiC;AACjC,uDAAyF;AACzF,yDAA4F;AAC5F,iEAGgC;AAChC,yDAA4F;AAC5F,mCAAwC;AAkBxC,SAAgB,oBAAoB,CAAC,KAAuB;IAC1D,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,+BAA+B,CAC7C,OAAqC,EACrC,KAAuB;IAEvB,MAAM,cAAc,GAAG,yBAAU,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACvD,MAAM,mBAAmB,GAAG,yBAAU,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAEjE,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;QACjB,OAAO,EAAE,GAAG,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC;IAC5C,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;QAClB,OAAO,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IACtD,CAAC;IAED,IAAI,cAAc,GAAiC;QACjD,GAAG,OAAO;QACV,WAAW,EAAE,CAAC,KAAK,CAAC,MAAM;QAC1B,gBAAgB,EAAE,KAAK,CAAC,UAAU;QAClC,WAAW,EAAE;YACX,eAAe,EAAE,cAAc,EAAE,eAAqC;SACvE;QACD,gBAAgB,EAAE;YAChB,eAAe,EAAE,mBAAmB,EAAE,eAAqC;SAC5E;QACD,mBAAmB,EAAE,cAAc,EAAE,WAAW,KAAK,aAAa;QAClE,6BAA6B,EAAE,mBAAmB,EAAE,WAAW,KAAK,aAAa;KAClF,CAAC;IAEF,SAAS,kBAAkB,CAAC,KAAyB,EAAE,OAAqC;QAC1F,IAAI,cAAc,GAAG,OAAO,CAAC;QAC7B,IAAI,IAAA,qBAAa,EAAC,KAAK,EAAE,mCAAgB,CAAC,EAAE,CAAC;YAC3C,cAAc,GAAG,IAAA,uDAAoC,EAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACrF,CAAC;aAAM,IAAI,IAAA,qBAAa,EAAC,KAAK,EAAE,iCAAe,CAAC,EAAE,CAAC;YACjD,cAAc,GAAG,IAAA,qDAAmC,EAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACpF,CAAC;aAAM,IAAI,IAAA,qBAAa,EAAC,KAAK,EAAE,mCAAgB,CAAC,EAAE,CAAC;YAClD,cAAc,GAAG,IAAA,uDAAoC,EAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACrF,CAAC;aAAM,IAAI,IAAA,qBAAa,EAAC,KAAK,EAAE,6CAAqB,CAAC,EAAE,CAAC;YACvD,cAAc,GAAG,IAAA,iEAAyC,EAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1F,CAAC;aAAM,IAAI,IAAA,qBAAa,EAAC,KAAK,EAAE,2CAAoB,CAAC,EAAE,CAAC;YACtD,cAAc,GAAG,IAAA,+DAAwC,EAAC,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACzF,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CACV,0DAA2D,KAAK,CAAC,IAAyB,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,EAAE,CAChH,CAAC;QACJ,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,gBAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;QACzC,IAAI,IAAA,sBAAc,EAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,cAAc,GAAG,kBAAkB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,cAAc,CAAC;AACxB,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport { Children, isValidElement, type ReactNode } from 'react';\nimport { StyleSheet, type ColorValue, type StyleProp } from 'react-native';\nimport type { ScreenStackHeaderConfigProps } from 'react-native-screens';\n\nimport {\n appendStackHeaderBackButtonPropsToOptions,\n StackHeaderBackButton,\n} from './StackHeaderBackButton';\nimport { StackHeaderLeft, appendStackHeaderLeftPropsToOptions } from './StackHeaderLeft';\nimport { StackHeaderRight, appendStackHeaderRightPropsToOptions } from './StackHeaderRight';\nimport {\n appendStackHeaderSearchBarPropsToOptions,\n StackHeaderSearchBar,\n} from './StackHeaderSearchBar';\nimport { appendStackHeaderTitlePropsToOptions, StackHeaderTitle } from './StackHeaderTitle';\nimport { isChildOfType } from './utils';\n\nexport interface StackHeaderProps {\n children?: ReactNode;\n hidden?: boolean;\n asChild?: boolean;\n blurEffect?: ScreenStackHeaderConfigProps['blurEffect'];\n style?: StyleProp<{\n color?: ColorValue; // tintColor from ReactNavigation\n backgroundColor?: ScreenStackHeaderConfigProps['backgroundColor'];\n shadowColor?: undefined | 'transparent';\n }>;\n largeStyle?: StyleProp<{\n backgroundColor?: ScreenStackHeaderConfigProps['largeTitleBackgroundColor'];\n shadowColor?: undefined | 'transparent';\n }>;\n}\n\nexport function StackHeaderComponent(props: StackHeaderProps) {\n return null;\n}\n\nexport function appendStackHeaderPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderProps\n): NativeStackNavigationOptions {\n const flattenedStyle = StyleSheet.flatten(props.style);\n const flattenedLargeStyle = StyleSheet.flatten(props.largeStyle);\n\n if (props.hidden) {\n return { ...options, headerShown: false };\n }\n\n if (props.asChild) {\n return { ...options, header: () => props.children };\n }\n\n let updatedOptions: NativeStackNavigationOptions = {\n ...options,\n headerShown: !props.hidden,\n headerBlurEffect: props.blurEffect,\n headerStyle: {\n backgroundColor: flattenedStyle?.backgroundColor as string | undefined,\n },\n headerLargeStyle: {\n backgroundColor: flattenedLargeStyle?.backgroundColor as string | undefined,\n },\n headerShadowVisible: flattenedStyle?.shadowColor !== 'transparent',\n headerLargeTitleShadowVisible: flattenedLargeStyle?.shadowColor !== 'transparent',\n };\n\n function appendChildOptions(child: React.ReactElement, options: NativeStackNavigationOptions) {\n let updatedOptions = options;\n if (isChildOfType(child, StackHeaderTitle)) {\n updatedOptions = appendStackHeaderTitlePropsToOptions(updatedOptions, child.props);\n } else if (isChildOfType(child, StackHeaderLeft)) {\n updatedOptions = appendStackHeaderLeftPropsToOptions(updatedOptions, child.props);\n } else if (isChildOfType(child, StackHeaderRight)) {\n updatedOptions = appendStackHeaderRightPropsToOptions(updatedOptions, child.props);\n } else if (isChildOfType(child, StackHeaderBackButton)) {\n updatedOptions = appendStackHeaderBackButtonPropsToOptions(updatedOptions, child.props);\n } else if (isChildOfType(child, StackHeaderSearchBar)) {\n updatedOptions = appendStackHeaderSearchBarPropsToOptions(updatedOptions, child.props);\n } else {\n console.warn(\n `Warning: Unknown child element passed to Stack.Header: ${(child.type as { name: string }).name ?? child.type}`\n );\n }\n return updatedOptions;\n }\n\n Children.forEach(props.children, (child) => {\n if (isValidElement(child)) {\n updatedOptions = appendChildOptions(child, updatedOptions);\n }\n });\n\n return updatedOptions;\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import type { ReactNode } from 'react';
|
|
3
|
+
export interface StackHeaderLeftProps {
|
|
4
|
+
children?: ReactNode;
|
|
5
|
+
asChild?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function StackHeaderLeft(props: StackHeaderLeftProps): null;
|
|
8
|
+
export declare function appendStackHeaderLeftPropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderLeftProps): NativeStackNavigationOptions;
|
|
9
|
+
//# sourceMappingURL=StackHeaderLeft.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderLeft.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderLeft.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,oBAAoB,QAE1D;AAED,wBAAgB,mCAAmC,CACjD,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,oBAAoB,GAC1B,4BAA4B,CAS9B"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderLeft = StackHeaderLeft;
|
|
4
|
+
exports.appendStackHeaderLeftPropsToOptions = appendStackHeaderLeftPropsToOptions;
|
|
5
|
+
function StackHeaderLeft(props) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
function appendStackHeaderLeftPropsToOptions(options, props) {
|
|
9
|
+
if (!props.asChild) {
|
|
10
|
+
return options;
|
|
11
|
+
}
|
|
12
|
+
return {
|
|
13
|
+
...options,
|
|
14
|
+
headerLeft: () => props.children,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=StackHeaderLeft.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderLeft.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderLeft.tsx"],"names":[],"mappings":";;AAQA,0CAEC;AAED,kFAYC;AAhBD,SAAgB,eAAe,CAAC,KAA2B;IACzD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,mCAAmC,CACjD,OAAqC,EACrC,KAA2B;IAE3B,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnB,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,OAAO;QACL,GAAG,OAAO;QACV,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ;KACjC,CAAC;AACJ,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport type { ReactNode } from 'react';\n\nexport interface StackHeaderLeftProps {\n children?: ReactNode;\n asChild?: boolean;\n}\n\nexport function StackHeaderLeft(props: StackHeaderLeftProps) {\n return null;\n}\n\nexport function appendStackHeaderLeftPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderLeftProps\n): NativeStackNavigationOptions {\n if (!props.asChild) {\n return options;\n }\n\n return {\n ...options,\n headerLeft: () => props.children,\n };\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import type { ReactNode } from 'react';
|
|
3
|
+
export interface StackHeaderRightProps {
|
|
4
|
+
children?: ReactNode;
|
|
5
|
+
asChild?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function StackHeaderRight(props: StackHeaderRightProps): null;
|
|
8
|
+
export declare function appendStackHeaderRightPropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderRightProps): NativeStackNavigationOptions;
|
|
9
|
+
//# sourceMappingURL=StackHeaderRight.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderRight.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderRight.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,QAE5D;AAED,wBAAgB,oCAAoC,CAClD,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,qBAAqB,GAC3B,4BAA4B,CAS9B"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderRight = StackHeaderRight;
|
|
4
|
+
exports.appendStackHeaderRightPropsToOptions = appendStackHeaderRightPropsToOptions;
|
|
5
|
+
function StackHeaderRight(props) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
function appendStackHeaderRightPropsToOptions(options, props) {
|
|
9
|
+
if (!props.asChild) {
|
|
10
|
+
return options;
|
|
11
|
+
}
|
|
12
|
+
return {
|
|
13
|
+
...options,
|
|
14
|
+
headerRight: () => props.children,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=StackHeaderRight.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderRight.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderRight.tsx"],"names":[],"mappings":";;AAQA,4CAEC;AAED,oFAYC;AAhBD,SAAgB,gBAAgB,CAAC,KAA4B;IAC3D,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,oCAAoC,CAClD,OAAqC,EACrC,KAA4B;IAE5B,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnB,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,OAAO;QACL,GAAG,OAAO;QACV,WAAW,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ;KAClC,CAAC;AACJ,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport type { ReactNode } from 'react';\n\nexport interface StackHeaderRightProps {\n children?: ReactNode;\n asChild?: boolean;\n}\n\nexport function StackHeaderRight(props: StackHeaderRightProps) {\n return null;\n}\n\nexport function appendStackHeaderRightPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderRightProps\n): NativeStackNavigationOptions {\n if (!props.asChild) {\n return options;\n }\n\n return {\n ...options,\n headerRight: () => props.children,\n };\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import type { SearchBarProps } from 'react-native-screens';
|
|
3
|
+
export interface StackHeaderSearchBarProps extends SearchBarProps {
|
|
4
|
+
}
|
|
5
|
+
export declare function StackHeaderSearchBar(props: StackHeaderSearchBarProps): null;
|
|
6
|
+
export declare function appendStackHeaderSearchBarPropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderSearchBarProps): NativeStackNavigationOptions;
|
|
7
|
+
//# sourceMappingURL=StackHeaderSearchBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderSearchBar.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderSearchBar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,WAAW,yBAA0B,SAAQ,cAAc;CAAG;AAEpE,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,QAEpE;AAED,wBAAgB,wCAAwC,CACtD,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,yBAAyB,GAC/B,4BAA4B,CAO9B"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderSearchBar = StackHeaderSearchBar;
|
|
4
|
+
exports.appendStackHeaderSearchBarPropsToOptions = appendStackHeaderSearchBarPropsToOptions;
|
|
5
|
+
function StackHeaderSearchBar(props) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
function appendStackHeaderSearchBarPropsToOptions(options, props) {
|
|
9
|
+
return {
|
|
10
|
+
...options,
|
|
11
|
+
headerSearchBarOptions: {
|
|
12
|
+
...props,
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=StackHeaderSearchBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderSearchBar.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderSearchBar.tsx"],"names":[],"mappings":";;AAKA,oDAEC;AAED,4FAUC;AAdD,SAAgB,oBAAoB,CAAC,KAAgC;IACnE,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,wCAAwC,CACtD,OAAqC,EACrC,KAAgC;IAEhC,OAAO;QACL,GAAG,OAAO;QACV,sBAAsB,EAAE;YACtB,GAAG,KAAK;SACT;KACF,CAAC;AACJ,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport type { SearchBarProps } from 'react-native-screens';\n\nexport interface StackHeaderSearchBarProps extends SearchBarProps {}\n\nexport function StackHeaderSearchBar(props: StackHeaderSearchBarProps) {\n return null;\n}\n\nexport function appendStackHeaderSearchBarPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderSearchBarProps\n): NativeStackNavigationOptions {\n return {\n ...options,\n headerSearchBarOptions: {\n ...props,\n },\n };\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import { type StyleProp, type TextStyle } from 'react-native';
|
|
3
|
+
export type StackHeaderTitleProps = {
|
|
4
|
+
children?: string;
|
|
5
|
+
style?: StyleProp<{
|
|
6
|
+
fontFamily?: TextStyle['fontFamily'];
|
|
7
|
+
fontSize?: TextStyle['fontSize'];
|
|
8
|
+
fontWeight?: Exclude<TextStyle['fontWeight'], number>;
|
|
9
|
+
color?: string;
|
|
10
|
+
textAlign?: 'left' | 'center';
|
|
11
|
+
}>;
|
|
12
|
+
largeStyle?: StyleProp<{
|
|
13
|
+
fontFamily?: TextStyle['fontFamily'];
|
|
14
|
+
fontSize?: TextStyle['fontSize'];
|
|
15
|
+
fontWeight?: Exclude<TextStyle['fontWeight'], number>;
|
|
16
|
+
color?: string;
|
|
17
|
+
}>;
|
|
18
|
+
large?: boolean;
|
|
19
|
+
};
|
|
20
|
+
export declare function StackHeaderTitle(props: StackHeaderTitleProps): null;
|
|
21
|
+
export declare function appendStackHeaderTitlePropsToOptions(options: NativeStackNavigationOptions, props: StackHeaderTitleProps): NativeStackNavigationOptions;
|
|
22
|
+
//# sourceMappingURL=StackHeaderTitle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderTitle.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderTitle.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EAAc,KAAK,SAAS,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAE1E,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,SAAS,CAAC;QAChB,UAAU,CAAC,EAAE,SAAS,CAAC,YAAY,CAAC,CAAC;QACrC,QAAQ,CAAC,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;QACjC,UAAU,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC,CAAC;QAGtD,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;KAC/B,CAAC,CAAC;IACH,UAAU,CAAC,EAAE,SAAS,CAAC;QACrB,UAAU,CAAC,EAAE,SAAS,CAAC,YAAY,CAAC,CAAC;QACrC,QAAQ,CAAC,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;QACjC,UAAU,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC,CAAC;QAGtD,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC,CAAC;IACH,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,QAE5D;AAED,wBAAgB,oCAAoC,CAClD,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,qBAAqB,GAC3B,4BAA4B,CA0B9B"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StackHeaderTitle = StackHeaderTitle;
|
|
4
|
+
exports.appendStackHeaderTitlePropsToOptions = appendStackHeaderTitlePropsToOptions;
|
|
5
|
+
const react_native_1 = require("react-native");
|
|
6
|
+
function StackHeaderTitle(props) {
|
|
7
|
+
return null;
|
|
8
|
+
}
|
|
9
|
+
function appendStackHeaderTitlePropsToOptions(options, props) {
|
|
10
|
+
const flattenedStyle = react_native_1.StyleSheet.flatten(props.style);
|
|
11
|
+
const flattenedLargeStyle = react_native_1.StyleSheet.flatten(props.largeStyle);
|
|
12
|
+
return {
|
|
13
|
+
...options,
|
|
14
|
+
title: props.children,
|
|
15
|
+
headerLargeTitle: props.large,
|
|
16
|
+
headerTitleAlign: flattenedStyle?.textAlign,
|
|
17
|
+
headerTitleStyle: {
|
|
18
|
+
...flattenedStyle,
|
|
19
|
+
...(flattenedStyle?.fontWeight
|
|
20
|
+
? {
|
|
21
|
+
fontWeight: convertFontWeightToStringFontWeight(flattenedStyle?.fontWeight),
|
|
22
|
+
}
|
|
23
|
+
: {}),
|
|
24
|
+
},
|
|
25
|
+
headerLargeTitleStyle: {
|
|
26
|
+
...flattenedLargeStyle,
|
|
27
|
+
...(flattenedLargeStyle?.fontWeight
|
|
28
|
+
? {
|
|
29
|
+
fontWeight: convertFontWeightToStringFontWeight(flattenedLargeStyle?.fontWeight),
|
|
30
|
+
}
|
|
31
|
+
: {}),
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
function convertFontWeightToStringFontWeight(fontWeight) {
|
|
36
|
+
if (typeof fontWeight === 'number') {
|
|
37
|
+
return String(fontWeight);
|
|
38
|
+
}
|
|
39
|
+
return fontWeight;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=StackHeaderTitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackHeaderTitle.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackHeaderTitle.tsx"],"names":[],"mappings":";;AAyBA,4CAEC;AAED,oFA6BC;AAzDD,+CAA0E;AAwB1E,SAAgB,gBAAgB,CAAC,KAA4B;IAC3D,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,oCAAoC,CAClD,OAAqC,EACrC,KAA4B;IAE5B,MAAM,cAAc,GAAG,yBAAU,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACvD,MAAM,mBAAmB,GAAG,yBAAU,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAEjE,OAAO;QACL,GAAG,OAAO;QACV,KAAK,EAAE,KAAK,CAAC,QAAQ;QACrB,gBAAgB,EAAE,KAAK,CAAC,KAAK;QAC7B,gBAAgB,EAAE,cAAc,EAAE,SAAS;QAC3C,gBAAgB,EAAE;YAChB,GAAG,cAAc;YACjB,GAAG,CAAC,cAAc,EAAE,UAAU;gBAC5B,CAAC,CAAC;oBACE,UAAU,EAAE,mCAAmC,CAAC,cAAc,EAAE,UAAU,CAAC;iBAC5E;gBACH,CAAC,CAAC,EAAE,CAAC;SACR;QACD,qBAAqB,EAAE;YACrB,GAAG,mBAAmB;YACtB,GAAG,CAAC,mBAAmB,EAAE,UAAU;gBACjC,CAAC,CAAC;oBACE,UAAU,EAAE,mCAAmC,CAAC,mBAAmB,EAAE,UAAU,CAAC;iBACjF;gBACH,CAAC,CAAC,EAAE,CAAC;SACR;KACF,CAAC;AACJ,CAAC;AAED,SAAS,mCAAmC,CAC1C,UAAmC;IAEnC,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE,CAAC;QACnC,OAAO,MAAM,CAAC,UAAU,CAAkD,CAAC;IAC7E,CAAC;IACD,OAAO,UAAU,CAAC;AACpB,CAAC","sourcesContent":["import { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport { StyleSheet, type StyleProp, type TextStyle } from 'react-native';\n\nexport type StackHeaderTitleProps = {\n children?: string;\n style?: StyleProp<{\n fontFamily?: TextStyle['fontFamily'];\n fontSize?: TextStyle['fontSize'];\n fontWeight?: Exclude<TextStyle['fontWeight'], number>;\n // TODO(@ubax): This should be ColorValue, but react-navigation types\n // currently only accept string for color props. In RN v8 we can change this to ColorValue.\n color?: string;\n textAlign?: 'left' | 'center';\n }>;\n largeStyle?: StyleProp<{\n fontFamily?: TextStyle['fontFamily'];\n fontSize?: TextStyle['fontSize'];\n fontWeight?: Exclude<TextStyle['fontWeight'], number>;\n // TODO(@ubax): This should be ColorValue, but react-navigation types\n // currently only accept string for color props. In RN v8 we can change this to ColorValue.\n color?: string;\n }>;\n large?: boolean;\n};\n\nexport function StackHeaderTitle(props: StackHeaderTitleProps) {\n return null;\n}\n\nexport function appendStackHeaderTitlePropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackHeaderTitleProps\n): NativeStackNavigationOptions {\n const flattenedStyle = StyleSheet.flatten(props.style);\n const flattenedLargeStyle = StyleSheet.flatten(props.largeStyle);\n\n return {\n ...options,\n title: props.children,\n headerLargeTitle: props.large,\n headerTitleAlign: flattenedStyle?.textAlign,\n headerTitleStyle: {\n ...flattenedStyle,\n ...(flattenedStyle?.fontWeight\n ? {\n fontWeight: convertFontWeightToStringFontWeight(flattenedStyle?.fontWeight),\n }\n : {}),\n },\n headerLargeTitleStyle: {\n ...flattenedLargeStyle,\n ...(flattenedLargeStyle?.fontWeight\n ? {\n fontWeight: convertFontWeightToStringFontWeight(flattenedLargeStyle?.fontWeight),\n }\n : {}),\n },\n };\n}\n\nfunction convertFontWeightToStringFontWeight(\n fontWeight: TextStyle['fontWeight']\n): Exclude<TextStyle['fontWeight'], number> | undefined {\n if (typeof fontWeight === 'number') {\n return String(fontWeight) as `${Extract<TextStyle['fontWeight'], number>}`;\n }\n return fontWeight;\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { NativeStackNavigationOptions } from '@react-navigation/native-stack';
|
|
2
|
+
import { type PropsWithChildren } from 'react';
|
|
3
|
+
export interface StackScreenProps extends PropsWithChildren {
|
|
4
|
+
name?: string;
|
|
5
|
+
options?: NativeStackNavigationOptions;
|
|
6
|
+
}
|
|
7
|
+
export declare function StackScreen({ children, options, ...rest }: StackScreenProps): import("react").JSX.Element;
|
|
8
|
+
export declare function appendScreenStackPropsToOptions(options: NativeStackNavigationOptions, props: StackScreenProps): NativeStackNavigationOptions;
|
|
9
|
+
//# sourceMappingURL=StackScreen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackScreen.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackScreen.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AAC9E,OAAO,EAAqC,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AASlF,MAAM,WAAW,gBAAiB,SAAQ,iBAAiB;IACzD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,4BAA4B,CAAC;CACxC;AAED,wBAAgB,WAAW,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,EAAE,gBAAgB,+BAU3E;AAED,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,4BAA4B,EACrC,KAAK,EAAE,gBAAgB,GACtB,4BAA4B,CAkB9B"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use client';
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.StackScreen = StackScreen;
|
|
5
|
+
exports.appendScreenStackPropsToOptions = appendScreenStackPropsToOptions;
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
const StackHeaderComponent_1 = require("./StackHeaderComponent");
|
|
8
|
+
const Screen_1 = require("../../views/Screen");
|
|
9
|
+
function StackScreen({ children, options, ...rest }) {
|
|
10
|
+
// This component will only render when used inside a page.
|
|
11
|
+
const updatedOptions = (0, react_1.useMemo)(() => appendScreenStackPropsToOptions(options ?? {}, {
|
|
12
|
+
children,
|
|
13
|
+
}), [options, children]);
|
|
14
|
+
return <Screen_1.Screen {...rest} options={updatedOptions}/>;
|
|
15
|
+
}
|
|
16
|
+
function appendScreenStackPropsToOptions(options, props) {
|
|
17
|
+
let updatedOptions = { ...options, ...props.options };
|
|
18
|
+
function appendChildOptions(child, options) {
|
|
19
|
+
if (child.type === StackHeaderComponent_1.StackHeaderComponent) {
|
|
20
|
+
updatedOptions = (0, StackHeaderComponent_1.appendStackHeaderPropsToOptions)(options, child.props);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
console.warn(`Warning: Unknown child element passed to Stack.Screen: ${child.type.name ?? child.type}`);
|
|
24
|
+
}
|
|
25
|
+
return updatedOptions;
|
|
26
|
+
}
|
|
27
|
+
react_1.Children.forEach(props.children, (child) => {
|
|
28
|
+
if ((0, react_1.isValidElement)(child)) {
|
|
29
|
+
updatedOptions = appendChildOptions(child, updatedOptions);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
return updatedOptions;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=StackScreen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackScreen.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/StackScreen.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;AAgBb,kCAUC;AAED,0EAqBC;AA/CD,iCAAkF;AAElF,iEAIgC;AAChC,+CAA4C;AAO5C,SAAgB,WAAW,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,EAAoB;IAC1E,2DAA2D;IAC3D,MAAM,cAAc,GAAG,IAAA,eAAO,EAC5B,GAAG,EAAE,CACH,+BAA+B,CAAC,OAAO,IAAI,EAAE,EAAE;QAC7C,QAAQ;KACT,CAAC,EACJ,CAAC,OAAO,EAAE,QAAQ,CAAC,CACpB,CAAC;IACF,OAAO,CAAC,eAAM,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,cAAc,CAAC,EAAG,CAAC;AACvD,CAAC;AAED,SAAgB,+BAA+B,CAC7C,OAAqC,EACrC,KAAuB;IAEvB,IAAI,cAAc,GAAG,EAAE,GAAG,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC;IACtD,SAAS,kBAAkB,CAAC,KAAyB,EAAE,OAAqC;QAC1F,IAAI,KAAK,CAAC,IAAI,KAAK,2CAAoB,EAAE,CAAC;YACxC,cAAc,GAAG,IAAA,sDAA+B,EAAC,OAAO,EAAE,KAAK,CAAC,KAAyB,CAAC,CAAC;QAC7F,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CACV,0DAA2D,KAAK,CAAC,IAAyB,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,EAAE,CAChH,CAAC;QACJ,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IACD,gBAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;QACzC,IAAI,IAAA,sBAAc,EAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,cAAc,GAAG,kBAAkB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC,CAAC,CAAC;IACH,OAAO,cAAc,CAAC;AACxB,CAAC","sourcesContent":["'use client';\nimport { NativeStackNavigationOptions } from '@react-navigation/native-stack';\nimport { Children, isValidElement, useMemo, type PropsWithChildren } from 'react';\n\nimport {\n StackHeaderComponent,\n appendStackHeaderPropsToOptions,\n type StackHeaderProps,\n} from './StackHeaderComponent';\nimport { Screen } from '../../views/Screen';\n\nexport interface StackScreenProps extends PropsWithChildren {\n name?: string;\n options?: NativeStackNavigationOptions;\n}\n\nexport function StackScreen({ children, options, ...rest }: StackScreenProps) {\n // This component will only render when used inside a page.\n const updatedOptions = useMemo(\n () =>\n appendScreenStackPropsToOptions(options ?? {}, {\n children,\n }),\n [options, children]\n );\n return <Screen {...rest} options={updatedOptions} />;\n}\n\nexport function appendScreenStackPropsToOptions(\n options: NativeStackNavigationOptions,\n props: StackScreenProps\n): NativeStackNavigationOptions {\n let updatedOptions = { ...options, ...props.options };\n function appendChildOptions(child: React.ReactElement, options: NativeStackNavigationOptions) {\n if (child.type === StackHeaderComponent) {\n updatedOptions = appendStackHeaderPropsToOptions(options, child.props as StackHeaderProps);\n } else {\n console.warn(\n `Warning: Unknown child element passed to Stack.Screen: ${(child.type as { name: string }).name ?? child.type}`\n );\n }\n return updatedOptions;\n }\n Children.forEach(props.children, (child) => {\n if (isValidElement(child)) {\n updatedOptions = appendChildOptions(child, updatedOptions);\n }\n });\n return updatedOptions;\n}\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { StackHeaderBackButton, type StackHeaderBackButtonProps } from './StackHeaderBackButton';
|
|
2
|
+
import { StackHeaderComponent, type StackHeaderProps } from './StackHeaderComponent';
|
|
3
|
+
import { StackHeaderLeft, type StackHeaderLeftProps } from './StackHeaderLeft';
|
|
4
|
+
import { StackHeaderRight, type StackHeaderRightProps } from './StackHeaderRight';
|
|
5
|
+
import { StackHeaderSearchBar, type StackHeaderSearchBarProps } from './StackHeaderSearchBar';
|
|
6
|
+
import { StackHeaderTitle, type StackHeaderTitleProps } from './StackHeaderTitle';
|
|
7
|
+
export declare const StackHeader: typeof StackHeaderComponent & {
|
|
8
|
+
Left: typeof StackHeaderLeft;
|
|
9
|
+
Right: typeof StackHeaderRight;
|
|
10
|
+
BackButton: typeof StackHeaderBackButton;
|
|
11
|
+
Title: typeof StackHeaderTitle;
|
|
12
|
+
SearchBar: typeof StackHeaderSearchBar;
|
|
13
|
+
};
|
|
14
|
+
export { StackHeaderBackButton, type StackHeaderBackButtonProps, StackHeaderComponent, type StackHeaderProps, StackHeaderLeft, type StackHeaderLeftProps, StackHeaderRight, type StackHeaderRightProps, StackHeaderSearchBar, type StackHeaderSearchBarProps, StackHeaderTitle, type StackHeaderTitleProps, };
|
|
15
|
+
export { StackScreen, appendScreenStackPropsToOptions, type StackScreenProps } from './StackScreen';
|
|
16
|
+
export { isChildOfType } from './utils';
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,MAAM,yBAAyB,CAAC;AACjG,OAAO,EAAE,oBAAoB,EAAE,KAAK,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,KAAK,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC/E,OAAO,EAAE,gBAAgB,EAAE,KAAK,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAClF,OAAO,EAAE,oBAAoB,EAAE,KAAK,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AAC9F,OAAO,EAAE,gBAAgB,EAAE,KAAK,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAElF,eAAO,MAAM,WAAW;;;;;;CAMtB,CAAC;AAEH,OAAO,EACL,qBAAqB,EACrB,KAAK,0BAA0B,EAC/B,oBAAoB,EACpB,KAAK,gBAAgB,EACrB,eAAe,EACf,KAAK,oBAAoB,EACzB,gBAAgB,EAChB,KAAK,qBAAqB,EAC1B,oBAAoB,EACpB,KAAK,yBAAyB,EAC9B,gBAAgB,EAChB,KAAK,qBAAqB,GAC3B,CAAC;AACF,OAAO,EAAE,WAAW,EAAE,+BAA+B,EAAE,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isChildOfType = exports.appendScreenStackPropsToOptions = exports.StackScreen = exports.StackHeaderTitle = exports.StackHeaderSearchBar = exports.StackHeaderRight = exports.StackHeaderLeft = exports.StackHeaderComponent = exports.StackHeaderBackButton = exports.StackHeader = void 0;
|
|
4
|
+
const StackHeaderBackButton_1 = require("./StackHeaderBackButton");
|
|
5
|
+
Object.defineProperty(exports, "StackHeaderBackButton", { enumerable: true, get: function () { return StackHeaderBackButton_1.StackHeaderBackButton; } });
|
|
6
|
+
const StackHeaderComponent_1 = require("./StackHeaderComponent");
|
|
7
|
+
Object.defineProperty(exports, "StackHeaderComponent", { enumerable: true, get: function () { return StackHeaderComponent_1.StackHeaderComponent; } });
|
|
8
|
+
const StackHeaderLeft_1 = require("./StackHeaderLeft");
|
|
9
|
+
Object.defineProperty(exports, "StackHeaderLeft", { enumerable: true, get: function () { return StackHeaderLeft_1.StackHeaderLeft; } });
|
|
10
|
+
const StackHeaderRight_1 = require("./StackHeaderRight");
|
|
11
|
+
Object.defineProperty(exports, "StackHeaderRight", { enumerable: true, get: function () { return StackHeaderRight_1.StackHeaderRight; } });
|
|
12
|
+
const StackHeaderSearchBar_1 = require("./StackHeaderSearchBar");
|
|
13
|
+
Object.defineProperty(exports, "StackHeaderSearchBar", { enumerable: true, get: function () { return StackHeaderSearchBar_1.StackHeaderSearchBar; } });
|
|
14
|
+
const StackHeaderTitle_1 = require("./StackHeaderTitle");
|
|
15
|
+
Object.defineProperty(exports, "StackHeaderTitle", { enumerable: true, get: function () { return StackHeaderTitle_1.StackHeaderTitle; } });
|
|
16
|
+
exports.StackHeader = Object.assign(StackHeaderComponent_1.StackHeaderComponent, {
|
|
17
|
+
Left: StackHeaderLeft_1.StackHeaderLeft,
|
|
18
|
+
Right: StackHeaderRight_1.StackHeaderRight,
|
|
19
|
+
BackButton: StackHeaderBackButton_1.StackHeaderBackButton,
|
|
20
|
+
Title: StackHeaderTitle_1.StackHeaderTitle,
|
|
21
|
+
SearchBar: StackHeaderSearchBar_1.StackHeaderSearchBar,
|
|
22
|
+
});
|
|
23
|
+
var StackScreen_1 = require("./StackScreen");
|
|
24
|
+
Object.defineProperty(exports, "StackScreen", { enumerable: true, get: function () { return StackScreen_1.StackScreen; } });
|
|
25
|
+
Object.defineProperty(exports, "appendScreenStackPropsToOptions", { enumerable: true, get: function () { return StackScreen_1.appendScreenStackPropsToOptions; } });
|
|
26
|
+
var utils_1 = require("./utils");
|
|
27
|
+
Object.defineProperty(exports, "isChildOfType", { enumerable: true, get: function () { return utils_1.isChildOfType; } });
|
|
28
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/index.tsx"],"names":[],"mappings":";;;AAAA,mEAAiG;AAgB/F,sGAhBO,6CAAqB,OAgBP;AAfvB,iEAAqF;AAiBnF,qGAjBO,2CAAoB,OAiBP;AAhBtB,uDAA+E;AAkB7E,gGAlBO,iCAAe,OAkBP;AAjBjB,yDAAkF;AAmBhF,iGAnBO,mCAAgB,OAmBP;AAlBlB,iEAA8F;AAoB5F,qGApBO,2CAAoB,OAoBP;AAnBtB,yDAAkF;AAqBhF,iGArBO,mCAAgB,OAqBP;AAnBL,QAAA,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,2CAAoB,EAAE;IAC7D,IAAI,EAAE,iCAAe;IACrB,KAAK,EAAE,mCAAgB;IACvB,UAAU,EAAE,6CAAqB;IACjC,KAAK,EAAE,mCAAgB;IACvB,SAAS,EAAE,2CAAoB;CAChC,CAAC,CAAC;AAgBH,6CAAoG;AAA3F,0GAAA,WAAW,OAAA;AAAE,8HAAA,+BAA+B,OAAA;AACrD,iCAAwC;AAA/B,sGAAA,aAAa,OAAA","sourcesContent":["import { StackHeaderBackButton, type StackHeaderBackButtonProps } from './StackHeaderBackButton';\nimport { StackHeaderComponent, type StackHeaderProps } from './StackHeaderComponent';\nimport { StackHeaderLeft, type StackHeaderLeftProps } from './StackHeaderLeft';\nimport { StackHeaderRight, type StackHeaderRightProps } from './StackHeaderRight';\nimport { StackHeaderSearchBar, type StackHeaderSearchBarProps } from './StackHeaderSearchBar';\nimport { StackHeaderTitle, type StackHeaderTitleProps } from './StackHeaderTitle';\n\nexport const StackHeader = Object.assign(StackHeaderComponent, {\n Left: StackHeaderLeft,\n Right: StackHeaderRight,\n BackButton: StackHeaderBackButton,\n Title: StackHeaderTitle,\n SearchBar: StackHeaderSearchBar,\n});\n\nexport {\n StackHeaderBackButton,\n type StackHeaderBackButtonProps,\n StackHeaderComponent,\n type StackHeaderProps,\n StackHeaderLeft,\n type StackHeaderLeftProps,\n StackHeaderRight,\n type StackHeaderRightProps,\n StackHeaderSearchBar,\n type StackHeaderSearchBarProps,\n StackHeaderTitle,\n type StackHeaderTitleProps,\n};\nexport { StackScreen, appendScreenStackPropsToOptions, type StackScreenProps } from './StackScreen';\nexport { isChildOfType } from './utils';\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/layouts/stack-utils/utils.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,YAAY,EAAE,MAAM,OAAO,CAAC;AAE1D,wBAAgB,aAAa,CAAC,MAAM,EAClC,OAAO,EAAE,KAAK,CAAC,SAAS,EACxB,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,GAC/B,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,CAEjC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isChildOfType = isChildOfType;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
function isChildOfType(element, type) {
|
|
6
|
+
return (0, react_1.isValidElement)(element) && element.type === type;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/layouts/stack-utils/utils.tsx"],"names":[],"mappings":";;AAEA,sCAKC;AAPD,iCAA0D;AAE1D,SAAgB,aAAa,CAC3B,OAAwB,EACxB,IAAgC;IAEhC,OAAO,IAAA,sBAAc,EAAC,OAAO,CAAC,IAAI,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC;AAC1D,CAAC","sourcesContent":["import { isValidElement, type ReactElement } from 'react';\n\nexport function isChildOfType<PropsT>(\n element: React.ReactNode,\n type: (props: PropsT) => unknown\n): element is ReactElement<PropsT> {\n return isValidElement(element) && element.type === type;\n}\n"]}
|
|
@@ -66,7 +66,7 @@ function useFilterScreenChildren(children, { isCustomNavigator, contextKey, } =
|
|
|
66
66
|
if (options.hidden === false) {
|
|
67
67
|
screens.push({
|
|
68
68
|
...child.props,
|
|
69
|
-
options
|
|
69
|
+
options,
|
|
70
70
|
});
|
|
71
71
|
}
|
|
72
72
|
else {
|