@common-stack/client-react 0.2.12 → 0.2.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/fill-register-test.js +5 -1
- package/lib/__tests__/fill-register-test.js.map +1 -1
- package/lib/__tests__/integrated-routes.test.js +8 -4
- package/lib/__tests__/integrated-routes.test.js.map +1 -1
- package/lib/__tests__/router-render.test.js +7 -3
- package/lib/__tests__/router-render.test.js.map +1 -1
- package/lib/connector/base-connector.d.ts +5 -4
- package/lib/connector/base-connector.js +20 -17
- package/lib/connector/base-connector.js.map +1 -1
- package/lib/connector/connector.d.ts +3 -0
- package/lib/connector/connector.js +3 -0
- package/lib/connector/connector.js.map +1 -1
- package/lib/connector/connector.native.d.ts +4 -1
- package/lib/connector/connector.native.js +9 -1
- package/lib/connector/connector.native.js.map +1 -1
- package/lib/connector/connector.test.js +5 -1
- package/lib/connector/connector.test.js.map +1 -1
- package/lib/connector/index.js +5 -1
- package/lib/connector/index.js.map +1 -1
- package/lib/index.js +5 -1
- package/lib/index.js.map +1 -1
- package/lib/index.native.js +5 -1
- package/lib/index.native.js.map +1 -1
- package/lib/interfaces/index.js +5 -1
- package/lib/interfaces/index.js.map +1 -1
- package/lib/interfaces/router.d.ts +4 -1
- package/lib/inversify/InversifyContext.js +5 -1
- package/lib/inversify/InversifyContext.js.map +1 -1
- package/lib/inversify/index.js +5 -1
- package/lib/inversify/index.js.map +1 -1
- package/lib/plugin-area/__tests__/higher-order-component-util.test.js +10 -6
- package/lib/plugin-area/__tests__/higher-order-component-util.test.js.map +1 -1
- package/lib/plugin-area/__tests__/plugin-api.test.js +9 -9
- package/lib/plugin-area/__tests__/plugin-api.test.js.map +1 -1
- package/lib/plugin-area/base-plugin-area.js +11 -7
- package/lib/plugin-area/base-plugin-area.js.map +1 -1
- package/lib/plugin-area/higher-order-component-util.js +1 -1
- package/lib/plugin-area/higher-order-component-util.js.map +1 -1
- package/lib/plugin-area/index.d.ts +1 -0
- package/lib/plugin-area/index.js +5 -1
- package/lib/plugin-area/index.js.map +1 -1
- package/lib/plugin-area/index.native.d.ts +1 -0
- package/lib/plugin-area/index.native.js +5 -1
- package/lib/plugin-area/index.native.js.map +1 -1
- package/lib/plugin-area/plugin-api.js +4 -4
- package/lib/plugin-area/plugin-api.js.map +1 -1
- package/lib/plugin-area/plugin-context.js +6 -2
- package/lib/plugin-area/plugin-context.js.map +1 -1
- package/lib/route/__tests__/admin-new-routes.test.js +8 -4
- package/lib/route/__tests__/admin-new-routes.test.js.map +1 -1
- package/lib/route/__tests__/getFlatMenus.test.js +3 -3
- package/lib/route/__tests__/getFlatMenus.test.js.map +1 -1
- package/lib/route/__tests__/render-routes-config.test.js +1 -1
- package/lib/route/__tests__/render-routes-config.test.js.map +1 -1
- package/lib/route/get-routes.js +2 -2
- package/lib/route/get-routes.js.map +1 -1
- package/lib/route/get-routes.test.js +3 -3
- package/lib/route/get-routes.test.js.map +1 -1
- package/lib/route/index.d.ts +1 -0
- package/lib/route/index.js +6 -1
- package/lib/route/index.js.map +1 -1
- package/lib/route/index.native.js +5 -1
- package/lib/route/index.native.js.map +1 -1
- package/lib/route/old/__tests__/config-sidebar-menu.test.js +3 -3
- package/lib/route/old/__tests__/config-sidebar-menu.test.js.map +1 -1
- package/lib/route/old/get-routes-notused.js +1 -1
- package/lib/route/old/get-routes-notused.js.map +1 -1
- package/lib/route/old/render.d.ts +1 -0
- package/lib/route/old/render.js +6 -3
- package/lib/route/old/render.js.map +1 -1
- package/lib/route/react-navigation/get-navigation-utils.d.ts +3 -0
- package/lib/route/react-navigation/get-navigation-utils.js +78 -0
- package/lib/route/react-navigation/get-navigation-utils.js.map +1 -0
- package/lib/route/react-navigation/get-navigation-utils.test.d.ts +1 -0
- package/lib/route/react-navigation/get-navigation-utils.test.js +101 -0
- package/lib/route/react-navigation/get-navigation-utils.test.js.map +1 -0
- package/lib/route/react-navigation/index.d.ts +2 -0
- package/lib/route/react-navigation/index.js +19 -0
- package/lib/route/react-navigation/index.js.map +1 -0
- package/lib/route/{react-navigation-render.d.ts → react-navigation/react-navigation-orig.d.ts} +0 -0
- package/lib/route/react-navigation/react-navigation-orig.js +44 -0
- package/lib/route/react-navigation/react-navigation-orig.js.map +1 -0
- package/lib/route/react-navigation/react-navigation-orig.test.d.ts +0 -0
- package/lib/route/react-navigation/react-navigation-orig.test.js +91 -0
- package/lib/route/react-navigation/react-navigation-orig.test.js.map +1 -0
- package/lib/route/react-navigation/react-navigation-render.d.ts +2 -0
- package/lib/route/react-navigation/react-navigation-render.js +43 -0
- package/lib/route/react-navigation/react-navigation-render.js.map +1 -0
- package/lib/route/react-navigation/react-navigation-render.test.d.ts +1 -0
- package/lib/route/react-navigation/react-navigation-render.test.js +101 -0
- package/lib/route/react-navigation/react-navigation-render.test.js.map +1 -0
- package/lib/route/react-navigation/routes.d.ts +11 -0
- package/lib/route/react-navigation/routes.js +3 -0
- package/lib/route/react-navigation/routes.js.map +1 -0
- package/lib/route/react-navigation/types.d.ts +28 -0
- package/lib/route/react-navigation/types.js +6 -0
- package/lib/route/react-navigation/types.js.map +1 -0
- package/lib/route/render-routes.d.ts +1 -0
- package/lib/route/render-routes.js +8 -4
- package/lib/route/render-routes.js.map +1 -1
- package/lib/route/render-routes.native.d.ts +1 -0
- package/lib/route/render-routes.native.js +8 -4
- package/lib/route/render-routes.native.js.map +1 -1
- package/lib/route/render-routes.test.js +23 -23
- package/lib/route/render-routes.test.js.map +1 -1
- package/lib/route-based-plugin-area/__tests__/higher-order-component-util.test.js +10 -6
- package/lib/route-based-plugin-area/__tests__/higher-order-component-util.test.js.map +1 -1
- package/lib/route-based-plugin-area/__tests__/plugin-api.test.js +9 -9
- package/lib/route-based-plugin-area/__tests__/plugin-api.test.js.map +1 -1
- package/lib/route-based-plugin-area/higher-order-component-util.js +1 -1
- package/lib/route-based-plugin-area/higher-order-component-util.js.map +1 -1
- package/lib/route-based-plugin-area/index.js +5 -1
- package/lib/route-based-plugin-area/index.js.map +1 -1
- package/lib/route-based-plugin-area/plugin-api.js +4 -4
- package/lib/route-based-plugin-area/plugin-api.js.map +1 -1
- package/lib/route-based-plugin-area/plugin-context.js +6 -2
- package/lib/route-based-plugin-area/plugin-context.js.map +1 -1
- package/lib/route-based-plugin-area/route-based-plugin-area.js +11 -7
- package/lib/route-based-plugin-area/route-based-plugin-area.js.map +1 -1
- package/lib/router-factory/index.js +5 -1
- package/lib/router-factory/index.js.map +1 -1
- package/lib/router-factory/index.native.js +5 -1
- package/lib/router-factory/index.native.js.map +1 -1
- package/lib/utils/index.js +5 -1
- package/lib/utils/index.js.map +1 -1
- package/lib/utils/sort-keys.test.js +1 -1
- package/lib/utils/sort-keys.test.js.map +1 -1
- package/package.json +20 -23
- package/lib/route/react-navigation-render.js +0 -1
- package/lib/route/react-navigation-render.js.map +0 -1
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.getNavigation = exports.getSortedNavigations = void 0;
|
|
15
|
+
const interfaces_1 = require("../../interfaces");
|
|
16
|
+
const utils_1 = require("../../utils");
|
|
17
|
+
const getSortedNavigations = (path, routeData) => {
|
|
18
|
+
const sortedRoutes = (0, utils_1.sortKeys)(routeData);
|
|
19
|
+
return getNavigation(path, sortedRoutes);
|
|
20
|
+
};
|
|
21
|
+
exports.getSortedNavigations = getSortedNavigations;
|
|
22
|
+
function getNavigation(path, routeData) {
|
|
23
|
+
if (!path.startsWith('/')) {
|
|
24
|
+
throw new Error('Invalid path!');
|
|
25
|
+
}
|
|
26
|
+
let searchPath = path;
|
|
27
|
+
if (path[path.length - 1] !== '/') {
|
|
28
|
+
searchPath = path + '/';
|
|
29
|
+
}
|
|
30
|
+
const childrens = Object.keys(routeData).filter(menuPath => {
|
|
31
|
+
return menuPath.indexOf(searchPath) === 0 || menuPath === path;
|
|
32
|
+
});
|
|
33
|
+
const mappedMenuPaths = childrens.map(mPath => {
|
|
34
|
+
return Object.assign({ route: mPath, position: interfaces_1.IMenuPosition.MIDDLE }, routeData[mPath]);
|
|
35
|
+
});
|
|
36
|
+
const root = {
|
|
37
|
+
// just to satisfy types added following
|
|
38
|
+
// TOOD need to correct types so we don't have to enter them.
|
|
39
|
+
name: 'root',
|
|
40
|
+
position: interfaces_1.IMenuPosition.LOGO,
|
|
41
|
+
};
|
|
42
|
+
mappedMenuPaths.forEach(routeItem => {
|
|
43
|
+
const children = routeItem.route.split('/');
|
|
44
|
+
children.shift();
|
|
45
|
+
// if the route is `/` then add this correction.
|
|
46
|
+
if (routeItem.path === '/') {
|
|
47
|
+
children.shift();
|
|
48
|
+
children.push('/');
|
|
49
|
+
}
|
|
50
|
+
const depth = children.length;
|
|
51
|
+
let lastNode = root;
|
|
52
|
+
for (let i = 0; i < depth; i++) {
|
|
53
|
+
const lastIndex = (lastNode.children || []).findIndex(item => {
|
|
54
|
+
var _a;
|
|
55
|
+
const routePath = `${item._pathPrefix}${item.path}`;
|
|
56
|
+
if (routeItem.route.startsWith(routePath)) {
|
|
57
|
+
// only if the parent path has `exact: false` allows to nested
|
|
58
|
+
return routeItem.route[routePath.length] === '/' && ((_a = routeData[routePath]) === null || _a === void 0 ? void 0 : _a.exact) === false;
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
if (lastIndex === -1) {
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
lastNode = lastNode.children[lastIndex];
|
|
65
|
+
const lastNodePath = `${lastNode._pathPrefix}${lastNode.path}`;
|
|
66
|
+
lastNode.exact = routeData[lastNodePath].hasOwnProperty('exact') ? routeData[lastNodePath].exact : false;
|
|
67
|
+
}
|
|
68
|
+
if (!lastNode.children) {
|
|
69
|
+
lastNode.children = [];
|
|
70
|
+
}
|
|
71
|
+
const { route: ignore, auth } = routeItem, rest = __rest(routeItem, ["route", "auth"]);
|
|
72
|
+
const pathParams = (0, utils_1.formatSlash)(routeItem.route);
|
|
73
|
+
lastNode.children.push(Object.assign(Object.assign(Object.assign({}, rest), pathParams), { exact: routeData[routeItem.route].hasOwnProperty('exact') ? routeData[routeItem.route].exact : true }));
|
|
74
|
+
});
|
|
75
|
+
return root.children;
|
|
76
|
+
}
|
|
77
|
+
exports.getNavigation = getNavigation;
|
|
78
|
+
//# sourceMappingURL=get-navigation-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-navigation-utils.js","sourceRoot":"","sources":["../../../src/route/react-navigation/get-navigation-utils.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const get_navigation_utils_1 = require("./get-navigation-utils");
|
|
4
|
+
const stack_1 = require("@react-navigation/stack");
|
|
5
|
+
const bottom_tabs_1 = require("@react-navigation/bottom-tabs");
|
|
6
|
+
const connector_native_1 = require("../../connector/connector.native");
|
|
7
|
+
const MyComponent = () => { };
|
|
8
|
+
describe('getRoutes utility with basic routes', () => {
|
|
9
|
+
const routerConfig1 = {
|
|
10
|
+
['/']: {
|
|
11
|
+
exact: false,
|
|
12
|
+
container: (0, stack_1.createStackNavigator)(),
|
|
13
|
+
name: 'MainStack',
|
|
14
|
+
props: {
|
|
15
|
+
initialRouteName: 'Guest',
|
|
16
|
+
screenOptions: {
|
|
17
|
+
headerShown: false,
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
['//guest']: {
|
|
22
|
+
container: (0, bottom_tabs_1.createBottomTabNavigator)(),
|
|
23
|
+
exact: false,
|
|
24
|
+
name: 'Guest',
|
|
25
|
+
props: {
|
|
26
|
+
initialRouteName: 'Home',
|
|
27
|
+
screenOptions: {
|
|
28
|
+
headerShown: false,
|
|
29
|
+
tabBarLabel: 'About',
|
|
30
|
+
// tabBarIcon: ({ color }) => <Ionicons name="person" size={24} color={color} />,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
['//guest/home']: {
|
|
35
|
+
name: 'Home',
|
|
36
|
+
props: {
|
|
37
|
+
initialParams: {},
|
|
38
|
+
component: MyComponent,
|
|
39
|
+
options: {
|
|
40
|
+
headerShown: true,
|
|
41
|
+
tabBarLabel: 'Home',
|
|
42
|
+
headerTitle: 'Home',
|
|
43
|
+
// tabBarIcon: ({ color }) => <Ionicons name="home" size={24} color={color} />,
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
['//guest/about']: {
|
|
48
|
+
exact: false,
|
|
49
|
+
container: (0, stack_1.createStackNavigator)(),
|
|
50
|
+
name: 'About',
|
|
51
|
+
props: {
|
|
52
|
+
initialRouteName: 'Hello',
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
['//guest/about/hello']: {
|
|
56
|
+
name: 'Hello',
|
|
57
|
+
props: {
|
|
58
|
+
initialParams: {},
|
|
59
|
+
component: MyComponent,
|
|
60
|
+
options: {
|
|
61
|
+
headerTitle: 'About',
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
['//guest/about/personalinfo']: {
|
|
66
|
+
name: 'Personal Info',
|
|
67
|
+
props: {
|
|
68
|
+
initialParams: { name: 'Test' },
|
|
69
|
+
component: MyComponent,
|
|
70
|
+
options: {
|
|
71
|
+
headerTitle: 'Personal Info',
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
['//setting']: {
|
|
76
|
+
name: 'Setting',
|
|
77
|
+
props: {
|
|
78
|
+
initialParams: {},
|
|
79
|
+
component: MyComponent,
|
|
80
|
+
options: {
|
|
81
|
+
headerShown: true,
|
|
82
|
+
headerTitle: 'Settings',
|
|
83
|
+
headerBackTitle: 'Back',
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
exact: false,
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
it('getNavigation ', () => {
|
|
90
|
+
const Navigation = (0, get_navigation_utils_1.getNavigation)('/', routerConfig1);
|
|
91
|
+
expect(Navigation).toMatchSnapshot();
|
|
92
|
+
});
|
|
93
|
+
it('with feature', () => {
|
|
94
|
+
const feature = new connector_native_1.Feature({ routeConfig: routerConfig1 });
|
|
95
|
+
const Navigation = feature.getConfiguredRoutes2('/');
|
|
96
|
+
expect(Navigation).toMatchSnapshot();
|
|
97
|
+
const Render = feature.getRoutes2('/', 'MainStack');
|
|
98
|
+
expect(Render).toMatchSnapshot();
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=get-navigation-utils.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-navigation-utils.test.js","sourceRoot":"","sources":["../../../src/route/react-navigation/get-navigation-utils.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./react-navigation-render"), exports);
|
|
18
|
+
__exportStar(require("./get-navigation-utils"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/route/react-navigation/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,yDAAuC"}
|
package/lib/route/{react-navigation-render.d.ts → react-navigation/react-navigation-orig.d.ts}
RENAMED
|
File without changes
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// import React from 'react';
|
|
2
|
+
// import { NavigatorItem, isStackOrTab } from './types';
|
|
3
|
+
// const childrenToRoutes = (
|
|
4
|
+
// children: { [name: string]: NavigatorItem },
|
|
5
|
+
// parentNavigator: NavigatorItem,
|
|
6
|
+
// parentRouteName: string,
|
|
7
|
+
// ) => Object.entries(children).map(([key, child]: any) => resolveRoute(key, child, parentNavigator, parentRouteName));
|
|
8
|
+
// const resolveRoute = (
|
|
9
|
+
// routeName: string | null,
|
|
10
|
+
// route: any,
|
|
11
|
+
// // parentNavigator: NavigatorItem,
|
|
12
|
+
// parentNavigator: any,
|
|
13
|
+
// parentRouteName: string,
|
|
14
|
+
// ) => {
|
|
15
|
+
// if (isStackOrTab(route)) {
|
|
16
|
+
// const navigatorRouteName = parentRouteName + (routeName === null ? '' : '.' + routeName);
|
|
17
|
+
// const navigator = (
|
|
18
|
+
// <route.container.Navigator
|
|
19
|
+
// {...route.props}
|
|
20
|
+
// key={navigatorRouteName}
|
|
21
|
+
// children={childrenToRoutes(route.children, route, navigatorRouteName)}
|
|
22
|
+
// />
|
|
23
|
+
// );
|
|
24
|
+
// if (!parentNavigator) {
|
|
25
|
+
// return navigator;
|
|
26
|
+
// } else {
|
|
27
|
+
// return (
|
|
28
|
+
// <parentNavigator.container.Screen
|
|
29
|
+
// key={navigatorRouteName}
|
|
30
|
+
// name={navigatorRouteName}
|
|
31
|
+
// children={() => navigator}
|
|
32
|
+
// />
|
|
33
|
+
// );
|
|
34
|
+
// }
|
|
35
|
+
// } else {
|
|
36
|
+
// const { component: C, ...rest } = route.props;
|
|
37
|
+
// const screenName = parentRouteName + '.' + routeName;
|
|
38
|
+
// return <parentNavigator.container.Screen {...rest} key={screenName} name={screenName} children={() => <C />} />;
|
|
39
|
+
// }
|
|
40
|
+
// };
|
|
41
|
+
// const resolveRootRoute = (rootRoute: NavigatorItem, rootRouteName: string) =>
|
|
42
|
+
// resolveRoute(null, rootRoute, null, rootRouteName);
|
|
43
|
+
// export default resolveRootRoute;
|
|
44
|
+
//# sourceMappingURL=react-navigation-orig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-navigation-orig.js","sourceRoot":"","sources":["../../../src/route/react-navigation/react-navigation-orig.tsx"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,yDAAyD;AAEzD,6BAA6B;AAC7B,mDAAmD;AACnD,sCAAsC;AACtC,+BAA+B;AAC/B,wHAAwH;AAExH,yBAAyB;AACzB,gCAAgC;AAChC,kBAAkB;AAClB,yCAAyC;AACzC,4BAA4B;AAC5B,+BAA+B;AAC/B,SAAS;AACT,iCAAiC;AACjC,oGAAoG;AACpG,8BAA8B;AAC9B,yCAAyC;AACzC,mCAAmC;AACnC,2CAA2C;AAC3C,yFAAyF;AACzF,iBAAiB;AACjB,aAAa;AACb,kCAAkC;AAClC,gCAAgC;AAChC,mBAAmB;AACnB,uBAAuB;AACvB,oDAAoD;AACpD,+CAA+C;AAC/C,gDAAgD;AAChD,iDAAiD;AACjD,qBAAqB;AACrB,iBAAiB;AACjB,YAAY;AACZ,eAAe;AACf,yDAAyD;AACzD,gEAAgE;AAChE,2HAA2H;AAC3H,QAAQ;AACR,KAAK;AAEL,gFAAgF;AAChF,0DAA0D;AAE1D,mCAAmC"}
|
|
File without changes
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
// import React from 'react';
|
|
2
|
+
// // import { Ionicons } from '@expo/vector-icons';
|
|
3
|
+
// import { createStackNavigator } from '@react-navigation/stack';
|
|
4
|
+
// import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
|
|
5
|
+
// // import { NavigationContainer } from '@react-navigation/native';
|
|
6
|
+
// import { RootAppNavigators } from './types';
|
|
7
|
+
// import resolveRootRoute from './react-navigation-render1';
|
|
8
|
+
// const SampleComponent = () => <></>
|
|
9
|
+
// // export const Navigation = () => {
|
|
10
|
+
// describe('react-navigation ', () => {
|
|
11
|
+
// const rootRoutes: RootAppNavigators = {
|
|
12
|
+
// MainStack: {
|
|
13
|
+
// container: createStackNavigator(),
|
|
14
|
+
// props: {
|
|
15
|
+
// initialRouteName: 'Guest',
|
|
16
|
+
// screenOptions: {
|
|
17
|
+
// headerShown: false,
|
|
18
|
+
// },
|
|
19
|
+
// },
|
|
20
|
+
// children: {
|
|
21
|
+
// Guest: {
|
|
22
|
+
// container: createBottomTabNavigator(),
|
|
23
|
+
// props: {
|
|
24
|
+
// initialRouteName: 'Home',
|
|
25
|
+
// screenOptions: {
|
|
26
|
+
// headerShown: false,
|
|
27
|
+
// tabBarLabel: 'About',
|
|
28
|
+
// // tabBarIcon: ({ color }) => <Ionicons name="person" size={24} color={color} />,
|
|
29
|
+
// },
|
|
30
|
+
// },
|
|
31
|
+
// children: {
|
|
32
|
+
// Home: {
|
|
33
|
+
// props: {
|
|
34
|
+
// initialParams: {},
|
|
35
|
+
// component: SampleComponent,
|
|
36
|
+
// options: {
|
|
37
|
+
// headerShown: true,
|
|
38
|
+
// tabBarLabel: 'Home',
|
|
39
|
+
// headerTitle: 'Home',
|
|
40
|
+
// // tabBarIcon: ({ color }) => <Ionicons name="home" size={24} color={color} />,
|
|
41
|
+
// },
|
|
42
|
+
// },
|
|
43
|
+
// },
|
|
44
|
+
// About: {
|
|
45
|
+
// container: createStackNavigator(),
|
|
46
|
+
// props: {
|
|
47
|
+
// initialRouteName: 'Hello',
|
|
48
|
+
// },
|
|
49
|
+
// children: {
|
|
50
|
+
// Hello: {
|
|
51
|
+
// props: {
|
|
52
|
+
// initialParams: {},
|
|
53
|
+
// component: SampleComponent,
|
|
54
|
+
// options: {
|
|
55
|
+
// headerTitle: 'About',
|
|
56
|
+
// },
|
|
57
|
+
// },
|
|
58
|
+
// },
|
|
59
|
+
// PersonalInfo: {
|
|
60
|
+
// props: {
|
|
61
|
+
// initialParams: { name: 'Test' },
|
|
62
|
+
// component: SampleComponent,
|
|
63
|
+
// options: {
|
|
64
|
+
// headerTitle: 'Personal Info',
|
|
65
|
+
// },
|
|
66
|
+
// },
|
|
67
|
+
// },
|
|
68
|
+
// },
|
|
69
|
+
// },
|
|
70
|
+
// },
|
|
71
|
+
// },
|
|
72
|
+
// Setting: {
|
|
73
|
+
// props: {
|
|
74
|
+
// initialParams: {},
|
|
75
|
+
// component: SampleComponent,
|
|
76
|
+
// options: {
|
|
77
|
+
// headerShown: true,
|
|
78
|
+
// headerTitle: 'Settings',
|
|
79
|
+
// headerBackTitle: 'Back',
|
|
80
|
+
// },
|
|
81
|
+
// },
|
|
82
|
+
// },
|
|
83
|
+
// },
|
|
84
|
+
// },
|
|
85
|
+
// };
|
|
86
|
+
// const MainStack = resolveRootRoute(rootRoutes.MainStack, 'MainStack');
|
|
87
|
+
// it('test component', () => {
|
|
88
|
+
// expect(MainStack).toMatchSnapshot();
|
|
89
|
+
// })
|
|
90
|
+
// })
|
|
91
|
+
//# sourceMappingURL=react-navigation-orig.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-navigation-orig.test.js","sourceRoot":"","sources":["../../../src/route/react-navigation/react-navigation-orig.test.tsx"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,oDAAoD;AACpD,kEAAkE;AAClE,4EAA4E;AAC5E,qEAAqE;AACrE,+CAA+C;AAC/C,6DAA6D;AAE7D,sCAAsC;AACtC,uCAAuC;AACvC,wCAAwC;AACxC,8CAA8C;AAC9C,uBAAuB;AACvB,iDAAiD;AACjD,uBAAuB;AACvB,6CAA6C;AAC7C,mCAAmC;AACnC,0CAA0C;AAC1C,qBAAqB;AACrB,iBAAiB;AACjB,0BAA0B;AAC1B,2BAA2B;AAC3B,6DAA6D;AAC7D,+BAA+B;AAC/B,oDAAoD;AACpD,2CAA2C;AAC3C,kDAAkD;AAClD,oDAAoD;AACpD,gHAAgH;AAChH,6BAA6B;AAC7B,yBAAyB;AACzB,kCAAkC;AAClC,kCAAkC;AAClC,uCAAuC;AACvC,qDAAqD;AACrD,8DAA8D;AAC9D,6CAA6C;AAC7C,yDAAyD;AACzD,2DAA2D;AAC3D,2DAA2D;AAC3D,sHAAsH;AACtH,qCAAqC;AACrC,iCAAiC;AACjC,6BAA6B;AAC7B,mCAAmC;AACnC,iEAAiE;AACjE,uCAAuC;AACvC,6DAA6D;AAC7D,iCAAiC;AACjC,0CAA0C;AAC1C,2CAA2C;AAC3C,+CAA+C;AAC/C,6DAA6D;AAC7D,sEAAsE;AACtE,qDAAqD;AACrD,oEAAoE;AACpE,6CAA6C;AAC7C,yCAAyC;AACzC,qCAAqC;AACrC,kDAAkD;AAClD,+CAA+C;AAC/C,2EAA2E;AAC3E,sEAAsE;AACtE,qDAAqD;AACrD,4EAA4E;AAC5E,6CAA6C;AAC7C,yCAAyC;AACzC,qCAAqC;AACrC,iCAAiC;AACjC,6BAA6B;AAC7B,yBAAyB;AACzB,qBAAqB;AACrB,6BAA6B;AAC7B,+BAA+B;AAC/B,6CAA6C;AAC7C,sDAAsD;AACtD,qCAAqC;AACrC,iDAAiD;AACjD,uDAAuD;AACvD,uDAAuD;AACvD,6BAA6B;AAC7B,yBAAyB;AACzB,qBAAqB;AACrB,iBAAiB;AACjB,aAAa;AACb,SAAS;AAET,6EAA6E;AAC7E,mCAAmC;AACnC,+CAA+C;AAC/C,SAAS;AACT,KAAK"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
const react_1 = __importDefault(require("react"));
|
|
18
|
+
const types_1 = require("./types");
|
|
19
|
+
const childrenToRoutes = (children, parentNavigator, parentRouteName) => {
|
|
20
|
+
return children.map((child) => resolveRoute(child.name, child, parentNavigator, parentRouteName));
|
|
21
|
+
};
|
|
22
|
+
const resolveRoute = (routeName, route,
|
|
23
|
+
// parentNavigator: NavigatorItem,
|
|
24
|
+
parentNavigator, parentRouteName) => {
|
|
25
|
+
if ((0, types_1.isStackOrTab)(route)) {
|
|
26
|
+
const navigatorRouteName = parentRouteName + (routeName === null ? '' : '.' + routeName);
|
|
27
|
+
const navigator = (react_1.default.createElement(route.container.Navigator, Object.assign({}, route.props, { key: navigatorRouteName, children: childrenToRoutes(route.children, route, navigatorRouteName) })));
|
|
28
|
+
if (!parentNavigator) {
|
|
29
|
+
return navigator;
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
return (react_1.default.createElement(parentNavigator.container.Screen, { key: navigatorRouteName, name: navigatorRouteName, children: () => navigator }));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
const _a = route.props, { component: C } = _a, rest = __rest(_a, ["component"]);
|
|
37
|
+
const screenName = parentRouteName + '.' + routeName;
|
|
38
|
+
return react_1.default.createElement(parentNavigator.container.Screen, Object.assign({}, rest, { key: screenName, name: screenName, children: () => react_1.default.createElement(C, null) }));
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
const resolveRootRoute = (rootRoute, rootRouteName) => resolveRoute(null, rootRoute, null, rootRouteName);
|
|
42
|
+
exports.default = resolveRootRoute;
|
|
43
|
+
//# sourceMappingURL=react-navigation-render.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-navigation-render.js","sourceRoot":"","sources":["../../../src/route/react-navigation/react-navigation-render.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,mCAAsD;AAEtD,MAAM,gBAAgB,GAAG,CACrB,QAA8C,EAC9C,eAA8B,EAC9B,eAAuB,EACzB,EAAE;IACA,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC,CAAC;AACtG,CAAC,CAAA;AAED,MAAM,YAAY,GAAG,CACjB,SAAwB,EACxB,KAAU;AACV,kCAAkC;AAClC,eAAoB,EACpB,eAAuB,EACzB,EAAE;IACA,IAAI,IAAA,oBAAY,EAAC,KAAK,CAAC,EAAE;QACrB,MAAM,kBAAkB,GAAG,eAAe,GAAG,CAAC,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,SAAS,CAAC,CAAC;QACzF,MAAM,SAAS,GAAG,CACd,8BAAC,KAAK,CAAC,SAAS,CAAC,SAAS,oBAClB,KAAK,CAAC,KAAK,IACf,GAAG,EAAE,kBAAkB,EACvB,QAAQ,EAAE,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,EAAE,kBAAkB,CAAC,IACvE,CACL,CAAC;QACF,IAAI,CAAC,eAAe,EAAE;YAClB,OAAO,SAAS,CAAC;SACpB;aAAM;YACH,OAAO,CACH,8BAAC,eAAe,CAAC,SAAS,CAAC,MAAM,IAC7B,GAAG,EAAE,kBAAkB,EACvB,IAAI,EAAE,kBAAkB,EACxB,QAAQ,EAAE,GAAG,EAAE,CAAC,SAAS,GAC3B,CACL,CAAC;SACL;KACJ;SAAM;QACH,MAAM,KAA4B,KAAK,CAAC,KAAK,EAAvC,EAAE,SAAS,EAAE,CAAC,OAAyB,EAApB,IAAI,cAAvB,aAAyB,CAAc,CAAC;QAC9C,MAAM,UAAU,GAAG,eAAe,GAAG,GAAG,GAAG,SAAS,CAAC;QACrD,OAAO,8BAAC,eAAe,CAAC,SAAS,CAAC,MAAM,oBAAK,IAAI,IAAE,GAAG,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,8BAAC,CAAC,OAAG,IAAI,CAAC;KACnH;AACL,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,SAAc,EAAE,aAAqB,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;AAEvH,kBAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
// import { Ionicons } from '@expo/vector-icons';
|
|
8
|
+
const stack_1 = require("@react-navigation/stack");
|
|
9
|
+
const bottom_tabs_1 = require("@react-navigation/bottom-tabs");
|
|
10
|
+
const react_navigation_render_1 = __importDefault(require("./react-navigation-render"));
|
|
11
|
+
const SampleComponent = () => react_1.default.createElement(react_1.default.Fragment, null);
|
|
12
|
+
// export const Navigation = () => {
|
|
13
|
+
describe('react-navigation ', () => {
|
|
14
|
+
const rootRoutes = [
|
|
15
|
+
{
|
|
16
|
+
container: (0, stack_1.createStackNavigator)(),
|
|
17
|
+
name: 'MainStack',
|
|
18
|
+
props: {
|
|
19
|
+
initialRouteName: 'Guest',
|
|
20
|
+
screenOptions: {
|
|
21
|
+
headerShown: false,
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
children: [
|
|
25
|
+
{
|
|
26
|
+
name: 'Guest',
|
|
27
|
+
container: (0, bottom_tabs_1.createBottomTabNavigator)(),
|
|
28
|
+
props: {
|
|
29
|
+
initialRouteName: 'Home',
|
|
30
|
+
screenOptions: {
|
|
31
|
+
headerShown: false,
|
|
32
|
+
tabBarLabel: 'About',
|
|
33
|
+
// tabBarIcon: ({ color }) => <Ionicons name="person" size={24} color={color} />,
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
children: [
|
|
37
|
+
{
|
|
38
|
+
name: 'Home',
|
|
39
|
+
props: {
|
|
40
|
+
initialParams: {},
|
|
41
|
+
component: SampleComponent,
|
|
42
|
+
options: {
|
|
43
|
+
headerShown: true,
|
|
44
|
+
tabBarLabel: 'Home',
|
|
45
|
+
headerTitle: 'Home',
|
|
46
|
+
// tabBarIcon: ({ color }) => <Ionicons name="home" size={24} color={color} />,
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
name: 'About',
|
|
52
|
+
container: (0, stack_1.createStackNavigator)(),
|
|
53
|
+
props: {
|
|
54
|
+
initialRouteName: 'Hello',
|
|
55
|
+
},
|
|
56
|
+
children: [
|
|
57
|
+
{
|
|
58
|
+
name: 'Hello',
|
|
59
|
+
props: {
|
|
60
|
+
initialParams: {},
|
|
61
|
+
component: SampleComponent,
|
|
62
|
+
options: {
|
|
63
|
+
headerTitle: 'About',
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
name: 'PersonalInfo',
|
|
69
|
+
props: {
|
|
70
|
+
initialParams: { name: 'Test' },
|
|
71
|
+
component: SampleComponent,
|
|
72
|
+
options: {
|
|
73
|
+
headerTitle: 'Personal Info',
|
|
74
|
+
},
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
],
|
|
78
|
+
},
|
|
79
|
+
],
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
name: 'Setting',
|
|
83
|
+
props: {
|
|
84
|
+
initialParams: {},
|
|
85
|
+
component: SampleComponent,
|
|
86
|
+
options: {
|
|
87
|
+
headerShown: true,
|
|
88
|
+
headerTitle: 'Settings',
|
|
89
|
+
headerBackTitle: 'Back',
|
|
90
|
+
},
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
],
|
|
94
|
+
},
|
|
95
|
+
];
|
|
96
|
+
const MainStack = (0, react_navigation_render_1.default)(rootRoutes[0], 'MainStack');
|
|
97
|
+
it('test component', () => {
|
|
98
|
+
expect(MainStack).toMatchSnapshot();
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=react-navigation-render.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-navigation-render.test.js","sourceRoot":"","sources":["../../../src/route/react-navigation/react-navigation-render.test.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,iDAAiD;AACjD,mDAA+D;AAC/D,+DAAyE;AAGzE,wFAAyD;AAEzD,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,6DAAK,CAAA;AACnC,oCAAoC;AACpC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IAC/B,MAAM,UAAU,GAAG;QACf;YACI,SAAS,EAAE,IAAA,4BAAoB,GAAE;YACjC,IAAI,EAAE,WAAW;YACjB,KAAK,EAAE;gBACH,gBAAgB,EAAE,OAAO;gBACzB,aAAa,EAAE;oBACX,WAAW,EAAE,KAAK;iBACrB;aACJ;YACD,QAAQ,EAAE;gBACN;oBACI,IAAI,EAAE,OAAO;oBACb,SAAS,EAAE,IAAA,sCAAwB,GAAE;oBACrC,KAAK,EAAE;wBACH,gBAAgB,EAAE,MAAM;wBACxB,aAAa,EAAE;4BACX,WAAW,EAAE,KAAK;4BAClB,WAAW,EAAE,OAAO;4BACpB,iFAAiF;yBACpF;qBACJ;oBACD,QAAQ,EAAE;wBACN;4BACI,IAAI,EAAE,MAAM;4BACZ,KAAK,EAAE;gCACH,aAAa,EAAE,EAAE;gCACjB,SAAS,EAAE,eAAe;gCAC1B,OAAO,EAAE;oCACL,WAAW,EAAE,IAAI;oCACjB,WAAW,EAAE,MAAM;oCACnB,WAAW,EAAE,MAAM;oCACnB,+EAA+E;iCAClF;6BACJ;yBACJ;wBACD;4BACI,IAAI,EAAE,OAAO;4BACb,SAAS,EAAE,IAAA,4BAAoB,GAAE;4BACjC,KAAK,EAAE;gCACH,gBAAgB,EAAE,OAAO;6BAC5B;4BACD,QAAQ,EAAE;gCACN;oCACI,IAAI,EAAE,OAAO;oCACb,KAAK,EAAE;wCACH,aAAa,EAAE,EAAE;wCACjB,SAAS,EAAE,eAAe;wCAC1B,OAAO,EAAE;4CACL,WAAW,EAAE,OAAO;yCACvB;qCACJ;iCACJ;gCACD;oCACI,IAAI,EAAE,cAAc;oCACpB,KAAK,EAAE;wCACH,aAAa,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;wCAC/B,SAAS,EAAE,eAAe;wCAC1B,OAAO,EAAE;4CACL,WAAW,EAAE,eAAe;yCAC/B;qCACJ;iCACJ;6BACJ;yBACJ;qBACJ;iBACJ;gBACD;oBACI,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE;wBACH,aAAa,EAAE,EAAE;wBACjB,SAAS,EAAE,eAAe;wBAC1B,OAAO,EAAE;4BACL,WAAW,EAAE,IAAI;4BACjB,WAAW,EAAE,UAAU;4BACvB,eAAe,EAAE,MAAM;yBAC1B;qBACJ;iBACJ;aACJ;SACJ;KACJ,CAAC;IAEF,MAAM,SAAS,GAAG,IAAA,iCAAgB,EAAC,UAAU,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;IAC/D,EAAE,CAAC,gBAAgB,EAAE,GAAG,EAAE;QACtB,MAAM,CAAC,SAAS,CAAC,CAAC,eAAe,EAAE,CAAC;IACxC,CAAC,CAAC,CAAA;AACN,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routes.js","sourceRoot":"","sources":["../../../src/route/react-navigation/routes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ComponentProps } from 'react';
|
|
2
|
+
import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
|
|
3
|
+
import { createStackNavigator } from '@react-navigation/stack';
|
|
4
|
+
interface Navigator<T extends (...args: any) => any> {
|
|
5
|
+
container: ReturnType<T>;
|
|
6
|
+
props: Omit<ComponentProps<ReturnType<T>['Navigator']>, 'name' | 'children'>;
|
|
7
|
+
children: (NavigatorItem & {
|
|
8
|
+
name: string;
|
|
9
|
+
})[];
|
|
10
|
+
}
|
|
11
|
+
export declare type TabNavigator = Navigator<typeof createBottomTabNavigator>;
|
|
12
|
+
export declare type StackNavigationNavigator = Navigator<typeof createStackNavigator>;
|
|
13
|
+
interface StackNavigationScreen {
|
|
14
|
+
props: Omit<ComponentProps<ReturnType<typeof createStackNavigator>['Screen']>, 'name'> & {
|
|
15
|
+
component: any;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
interface TabNavigationScreen {
|
|
19
|
+
props: Omit<ComponentProps<ReturnType<typeof createBottomTabNavigator>['Screen']>, 'name'> & {
|
|
20
|
+
component: any;
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export declare type NavigatorItem = StackNavigationNavigator | StackNavigationScreen | TabNavigator | TabNavigationScreen;
|
|
24
|
+
export declare type RootAppNavigators = {
|
|
25
|
+
[routeName: string]: NavigatorItem;
|
|
26
|
+
};
|
|
27
|
+
export declare const isStackOrTab: (s: NavigatorItem) => s is Navigator<any>;
|
|
28
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/route/react-navigation/types.tsx"],"names":[],"mappings":";;;AA2BO,MAAM,YAAY,GAAG,CAAC,CAAgB,EAAuB,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;AAAvF,QAAA,YAAY,gBAA2E"}
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -47,8 +51,8 @@ function wrapInitialPropsFetch(route, opts) {
|
|
|
47
51
|
const { component } = route, restRouteParams = __rest(route, ["component"]);
|
|
48
52
|
let Component = route.component;
|
|
49
53
|
function ComponentWithInitialPropsFetch(props) {
|
|
50
|
-
const [initialProps, setInitialProps] = react_1.useState(() => window.g_initialProps);
|
|
51
|
-
react_1.useEffect(() => {
|
|
54
|
+
const [initialProps, setInitialProps] = (0, react_1.useState)(() => window.g_initialProps);
|
|
55
|
+
(0, react_1.useEffect)(() => {
|
|
52
56
|
/**
|
|
53
57
|
* 1. 首次渲染时,此时 window.g_initialProps 变量存在,不需要再走一次 getInitialProps,这样一次 SSR 就走了 2 次 getInitialProps
|
|
54
58
|
* 2. 但是路由切换时,window.getInitialProps 会被赋为 null,这时候就走 getInitialProps 逻辑
|
|
@@ -110,7 +114,7 @@ function render({ route, opts, props, }) {
|
|
|
110
114
|
if (wrappers) {
|
|
111
115
|
let len = wrappers.length - 1;
|
|
112
116
|
while (len >= 0) {
|
|
113
|
-
ret = react_1.createElement(wrappers[len], newProps, ret);
|
|
117
|
+
ret = (0, react_1.createElement)(wrappers[len], newProps, ret);
|
|
114
118
|
len -= 1;
|
|
115
119
|
}
|
|
116
120
|
}
|