one
Version:
One is a new React Framework that makes Vite serve both native and web.
105 lines (103 loc) • 4.02 kB
JavaScript
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all) __defProp(target, name, {
get: all[name],
enumerable: !0
});
},
__copyProps = (to, from, except, desc) => {
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
get: () => from[key],
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
});
return to;
};
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
value: !0
}), mod);
var findRouteNode_exports = {};
__export(findRouteNode_exports, {
extractParamsFromState: () => extractParamsFromState,
extractPathnameFromHref: () => extractPathnameFromHref,
extractSearchFromHref: () => extractSearchFromHref,
findRouteNodeFromState: () => findRouteNodeFromState
});
module.exports = __toCommonJS(findRouteNode_exports);
function findRouteNodeFromState(state, rootNode) {
if (!state || !rootNode) return null;
var currentRoute = state.routes[state.routes.length - 1];
if (!currentRoute) return null;
var matchingNode = findNodeByRouteName(rootNode, currentRoute.name);
if (!matchingNode) return null;
if (currentRoute.state && currentRoute.state.routes) {
var nestedResult = findRouteNodeFromState(currentRoute.state, matchingNode);
if (nestedResult) return nestedResult;
}
return matchingNode;
}
function findNodeByRouteName(node, routeName) {
if (node.route === routeName) return node;
var _iteratorNormalCompletion = !0,
_didIteratorError = !1,
_iteratorError = void 0;
try {
for (var _iterator = node.children[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
var child = _step.value,
found = findNodeByRouteName(child, routeName);
if (found) return found;
}
} catch (err) {
_didIteratorError = !0, _iteratorError = err;
} finally {
try {
!_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
} finally {
if (_didIteratorError) throw _iteratorError;
}
}
return null;
}
function extractParamsFromState(state) {
if (!state) return {};
var params = {},
_iteratorNormalCompletion = !0,
_didIteratorError = !1,
_iteratorError = void 0;
try {
for (var _iterator = state.routes[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = !0) {
var route = _step.value;
route.params && Object.assign(params, route.params), route.state && Object.assign(params, extractParamsFromState(route.state));
}
} catch (err) {
_didIteratorError = !0, _iteratorError = err;
} finally {
try {
!_iteratorNormalCompletion && _iterator.return != null && _iterator.return();
} finally {
if (_didIteratorError) throw _iteratorError;
}
}
return params;
}
function extractSearchFromHref(href) {
var searchIndex = href.indexOf("?");
if (searchIndex === -1) return {};
var searchString = href.slice(searchIndex + 1),
params = {},
searchParams = new URLSearchParams(searchString);
return searchParams.forEach(function (value, key) {
var existing = params[key];
existing === void 0 ? params[key] = value : Array.isArray(existing) ? existing.push(value) : params[key] = [existing, value];
}), params;
}
function extractPathnameFromHref(href) {
var searchIndex = href.indexOf("?"),
hashIndex = href.indexOf("#"),
endIndex = href.length;
return searchIndex !== -1 && (endIndex = Math.min(endIndex, searchIndex)), hashIndex !== -1 && (endIndex = Math.min(endIndex, hashIndex)), href.slice(0, endIndex);
}
//# sourceMappingURL=findRouteNode.native.js.map