one
Version:
One is a new React Framework that makes Vite serve both native and web.
100 lines • 4.12 kB
JavaScript
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all) __defProp(target, name, {
get: all[name],
enumerable: true
});
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
get: () => from[key],
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
});
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
value: mod,
enumerable: true
}) : target, mod));
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
value: true
}), mod);
var Route_exports = {};
__export(Route_exports, {
Route: () => Route,
RouteParamsContext: () => RouteParamsContext,
useContextKey: () => useContextKey,
useRouteNode: () => useRouteNode
});
module.exports = __toCommonJS(Route_exports);
var import_react = __toESM(require("react"), 1);
var import_findFocusedRoute = require("../fork/findFocusedRoute.cjs");
var import_linkingConfig = require("./linkingConfig.cjs");
var import_matchers = require("./matchers.cjs");
var import_params = require("./params.cjs");
var import_router = require("./router.cjs");
var import_RouteInfoContext = require("./RouteInfoContext.cjs");
var import_jsx_runtime = require("react/jsx-runtime");
const RouteParamsContext = (0, import_react.createContext)({});
const CurrentRouteContext = import_react.default.createContext(null);
if (process.env.NODE_ENV !== "production") {
CurrentRouteContext.displayName = "RouteNode";
}
function useRouteNode() {
return (0, import_react.useContext)(CurrentRouteContext);
}
function useContextKey() {
const node = useRouteNode();
if (node == null) {
throw new Error("No filename found. This is likely a bug in router.");
}
return (0, import_matchers.getContextKey)(node.contextKey);
}
function getParamsFromCurrentUrl(route) {
const linking = (0, import_linkingConfig.getResolvedLinking)();
if (!linking?.getStateFromPath) return void 0;
const path = import_router.routeInfo?.unstable_globalHref || route?.path || (typeof window !== "undefined" && window.location ? window.location.pathname + window.location.search : void 0);
if (!path) return void 0;
const state = linking.getStateFromPath(path, linking.config);
if (!state) return void 0;
const focused = (0, import_findFocusedRoute.findFocusedRoute)(state);
return focused?.params;
}
function Route({
children,
node,
route
}) {
const parentParams = (0, import_react.useContext)(RouteParamsContext);
const resolvedParams = import_react.default.useMemo(() => {
const rp = route?.params;
const ownParams = node.dynamic?.length ? (0, import_params.mergeDynamicParams)(rp, node.dynamic, getParamsFromCurrentUrl(route)) : rp;
if (!parentParams) return ownParams;
if (!ownParams) return parentParams;
return {
...parentParams,
...ownParams
};
}, [node, parentParams, route, import_router.routeInfo?.unstable_globalHref]);
return /* @__PURE__ */(0, import_jsx_runtime.jsx)(RouteParamsContext.Provider, {
value: resolvedParams,
children: /* @__PURE__ */(0, import_jsx_runtime.jsx)(CurrentRouteContext.Provider, {
value: node,
children: /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_RouteInfoContext.RouteInfoContextProvider, {
children
})
})
});
}