@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.
Files changed (130) hide show
  1. package/lib/__tests__/fill-register-test.js +5 -1
  2. package/lib/__tests__/fill-register-test.js.map +1 -1
  3. package/lib/__tests__/integrated-routes.test.js +8 -4
  4. package/lib/__tests__/integrated-routes.test.js.map +1 -1
  5. package/lib/__tests__/router-render.test.js +7 -3
  6. package/lib/__tests__/router-render.test.js.map +1 -1
  7. package/lib/connector/base-connector.d.ts +5 -4
  8. package/lib/connector/base-connector.js +20 -17
  9. package/lib/connector/base-connector.js.map +1 -1
  10. package/lib/connector/connector.d.ts +3 -0
  11. package/lib/connector/connector.js +3 -0
  12. package/lib/connector/connector.js.map +1 -1
  13. package/lib/connector/connector.native.d.ts +4 -1
  14. package/lib/connector/connector.native.js +9 -1
  15. package/lib/connector/connector.native.js.map +1 -1
  16. package/lib/connector/connector.test.js +5 -1
  17. package/lib/connector/connector.test.js.map +1 -1
  18. package/lib/connector/index.js +5 -1
  19. package/lib/connector/index.js.map +1 -1
  20. package/lib/index.js +5 -1
  21. package/lib/index.js.map +1 -1
  22. package/lib/index.native.js +5 -1
  23. package/lib/index.native.js.map +1 -1
  24. package/lib/interfaces/index.js +5 -1
  25. package/lib/interfaces/index.js.map +1 -1
  26. package/lib/interfaces/router.d.ts +4 -1
  27. package/lib/inversify/InversifyContext.js +5 -1
  28. package/lib/inversify/InversifyContext.js.map +1 -1
  29. package/lib/inversify/index.js +5 -1
  30. package/lib/inversify/index.js.map +1 -1
  31. package/lib/plugin-area/__tests__/higher-order-component-util.test.js +10 -6
  32. package/lib/plugin-area/__tests__/higher-order-component-util.test.js.map +1 -1
  33. package/lib/plugin-area/__tests__/plugin-api.test.js +9 -9
  34. package/lib/plugin-area/__tests__/plugin-api.test.js.map +1 -1
  35. package/lib/plugin-area/base-plugin-area.js +11 -7
  36. package/lib/plugin-area/base-plugin-area.js.map +1 -1
  37. package/lib/plugin-area/higher-order-component-util.js +1 -1
  38. package/lib/plugin-area/higher-order-component-util.js.map +1 -1
  39. package/lib/plugin-area/index.d.ts +1 -0
  40. package/lib/plugin-area/index.js +5 -1
  41. package/lib/plugin-area/index.js.map +1 -1
  42. package/lib/plugin-area/index.native.d.ts +1 -0
  43. package/lib/plugin-area/index.native.js +5 -1
  44. package/lib/plugin-area/index.native.js.map +1 -1
  45. package/lib/plugin-area/plugin-api.js +4 -4
  46. package/lib/plugin-area/plugin-api.js.map +1 -1
  47. package/lib/plugin-area/plugin-context.js +6 -2
  48. package/lib/plugin-area/plugin-context.js.map +1 -1
  49. package/lib/route/__tests__/admin-new-routes.test.js +8 -4
  50. package/lib/route/__tests__/admin-new-routes.test.js.map +1 -1
  51. package/lib/route/__tests__/getFlatMenus.test.js +3 -3
  52. package/lib/route/__tests__/getFlatMenus.test.js.map +1 -1
  53. package/lib/route/__tests__/render-routes-config.test.js +1 -1
  54. package/lib/route/__tests__/render-routes-config.test.js.map +1 -1
  55. package/lib/route/get-routes.js +2 -2
  56. package/lib/route/get-routes.js.map +1 -1
  57. package/lib/route/get-routes.test.js +3 -3
  58. package/lib/route/get-routes.test.js.map +1 -1
  59. package/lib/route/index.d.ts +1 -0
  60. package/lib/route/index.js +6 -1
  61. package/lib/route/index.js.map +1 -1
  62. package/lib/route/index.native.js +5 -1
  63. package/lib/route/index.native.js.map +1 -1
  64. package/lib/route/old/__tests__/config-sidebar-menu.test.js +3 -3
  65. package/lib/route/old/__tests__/config-sidebar-menu.test.js.map +1 -1
  66. package/lib/route/old/get-routes-notused.js +1 -1
  67. package/lib/route/old/get-routes-notused.js.map +1 -1
  68. package/lib/route/old/render.d.ts +1 -0
  69. package/lib/route/old/render.js +6 -3
  70. package/lib/route/old/render.js.map +1 -1
  71. package/lib/route/react-navigation/get-navigation-utils.d.ts +3 -0
  72. package/lib/route/react-navigation/get-navigation-utils.js +78 -0
  73. package/lib/route/react-navigation/get-navigation-utils.js.map +1 -0
  74. package/lib/route/react-navigation/get-navigation-utils.test.d.ts +1 -0
  75. package/lib/route/react-navigation/get-navigation-utils.test.js +101 -0
  76. package/lib/route/react-navigation/get-navigation-utils.test.js.map +1 -0
  77. package/lib/route/react-navigation/index.d.ts +2 -0
  78. package/lib/route/react-navigation/index.js +19 -0
  79. package/lib/route/react-navigation/index.js.map +1 -0
  80. package/lib/route/{react-navigation-render.d.ts → react-navigation/react-navigation-orig.d.ts} +0 -0
  81. package/lib/route/react-navigation/react-navigation-orig.js +44 -0
  82. package/lib/route/react-navigation/react-navigation-orig.js.map +1 -0
  83. package/lib/route/react-navigation/react-navigation-orig.test.d.ts +0 -0
  84. package/lib/route/react-navigation/react-navigation-orig.test.js +91 -0
  85. package/lib/route/react-navigation/react-navigation-orig.test.js.map +1 -0
  86. package/lib/route/react-navigation/react-navigation-render.d.ts +2 -0
  87. package/lib/route/react-navigation/react-navigation-render.js +43 -0
  88. package/lib/route/react-navigation/react-navigation-render.js.map +1 -0
  89. package/lib/route/react-navigation/react-navigation-render.test.d.ts +1 -0
  90. package/lib/route/react-navigation/react-navigation-render.test.js +101 -0
  91. package/lib/route/react-navigation/react-navigation-render.test.js.map +1 -0
  92. package/lib/route/react-navigation/routes.d.ts +11 -0
  93. package/lib/route/react-navigation/routes.js +3 -0
  94. package/lib/route/react-navigation/routes.js.map +1 -0
  95. package/lib/route/react-navigation/types.d.ts +28 -0
  96. package/lib/route/react-navigation/types.js +6 -0
  97. package/lib/route/react-navigation/types.js.map +1 -0
  98. package/lib/route/render-routes.d.ts +1 -0
  99. package/lib/route/render-routes.js +8 -4
  100. package/lib/route/render-routes.js.map +1 -1
  101. package/lib/route/render-routes.native.d.ts +1 -0
  102. package/lib/route/render-routes.native.js +8 -4
  103. package/lib/route/render-routes.native.js.map +1 -1
  104. package/lib/route/render-routes.test.js +23 -23
  105. package/lib/route/render-routes.test.js.map +1 -1
  106. package/lib/route-based-plugin-area/__tests__/higher-order-component-util.test.js +10 -6
  107. package/lib/route-based-plugin-area/__tests__/higher-order-component-util.test.js.map +1 -1
  108. package/lib/route-based-plugin-area/__tests__/plugin-api.test.js +9 -9
  109. package/lib/route-based-plugin-area/__tests__/plugin-api.test.js.map +1 -1
  110. package/lib/route-based-plugin-area/higher-order-component-util.js +1 -1
  111. package/lib/route-based-plugin-area/higher-order-component-util.js.map +1 -1
  112. package/lib/route-based-plugin-area/index.js +5 -1
  113. package/lib/route-based-plugin-area/index.js.map +1 -1
  114. package/lib/route-based-plugin-area/plugin-api.js +4 -4
  115. package/lib/route-based-plugin-area/plugin-api.js.map +1 -1
  116. package/lib/route-based-plugin-area/plugin-context.js +6 -2
  117. package/lib/route-based-plugin-area/plugin-context.js.map +1 -1
  118. package/lib/route-based-plugin-area/route-based-plugin-area.js +11 -7
  119. package/lib/route-based-plugin-area/route-based-plugin-area.js.map +1 -1
  120. package/lib/router-factory/index.js +5 -1
  121. package/lib/router-factory/index.js.map +1 -1
  122. package/lib/router-factory/index.native.js +5 -1
  123. package/lib/router-factory/index.native.js.map +1 -1
  124. package/lib/utils/index.js +5 -1
  125. package/lib/utils/index.js.map +1 -1
  126. package/lib/utils/sort-keys.test.js +1 -1
  127. package/lib/utils/sort-keys.test.js.map +1 -1
  128. package/package.json +20 -23
  129. package/lib/route/react-navigation-render.js +0 -1
  130. 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":";;;;;;;;;;;;;;AACA,iDAA0E;AAC1E,uCAAoD;AAE7C,MAAM,oBAAoB,GAAG,CAAC,IAAY,EAAE,SAAqB,EAAE,EAAE;IACxE,MAAM,YAAY,GAAG,IAAA,gBAAQ,EAAC,SAAS,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;AAC7C,CAAC,CAAC;AAHW,QAAA,oBAAoB,wBAG/B;AAEF,SAAgB,aAAa,CAAC,IAAY,EAAE,SAAc;IACtD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;KAClC;IACD,IAAI,UAAU,GAAG,IAAI,CAAC;IACtB,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,EAAE;QACjC,UAAU,GAAG,IAAI,GAAG,GAAG,CAAC;KACzB;IACD,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE;QACzD,OAAO,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,QAAQ,KAAK,IAAI,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,MAAM,eAAe,GAAuB,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;QAChE,uBACE,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,0BAAa,CAAC,MAAM,IAC3B,SAAS,CAAC,KAAK,CAAC,EACnB;IACJ,CAAC,CAAC,CAAC;IACH,MAAM,IAAI,GAAoC;QAC5C,wCAAwC;QACxC,6DAA6D;QAC7D,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,0BAAa,CAAC,IAAI;KACtB,CAAC;IACT,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;QAClC,MAAM,QAAQ,GAAG,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,QAAQ,CAAC,KAAK,EAAE,CAAC;QAEjB,gDAAgD;QAChD,IAAI,SAAS,CAAC,IAAI,KAAK,GAAG,EAAE;YAC1B,QAAQ,CAAC,KAAK,EAAE,CAAC;YACjB,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACpB;QACD,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC9B,IAAI,QAAQ,GAAG,IAAI,CAAC;QACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,SAAS,GAAG,CAAC,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;;gBAC3D,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;gBAEpD,IAAI,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;oBACzC,8DAA8D;oBAC9D,OAAO,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAA,MAAA,SAAS,CAAC,SAAS,CAAC,0CAAE,KAAK,MAAK,KAAK,CAAC;iBAC3F;YACH,CAAC,CAAC,CAAC;YACH,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;gBACpB,MAAM;aACP;YACD,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YACxC,MAAM,YAAY,GAAG,GAAI,QAAgB,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC;YACxE,QAAQ,CAAC,KAAK,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;SAC1G;QACD,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;YACtB,QAAQ,CAAC,QAAQ,GAAG,EAAE,CAAC;SACxB;QACD,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,KAAc,SAAS,EAAlB,IAAI,UAAK,SAAS,EAA5C,iBAAgC,CAAY,CAAC;QACnD,MAAM,UAAU,GAAG,IAAA,mBAAW,EAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEhD,QAAQ,CAAC,QAAQ,CAAC,IAAI,+CACjB,IAAI,GAGJ,UAAU,KACb,KAAK,EAAE,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IACnG,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,IAAI,CAAC,QAAQ,CAAC;AACvB,CAAC;AApEH,sCAoEG"}
@@ -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,2 @@
1
+ export * from './react-navigation-render';
2
+ export * from './get-navigation-utils';
@@ -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"}
@@ -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"}
@@ -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,2 @@
1
+ declare const resolveRootRoute: (rootRoute: any, rootRouteName: string) => JSX.Element;
2
+ export default resolveRootRoute;
@@ -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,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,11 @@
1
+ export interface INavigationProps {
2
+ container: any;
3
+ props: {
4
+ options: any;
5
+ initialRouteName: string;
6
+ component: any;
7
+ };
8
+ children: {
9
+ [key: string]: INavigationProps;
10
+ }[];
11
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=routes.js.map
@@ -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,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isStackOrTab = void 0;
4
+ const isStackOrTab = (s) => s.hasOwnProperty('children');
5
+ exports.isStackOrTab = isStackOrTab;
6
+ //# sourceMappingURL=types.js.map
@@ -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,3 +1,4 @@
1
+ /// <reference types="react" />
1
2
  import { IRouterRederOptions } from '../interfaces/new-router';
2
3
  declare function renderRoutes(opts: IRouterRederOptions): JSX.Element;
3
4
  export { renderRoutes as renderRoutes2 };
@@ -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.defineProperty(o, k2, { enumerable: true, get: function() { return m[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);
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
  }