✨ 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
49 lines
2.0 KiB
JavaScript
Executable File
49 lines
2.0 KiB
JavaScript
Executable File
import { SCHEMES } from "../uri";
|
|
const NID$ = "(?:[0-9A-Za-z][0-9A-Za-z\\-]{1,31})";
|
|
const PCT_ENCODED$ = "(?:\\%[0-9A-Fa-f]{2})";
|
|
const TRANS$$ = "[0-9A-Za-z\\(\\)\\+\\,\\-\\.\\:\\=\\@\\;\\$\\_\\!\\*\\'\\/\\?\\#]";
|
|
const NSS$ = "(?:(?:" + PCT_ENCODED$ + "|" + TRANS$$ + ")+)";
|
|
const URN_SCHEME = new RegExp("^urn\\:(" + NID$ + ")$");
|
|
const URN_PATH = new RegExp("^(" + NID$ + ")\\:(" + NSS$ + ")$");
|
|
const URN_PARSE = /^([^\:]+)\:(.*)/;
|
|
const URN_EXCLUDED = /[\x00-\x20\\\"\&\<\>\[\]\^\`\{\|\}\~\x7F-\xFF]/g;
|
|
//RFC 2141
|
|
const handler = {
|
|
scheme: "urn",
|
|
parse: function (components, options) {
|
|
const matches = components.path && components.path.match(URN_PARSE);
|
|
let urnComponents = components;
|
|
if (matches) {
|
|
const scheme = options.scheme || urnComponents.scheme || "urn";
|
|
const nid = matches[1].toLowerCase();
|
|
const nss = matches[2];
|
|
const urnScheme = `${scheme}:${options.nid || nid}`;
|
|
const schemeHandler = SCHEMES[urnScheme];
|
|
urnComponents.nid = nid;
|
|
urnComponents.nss = nss;
|
|
urnComponents.path = undefined;
|
|
if (schemeHandler) {
|
|
urnComponents = schemeHandler.parse(urnComponents, options);
|
|
}
|
|
}
|
|
else {
|
|
urnComponents.error = urnComponents.error || "URN can not be parsed.";
|
|
}
|
|
return urnComponents;
|
|
},
|
|
serialize: function (urnComponents, options) {
|
|
const scheme = options.scheme || urnComponents.scheme || "urn";
|
|
const nid = urnComponents.nid;
|
|
const urnScheme = `${scheme}:${options.nid || nid}`;
|
|
const schemeHandler = SCHEMES[urnScheme];
|
|
if (schemeHandler) {
|
|
urnComponents = schemeHandler.serialize(urnComponents, options);
|
|
}
|
|
const uriComponents = urnComponents;
|
|
const nss = urnComponents.nss;
|
|
uriComponents.path = `${nid || options.nid}:${nss}`;
|
|
return uriComponents;
|
|
},
|
|
};
|
|
export default handler;
|
|
//# sourceMappingURL=urn.js.map
|