UNPKG

one

Version:

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

112 lines (110 loc) 3.98 kB
"use strict"; 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 useNavigation_exports = {}; __export(useNavigation_exports, { resolveParentId: () => resolveParentId, useNavigation: () => useNavigation }); module.exports = __toCommonJS(useNavigation_exports); var import_native = require("@react-navigation/native"); var import_react = __toESM(require("react"), 1); var import_matchers = require("./matchers.native.js"); var import_Route = require("./Route.native.js"); function useNavigation(parent) { var navigation = (0, import_native.useNavigation)(); var contextKey = (0, import_Route.useContextKey)(); var normalizedParent = import_react.default.useMemo(function () { if (!parent) { return null; } var normalized = (0, import_matchers.getNameFromFilePath)(parent); if (parent.startsWith(".")) { return relativePaths(contextKey, parent); } return normalized; }, [contextKey, parent]); if (normalizedParent != null) { var parentNavigation = navigation.getParent(normalizedParent); if (!parentNavigation) { throw new Error(`Could not find parent navigation with route "${parent}".` + (normalizedParent !== parent ? ` (normalized: ${normalizedParent})` : "")); } return parentNavigation; } return navigation; } function resolveParentId(contextKey, parentId) { if (!parentId) { return null; } if (parentId.startsWith(".")) { return (0, import_matchers.getNameFromFilePath)(relativePaths(contextKey, parentId)); } return (0, import_matchers.getNameFromFilePath)(parentId); } function relativePaths(from, to) { var fromParts = from.split("/").filter(Boolean); var toParts = to.split("/").filter(Boolean); var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = void 0; try { for (var _iterator = toParts[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var part = _step.value; if (part === "..") { if (fromParts.length === 0) { throw new Error(`Cannot resolve path "${to}" relative to "${from}"`); } fromParts.pop(); } else if (part === ".") {} else { fromParts.push(part); } } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator.return != null) { _iterator.return(); } } finally { if (_didIteratorError) { throw _iteratorError; } } } return "/" + fromParts.join("/"); } //# sourceMappingURL=useNavigation.native.js.map