UNPKG

one

Version:

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

40 lines (39 loc) 1.58 kB
import { jsx as _jsx } from "react/jsx-runtime"; import { useStateForPath } from "@react-navigation/core"; import { createContext, useRef } from "react"; import { getRouteInfo } from "./getRouteInfo.native.js"; var RouteInfoContext = /* @__PURE__ */createContext(void 0); function RouteInfoContextProvider(param) { var { children } = param, currentState = useStateForPath(), currentStateRef = useRef(void 0), lastStateRef = useRef(void 0), cachedRouteInfoValueRef = useRef(void 0), lazilyCalculatedRouteInfo = useRef(void 0); return currentState && currentStateRef.current !== currentState && (lazilyCalculatedRouteInfo.current = makeLazilyCalculatedRouteInfo({ currentStateRef, lastStateRef, cachedRouteInfoValueRef })), currentStateRef.current = currentState, /* @__PURE__ */_jsx(RouteInfoContext.Provider, { value: currentState ? lazilyCalculatedRouteInfo.current : void 0, children }); } function makeLazilyCalculatedRouteInfo(param) { var { currentStateRef, lastStateRef, cachedRouteInfoValueRef } = param; return new Proxy({}, { get(_, p) { var state = currentStateRef.current; if (!state) throw new Error("[lazilyCalculatedRouteInfo] cannot get state"); return (!cachedRouteInfoValueRef.current || lastStateRef.current !== state) && (cachedRouteInfoValueRef.current = getRouteInfo(state), lastStateRef.current = state), cachedRouteInfoValueRef.current[p]; } }); } export { RouteInfoContext, RouteInfoContextProvider }; //# sourceMappingURL=RouteInfoContext.native.js.map