✨ 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
93 lines
3.9 KiB
JavaScript
93 lines
3.9 KiB
JavaScript
import { normalizePathSep } from "../../shared/lib/page-path/normalize-path-sep";
|
|
export const STATIC_METADATA_IMAGES = {
|
|
icon: {
|
|
filename: "icon",
|
|
extensions: [
|
|
"ico",
|
|
"jpg",
|
|
"jpeg",
|
|
"png",
|
|
"svg"
|
|
]
|
|
},
|
|
apple: {
|
|
filename: "apple-icon",
|
|
extensions: [
|
|
"jpg",
|
|
"jpeg",
|
|
"png"
|
|
]
|
|
},
|
|
favicon: {
|
|
filename: "favicon",
|
|
extensions: [
|
|
"ico"
|
|
]
|
|
},
|
|
openGraph: {
|
|
filename: "opengraph-image",
|
|
extensions: [
|
|
"jpg",
|
|
"jpeg",
|
|
"png",
|
|
"gif"
|
|
]
|
|
},
|
|
twitter: {
|
|
filename: "twitter-image",
|
|
extensions: [
|
|
"jpg",
|
|
"jpeg",
|
|
"png",
|
|
"gif"
|
|
]
|
|
}
|
|
};
|
|
// Match routes that are metadata routes, e.g. /sitemap.xml, /favicon.<ext>, /<icon>.<ext>, etc.
|
|
// TODO-METADATA: support more metadata routes with more extensions
|
|
const defaultExtensions = [
|
|
"js",
|
|
"jsx",
|
|
"ts",
|
|
"tsx"
|
|
];
|
|
const getExtensionRegexString = (extensions)=>`(?:${extensions.join("|")})`;
|
|
// When you only pass the file extension as `[]`, it will only match the static convention files
|
|
// e.g. /robots.txt, /sitemap.xml, /favicon.ico, /manifest.json
|
|
// When you pass the file extension as `['js', 'jsx', 'ts', 'tsx']`, it will also match the dynamic convention files
|
|
// e.g. /robots.js, /sitemap.tsx, /favicon.jsx, /manifest.ts
|
|
// When `withExtension` is false, it will match the static convention files without the extension, by default it's true
|
|
// e.g. /robots, /sitemap, /favicon, /manifest, use to match dynamic API routes like app/robots.ts
|
|
export function isMetadataRouteFile(appDirRelativePath, pageExtensions, withExtension) {
|
|
const metadataRouteFilesRegex = [
|
|
new RegExp(`^[\\\\/]robots${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat("txt"))}$` : ""}`),
|
|
new RegExp(`^[\\\\/]manifest${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat("webmanifest", "json"))}$` : ""}`),
|
|
new RegExp(`^[\\\\/]favicon\\.ico$`),
|
|
new RegExp(`[\\\\/]sitemap${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat("xml"))}$` : ""}`),
|
|
new RegExp(`[\\\\/]${STATIC_METADATA_IMAGES.icon.filename}\\d?${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat(STATIC_METADATA_IMAGES.icon.extensions))}$` : ""}`),
|
|
new RegExp(`[\\\\/]${STATIC_METADATA_IMAGES.apple.filename}\\d?${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat(STATIC_METADATA_IMAGES.apple.extensions))}$` : ""}`),
|
|
new RegExp(`[\\\\/]${STATIC_METADATA_IMAGES.openGraph.filename}\\d?${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat(STATIC_METADATA_IMAGES.openGraph.extensions))}$` : ""}`),
|
|
new RegExp(`[\\\\/]${STATIC_METADATA_IMAGES.twitter.filename}\\d?${withExtension ? `\\.${getExtensionRegexString(pageExtensions.concat(STATIC_METADATA_IMAGES.twitter.extensions))}$` : ""}`)
|
|
];
|
|
const normalizedAppDirRelativePath = normalizePathSep(appDirRelativePath);
|
|
return metadataRouteFilesRegex.some((r)=>r.test(normalizedAppDirRelativePath));
|
|
}
|
|
export function isStaticMetadataRouteFile(appDirRelativePath) {
|
|
return isMetadataRouteFile(appDirRelativePath, [], true);
|
|
}
|
|
export function isStaticMetadataRoute(page) {
|
|
return page === "/robots" || page === "/manifest" || isStaticMetadataRouteFile(page);
|
|
}
|
|
/*
|
|
* Remove the 'app' prefix or '/route' suffix, only check the route name since they're only allowed in root app directory
|
|
* e.g.
|
|
* /app/robots -> /robots
|
|
* app/robots -> /robots
|
|
* /robots -> /robots
|
|
*/ export function isMetadataRoute(route) {
|
|
let page = route.replace(/^\/?app\//, "").replace(/\/route$/, "");
|
|
if (page[0] !== "/") page = "/" + page;
|
|
return !page.endsWith("/page") && isMetadataRouteFile(page, defaultExtensions, false);
|
|
}
|
|
|
|
//# sourceMappingURL=is-metadata-route.js.map
|