@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 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:d}=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(),d({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);return{route:r.route,view:()=>{const{layout:n,fallback:u=()=>e.jsx(e.Fragment,{})}=r;return 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,{})})}}},exports.createRouteView=function(t){return{route:t.route,view:()=>{const{view:r,layout:o}=t;return o?e.jsx(o,{children:e.jsx(r,{})}):e.jsx(r,{})}}},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;
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.9.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.9.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": "fab0cd752c30cf142c168308596b2dcf2c664da2"
62
+ "gitHead": "7f8d946c9b6d11a4a828bdf2bafcf012970aa4d7"
63
63
  }