one
Version:
One is a new React Framework that makes Vite serve both native and web.
40 lines (39 loc) • 1.58 kB
JavaScript
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