UNPKG

one

Version:

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

105 lines (103 loc) 4.02 kB
"use strict"; 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