@argon-router/react 0.11.0 → 0.11.2
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 +2 -1
- package/dist/index.js +4 -10
- 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,...
|
|
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,replace:a,query:c,...l}=t,{mappedRoutes:p}=n(),x=p.find(({route:e})=>e===u),{onOpen:d}=r.useUnit(u);if(!x)throw new Error(`[Link] Route with path "${u.path}" not found. Maybe it is not passed into createRouter?`);return e.jsx("a",{...l,ref:o,href:x.build(s??void 0),onClick:e=>{null==i||i(e),e.defaultPrevented||l.target&&"_self"!==l.target||e.metaKey||e.altKey||e.ctrlKey||e.shiftKey||(e.preventDefault(),d({params:s||{},replace:a,query:c}))}})});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.useUnit(n.map(e=>e.route.$isOpened)),s=t.useMemo(()=>{const e=n.filter((e,t)=>o[t]);return e.reduce((e,t)=>e.filter(e=>e.route!==t.route.parent),e)},[o]).at(-1);return s?t.createElement(s.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
|
@@ -4,6 +4,7 @@ import { FC } from 'react';
|
|
|
4
4
|
import { ForwardedRef } from 'react';
|
|
5
5
|
import { JSX } from 'react/jsx-runtime';
|
|
6
6
|
import { NavigatePayload } from '@argon-router/core';
|
|
7
|
+
import { OpenPayloadBase } from '@argon-router/core';
|
|
7
8
|
import { Query } from '@argon-router/core';
|
|
8
9
|
import { ReactNode } from 'react';
|
|
9
10
|
import { Route } from '@argon-router/core';
|
|
@@ -14,7 +15,7 @@ declare type AnchorProps = Omit<AnchorHTMLAttributes<HTMLAnchorElement>, 'href'>
|
|
|
14
15
|
declare type BaseLinkProps<Params> = {
|
|
15
16
|
to: Route<Params>;
|
|
16
17
|
children?: ReactNode;
|
|
17
|
-
} & AnchorProps;
|
|
18
|
+
} & AnchorProps & OpenPayloadBase;
|
|
18
19
|
|
|
19
20
|
declare interface CreateBaseRouteViewProps<T> {
|
|
20
21
|
route: Route<T>;
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsx, Fragment } from "react/jsx-runtime";
|
|
2
2
|
import { createContext, useContext, forwardRef, useMemo, createElement, lazy, Suspense } from "react";
|
|
3
|
-
import { useUnit
|
|
3
|
+
import { useUnit } from "effector-react";
|
|
4
4
|
const RouterProviderContext = createContext(null);
|
|
5
5
|
const RouterProvider = (props) => {
|
|
6
6
|
return /* @__PURE__ */ jsx(RouterProviderContext.Provider, { value: props.router, children: props.children });
|
|
@@ -18,7 +18,7 @@ function useRouter() {
|
|
|
18
18
|
return useUnit(useRouterContext());
|
|
19
19
|
}
|
|
20
20
|
const Link = forwardRef((props, ref) => {
|
|
21
|
-
const { to, params, onClick, ...anchorProps } = props;
|
|
21
|
+
const { to, params, onClick, replace, query, ...anchorProps } = props;
|
|
22
22
|
const { mappedRoutes } = useRouterContext();
|
|
23
23
|
const target = mappedRoutes.find(({ route }) => route === to);
|
|
24
24
|
const { onOpen } = useUnit(to);
|
|
@@ -45,7 +45,7 @@ const Link = forwardRef((props, ref) => {
|
|
|
45
45
|
return;
|
|
46
46
|
}
|
|
47
47
|
e.preventDefault();
|
|
48
|
-
onOpen({ params: params || {} });
|
|
48
|
+
onOpen({ params: params || {}, replace, query });
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
51
|
);
|
|
@@ -58,18 +58,12 @@ function createRouteView(props) {
|
|
|
58
58
|
view
|
|
59
59
|
};
|
|
60
60
|
}
|
|
61
|
-
function getStoreValue(store, scope) {
|
|
62
|
-
return scope ? scope.getState(store) : store.getState();
|
|
63
|
-
}
|
|
64
61
|
const createRoutesView = (props) => {
|
|
65
62
|
const { routes, otherwise: NotFound } = props;
|
|
66
63
|
return () => {
|
|
67
|
-
const scope = useProvidedScope();
|
|
68
64
|
const visibilities = useUnit(routes.map((view) => view.route.$isOpened));
|
|
69
65
|
const openedViews = useMemo(() => {
|
|
70
|
-
const filtered = routes.filter(
|
|
71
|
-
(view) => Boolean(getStoreValue(view.route.$isOpened, scope))
|
|
72
|
-
);
|
|
66
|
+
const filtered = routes.filter((_, i) => visibilities[i]);
|
|
73
67
|
return filtered.reduce(
|
|
74
68
|
(filtered2, view) => filtered2.filter(
|
|
75
69
|
(r) => r.route !== view.route.parent
|
package/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"registry": "https://registry.npmjs.org/"
|
|
6
6
|
},
|
|
7
7
|
"private": false,
|
|
8
|
-
"version": "0.11.
|
|
8
|
+
"version": "0.11.2",
|
|
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.11.
|
|
47
|
+
"@argon-router/core": "^0.11.1"
|
|
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": "f63bf945db57a29b96028a96aaef81cc79bc4320"
|
|
63
63
|
}
|