"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); 0 && (module.exports = { fillMetadataSegment: null, normalizeMetadataRoute: null }); function _export(target, all) { for(var name in all)Object.defineProperty(target, name, { enumerable: true, get: all[name] }); } _export(exports, { fillMetadataSegment: function() { return fillMetadataSegment; }, normalizeMetadataRoute: function() { return normalizeMetadataRoute; } }); const _ismetadataroute = require("./is-metadata-route"); const _path = /*#__PURE__*/ _interop_require_default(require("../../shared/lib/isomorphic/path")); const _serverutils = require("../../server/server-utils"); const _routeregex = require("../../shared/lib/router/utils/route-regex"); const _hash = require("../../shared/lib/hash"); const _apppaths = require("../../shared/lib/router/utils/app-paths"); const _normalizepathsep = require("../../shared/lib/page-path/normalize-path-sep"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /* * If there's special convention like (...) or @ in the page path, * Give it a unique hash suffix to avoid conflicts * * e.g. * /app/open-graph.tsx -> /open-graph/route * /app/(post)/open-graph.tsx -> /open-graph/route-[0-9a-z]{6} */ function getMetadataRouteSuffix(page) { let suffix = ""; if (page.includes("(") && page.includes(")") || page.includes("@")) { suffix = (0, _hash.djb2Hash)(page).toString(36).slice(0, 6); } return suffix; } function fillMetadataSegment(segment, params, imageSegment) { const pathname = (0, _apppaths.normalizeAppPath)(segment); const routeRegex = (0, _routeregex.getNamedRouteRegex)(pathname, false); const route = (0, _serverutils.interpolateDynamicPath)(pathname, params, routeRegex); const suffix = getMetadataRouteSuffix(segment); const routeSuffix = suffix ? `-${suffix}` : ""; const { name, ext } = _path.default.parse(imageSegment); return (0, _normalizepathsep.normalizePathSep)(_path.default.join(route, `${name}${routeSuffix}${ext}`)); } function normalizeMetadataRoute(page) { if (!(0, _ismetadataroute.isMetadataRoute)(page)) { return page; } let route = page; let suffix = ""; if (page === "/robots") { route += ".txt"; } else if (page === "/manifest") { route += ".webmanifest"; } else if (page.endsWith("/sitemap")) { route += ".xml"; } else { // Remove the file extension, e.g. /route-path/robots.txt -> /route-path const pathnamePrefix = page.slice(0, -(_path.default.basename(page).length + 1)); suffix = getMetadataRouteSuffix(pathnamePrefix); } // Support both / and custom routes //route.ts. // If it's a metadata file route, we need to append /[id]/route to the page. if (!route.endsWith("/route")) { const { dir, name: baseName, ext } = _path.default.parse(route); const isStaticRoute = (0, _ismetadataroute.isStaticMetadataRoute)(page); route = _path.default.posix.join(dir, `${baseName}${suffix ? `-${suffix}` : ""}${ext}`, isStaticRoute ? "" : "[[...__metadata_id__]]", "route"); } return route; } //# sourceMappingURL=get-metadata-route.js.map