✨ MAJOR FEATURES: • Auto-zoom intelligence với smart bounds fitting • Enhanced 3D GPS markers với pulsing effects • Professional route display với 6-layer rendering • Status-based parking icons với availability indicators • Production-ready build optimizations 🗺️ AUTO-ZOOM FEATURES: • Smart bounds fitting cho GPS + selected parking • Adaptive padding (50px) cho visual balance • Max zoom control (level 16) để tránh quá gần • Dynamic centering khi không có selection 🎨 ENHANCED VISUALS: • 3D GPS marker với multi-layer pulse effects • Advanced parking icons với status colors • Selection highlighting với animation • Dimming system cho non-selected items 🛣️ ROUTE SYSTEM: • OpenRouteService API integration • Multi-layer route rendering (glow, shadow, main, animated) • Real-time distance & duration calculation • Visual route info trong popup 📱 PRODUCTION READY: • SSR safe với dynamic imports • Build errors resolved • Global deployment via Vercel • Optimized performance 🌍 DEPLOYMENT: • Vercel: https://whatever-ctk2auuxr-phong12hexdockworks-projects.vercel.app • Bundle size: 22.8 kB optimized • Global CDN distribution • HTTPS enabled 💾 VERSION CONTROL: • MapView-v2.0.tsx backup created • MAPVIEW_VERSIONS.md documentation • Full version history tracking
72 lines
2.9 KiB
JavaScript
72 lines
2.9 KiB
JavaScript
import { isMetadataRoute, isStaticMetadataRoute } from "./is-metadata-route";
|
|
import path from "../../shared/lib/isomorphic/path";
|
|
import { interpolateDynamicPath } from "../../server/server-utils";
|
|
import { getNamedRouteRegex } from "../../shared/lib/router/utils/route-regex";
|
|
import { djb2Hash } from "../../shared/lib/hash";
|
|
import { normalizeAppPath } from "../../shared/lib/router/utils/app-paths";
|
|
import { normalizePathSep } from "../../shared/lib/page-path/normalize-path-sep";
|
|
/*
|
|
* 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 = djb2Hash(page).toString(36).slice(0, 6);
|
|
}
|
|
return suffix;
|
|
}
|
|
/**
|
|
* Fill the dynamic segment in the metadata route
|
|
*
|
|
* Example:
|
|
* fillMetadataSegment('/a/[slug]', { params: { slug: 'b' } }, 'open-graph') -> '/a/b/open-graph'
|
|
*
|
|
*/ export function fillMetadataSegment(segment, params, imageSegment) {
|
|
const pathname = normalizeAppPath(segment);
|
|
const routeRegex = getNamedRouteRegex(pathname, false);
|
|
const route = interpolateDynamicPath(pathname, params, routeRegex);
|
|
const suffix = getMetadataRouteSuffix(segment);
|
|
const routeSuffix = suffix ? `-${suffix}` : "";
|
|
const { name, ext } = path.parse(imageSegment);
|
|
return normalizePathSep(path.join(route, `${name}${routeSuffix}${ext}`));
|
|
}
|
|
/**
|
|
* Map metadata page key to the corresponding route
|
|
*
|
|
* static file page key: /app/robots.txt -> /robots.xml -> /robots.txt/route
|
|
* dynamic route page key: /app/robots.tsx -> /robots -> /robots.txt/route
|
|
*
|
|
* @param page
|
|
* @returns
|
|
*/ export function normalizeMetadataRoute(page) {
|
|
if (!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.basename(page).length + 1));
|
|
suffix = getMetadataRouteSuffix(pathnamePrefix);
|
|
}
|
|
// Support both /<metadata-route.ext> and custom routes /<metadata-route>/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.parse(route);
|
|
const isStaticRoute = isStaticMetadataRoute(page);
|
|
route = path.posix.join(dir, `${baseName}${suffix ? `-${suffix}` : ""}${ext}`, isStaticRoute ? "" : "[[...__metadata_id__]]", "route");
|
|
}
|
|
return route;
|
|
}
|
|
|
|
//# sourceMappingURL=get-metadata-route.js.map
|