UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

80 lines (79 loc) 2.57 kB
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