@argon-router/react 0.9.0 → 0.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +34 -0
- package/dist/index.js +15 -9
- package/package.json +3 -3
package/dist/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),t=require("react"),r=require("effector-react"),o=t.createContext(null);function n(){const e=t.useContext(o);if(!e)throw new Error("[useRouter] Router not found. Add RouterProvider in app root");return e}const u=t.forwardRef((t,o)=>{const{to:u,params:s,onClick:i,...a}=t,{mappedRoutes:c}=n(),l=c.find(({route:e})=>e===u),{onOpen:
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),t=require("react"),r=require("effector-react"),o=t.createContext(null);function n(){const e=t.useContext(o);if(!e)throw new Error("[useRouter] Router not found. Add RouterProvider in app root");return e}const u=t.forwardRef((t,o)=>{const{to:u,params:s,onClick:i,...a}=t,{mappedRoutes:c}=n(),l=c.find(({route:e})=>e===u),{onOpen:p}=r.useUnit(u);if(!l)throw new Error(`[Link] Route with path "${u.path}" not found. Maybe it is not passed into createRouter?`);return e.jsx("a",{...a,ref:o,href:l.build(s??void 0),onClick:e=>{null==i||i(e),e.defaultPrevented||a.target&&"_self"!==a.target||e.metaKey||e.altKey||e.ctrlKey||e.shiftKey||(e.preventDefault(),p({params:s||{}}))}})});exports.Link=u,exports.RouterProvider=t=>e.jsx(o.Provider,{value:t.router,children:t.children}),exports.createLazyRouteView=function(r){r.route.internal.setAsyncImport(r.view);const o=t.lazy(r.view),{layout:n,fallback:u=()=>e.jsx(e.Fragment,{})}=r,s=n?()=>e.jsx(n,{children:e.jsx(t.Suspense,{fallback:e.jsx(u,{}),children:e.jsx(o,{})})}):()=>e.jsx(t.Suspense,{fallback:e.jsx(u,{}),children:e.jsx(o,{})});return{route:r.route,view:s}},exports.createRouteView=function(t){const{layout:r,view:o}=t,n=r?()=>e.jsx(r,{children:e.jsx(o,{})}):()=>e.jsx(o,{});return{route:t.route,view:n}},exports.createRoutesView=o=>{const{routes:n,otherwise:u}=o;return()=>{const o=r.useProvidedScope(),s=r.useUnit(n.map(e=>e.route.$isOpened)),i=t.useMemo(()=>{const e=n.filter(e=>Boolean(function(e,t){return t?t.getState(e):e.getState()}(e.route.$isOpened,o)));return e.reduce((e,t)=>e.filter(e=>e.route!==t.route.parent),e)},[s]),a=i.at(-1);return a?t.createElement(a.view):u?e.jsx(u,{}):null}},exports.useRouter=function(){return r.useUnit(n())},exports.useRouterContext=n,exports.withLayout=function(r,o){const n=r;return o.map(({route:r,view:o})=>({route:r,view:()=>e.jsx(n,{children:t.createElement(o)})}))};
|
package/dist/index.d.ts
CHANGED
|
@@ -179,4 +179,38 @@ export declare function useRouter(): {
|
|
|
179
179
|
|
|
180
180
|
export declare function useRouterContext(): Router;
|
|
181
181
|
|
|
182
|
+
/**
|
|
183
|
+
* @description Group routes by layout, so you don't need to pass `layout` property manually in all routes. Works for `createRouteView` and `createLazyRouteView`.
|
|
184
|
+
* @link https://movpushmov.dev/argon-router/react/with-layout.html
|
|
185
|
+
* @example ```tsx
|
|
186
|
+
* import {
|
|
187
|
+
* createRoutesView,
|
|
188
|
+
* createRouteView,
|
|
189
|
+
* withLayout,
|
|
190
|
+
* } from '@argon-router/react';
|
|
191
|
+
*
|
|
192
|
+
* import { ProfileScreen } from './profile';
|
|
193
|
+
* import { SignInScreen } from './sign-in';
|
|
194
|
+
* import { SignUpScreen } from './sign-up';
|
|
195
|
+
*
|
|
196
|
+
* import { routes } from '@shared/routing';
|
|
197
|
+
*
|
|
198
|
+
* import { AuthLayout } from '@layouts/auth';
|
|
199
|
+
*
|
|
200
|
+
* export const RoutesView = createRoutesView([
|
|
201
|
+
* ...withLayout(AuthLayout, [
|
|
202
|
+
* createRouteView({ route: routes.signIn, view: SignInScreen }),
|
|
203
|
+
* createRouteView({ route: routes.signUp, view: SignUpScreen }),
|
|
204
|
+
* ]),
|
|
205
|
+
* createRouteView({ route: routes.profile, view: ProfileScreen }),
|
|
206
|
+
* ]);
|
|
207
|
+
* ```
|
|
208
|
+
*/
|
|
209
|
+
export declare function withLayout(layout: ComponentType<{
|
|
210
|
+
children: ReactNode;
|
|
211
|
+
}>, views: RouteView[]): {
|
|
212
|
+
route: Route<any>;
|
|
213
|
+
view: () => JSX.Element;
|
|
214
|
+
}[];
|
|
215
|
+
|
|
182
216
|
export { }
|
package/dist/index.js
CHANGED
|
@@ -51,12 +51,11 @@ const Link = forwardRef((props, ref) => {
|
|
|
51
51
|
);
|
|
52
52
|
});
|
|
53
53
|
function createRouteView(props) {
|
|
54
|
+
const { layout: Layout, view: View } = props;
|
|
55
|
+
const view = Layout ? () => /* @__PURE__ */ jsx(Layout, { children: /* @__PURE__ */ jsx(View, {}) }) : () => /* @__PURE__ */ jsx(View, {});
|
|
54
56
|
return {
|
|
55
57
|
route: props.route,
|
|
56
|
-
view
|
|
57
|
-
const { view: View, layout: Layout } = props;
|
|
58
|
-
return Layout ? /* @__PURE__ */ jsx(Layout, { children: /* @__PURE__ */ jsx(View, {}) }) : /* @__PURE__ */ jsx(View, {});
|
|
59
|
-
}
|
|
58
|
+
view
|
|
60
59
|
};
|
|
61
60
|
}
|
|
62
61
|
function getStoreValue(store, scope) {
|
|
@@ -88,14 +87,20 @@ const createRoutesView = (props) => {
|
|
|
88
87
|
function createLazyRouteView(props) {
|
|
89
88
|
props.route.internal.setAsyncImport(props.view);
|
|
90
89
|
const View = lazy(props.view);
|
|
90
|
+
const { layout: Layout, fallback: Fallback = () => /* @__PURE__ */ jsx(Fragment, {}) } = props;
|
|
91
|
+
const view = Layout ? () => /* @__PURE__ */ jsx(Layout, { children: /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Fallback, {}), children: /* @__PURE__ */ jsx(View, {}) }) }) : () => /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Fallback, {}), children: /* @__PURE__ */ jsx(View, {}) });
|
|
91
92
|
return {
|
|
92
93
|
route: props.route,
|
|
93
|
-
view
|
|
94
|
-
const { layout: Layout, fallback: Fallback = () => /* @__PURE__ */ jsx(Fragment, {}) } = props;
|
|
95
|
-
return Layout ? /* @__PURE__ */ jsx(Layout, { children: /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Fallback, {}), children: /* @__PURE__ */ jsx(View, {}) }) }) : /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Fallback, {}), children: /* @__PURE__ */ jsx(View, {}) });
|
|
96
|
-
}
|
|
94
|
+
view
|
|
97
95
|
};
|
|
98
96
|
}
|
|
97
|
+
function withLayout(layout, views) {
|
|
98
|
+
const Layout = layout;
|
|
99
|
+
return views.map(({ route, view }) => ({
|
|
100
|
+
route,
|
|
101
|
+
view: () => /* @__PURE__ */ jsx(Layout, { children: createElement(view) })
|
|
102
|
+
}));
|
|
103
|
+
}
|
|
99
104
|
export {
|
|
100
105
|
Link,
|
|
101
106
|
RouterProvider,
|
|
@@ -103,5 +108,6 @@ export {
|
|
|
103
108
|
createRouteView,
|
|
104
109
|
createRoutesView,
|
|
105
110
|
useRouter,
|
|
106
|
-
useRouterContext
|
|
111
|
+
useRouterContext,
|
|
112
|
+
withLayout
|
|
107
113
|
};
|
package/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"registry": "https://registry.npmjs.org/"
|
|
6
6
|
},
|
|
7
7
|
"private": false,
|
|
8
|
-
"version": "0.
|
|
8
|
+
"version": "0.10.0",
|
|
9
9
|
"description": "React bindings for argon router",
|
|
10
10
|
"keywords": [
|
|
11
11
|
"effector",
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
"url": "https://github.com/movpushmov/argon-router/issues"
|
|
45
45
|
},
|
|
46
46
|
"dependencies": {
|
|
47
|
-
"@argon-router/core": "^0.
|
|
47
|
+
"@argon-router/core": "^0.10.0"
|
|
48
48
|
},
|
|
49
49
|
"devDependencies": {
|
|
50
50
|
"@babel/preset-react": "^7.26.3",
|
|
@@ -59,5 +59,5 @@
|
|
|
59
59
|
"effector-react": ">=23",
|
|
60
60
|
"react": "18 || 19"
|
|
61
61
|
},
|
|
62
|
-
"gitHead": "
|
|
62
|
+
"gitHead": "7f8d946c9b6d11a4a828bdf2bafcf012970aa4d7"
|
|
63
63
|
}
|