one
Version:
One is a new React Framework that makes Vite serve both native and web.
80 lines (79 loc) • 2.57 kB
JavaScript
import { jsx as _jsx } from "react/jsx-runtime";
import React, { createContext, useContext } from "react";
import { router } from "./router/imperative-api.native.js";
import { RouteParamsContext, useRouteNode } from "./router/Route.native.js";
import { RouteInfoContext } from "./router/RouteInfoContext.native.js";
import { navigationRef, useStoreRootState, useStoreRouteInfo } from "./router/router.native.js";
function useRootNavigationState() {
return useStoreRootState();
}
function useRouteInfo() {
var routeInfoFromContext = useContext(RouteInfoContext),
routeInfoFromRootState = useStoreRouteInfo(),
routeNode = useRouteNode();
return routeNode?.type === "layout" ? routeInfoFromRootState : routeInfoFromContext || routeInfoFromRootState;
}
function useNavigationContainerRef() {
return navigationRef;
}
var FrozeContext = /* @__PURE__ */createContext(!1);
function Frozen(param) {
var {
on = !1,
children
} = param;
return typeof window > "u" ? children : /* @__PURE__ */_jsx(FrozeContext.Provider, {
value: on,
children: (/* <Freeze freeze={on}> */
/* @__PURE__ */_jsx("div", {
...(on && {
inert: !0
}),
style: {
display: "contents"
},
children
}))
});
}
function useRouter() {
return router;
}
function useUnstableGlobalHref() {
return useRouteInfo().unstable_globalHref;
}
function useSegments() {
return useRouteInfo().segments;
}
function usePathname() {
return useRouteInfo().pathname;
}
function useActiveParams() {
return useRouteInfo().params;
}
var useLocalSearchParams = useParams,
useGlobalSearchParams = useActiveParams;
function useParams() {
var _React_useContext,
params = (_React_useContext = React.useContext(RouteParamsContext)) !== null && _React_useContext !== void 0 ? _React_useContext : {};
return Object.fromEntries(Object.entries(params).filter(function (param) {
var [_, value] = param;
return value !== void 0;
}).map(function (param) {
var [key, value] = param;
if (Array.isArray(value)) return [key, value.map(function (v) {
try {
return decodeURIComponent(v);
} catch {
return v;
}
})];
try {
return [key, decodeURIComponent(value)];
} catch {
return [key, value];
}
}));
}
export { Frozen, useActiveParams, useGlobalSearchParams, useLocalSearchParams, useNavigationContainerRef, useParams, usePathname, useRootNavigationState, useRouteInfo, useRouter, useSegments, useUnstableGlobalHref };
//# sourceMappingURL=hooks.native.js.map