Files
Laca-City/backend/node_modules/jake/lib/namespace.js
PhongPham c65cc97a33 🎯 MapView v2.0 - Global Deployment Ready
 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
2025-07-20 19:52:16 +07:00

116 lines
2.4 KiB
JavaScript

const ROOT_NAMESPACE_NAME = '__rootNamespace__';
class Namespace {
constructor(name, parentNamespace) {
this.name = name;
this.parentNamespace = parentNamespace;
this.childNamespaces = {};
this.tasks = {};
this.rules = {};
this.path = this.getPath();
}
get fullName() {
return this._getFullName();
}
addTask(task) {
this.tasks[task.name] = task;
task.namespace = this;
}
resolveTask(name) {
if (!name) {
return;
}
let taskPath = name.split(':');
let taskName = taskPath.pop();
let task;
let ns;
// Namespaced, return either relative to current, or from root
if (taskPath.length) {
taskPath = taskPath.join(':');
ns = this.resolveNamespace(taskPath) ||
Namespace.ROOT_NAMESPACE.resolveNamespace(taskPath);
task = (ns && ns.resolveTask(taskName));
}
// Bare task, return either local, or top-level
else {
task = this.tasks[name] || Namespace.ROOT_NAMESPACE.tasks[name];
}
return task || null;
}
resolveNamespace(relativeName) {
if (!relativeName) {
return this;
}
let parts = relativeName.split(':');
let ns = this;
for (let i = 0, ii = parts.length; (ns && i < ii); i++) {
ns = ns.childNamespaces[parts[i]];
}
return ns || null;
}
matchRule(relativeName) {
let parts = relativeName.split(':');
parts.pop();
let ns = this.resolveNamespace(parts.join(':'));
let rules = ns ? ns.rules : [];
let r;
let match;
for (let p in rules) {
r = rules[p];
if (r.match(relativeName)) {
match = r;
}
}
return (ns && match) ||
(this.parentNamespace &&
this.parentNamespace.matchRule(relativeName));
}
getPath() {
let parts = [];
let next = this.parentNamespace;
while (next) {
parts.push(next.name);
next = next.parentNamespace;
}
parts.pop(); // Remove '__rootNamespace__'
return parts.reverse().join(':');
}
_getFullName() {
let path = this.path;
path = (path && path.split(':')) || [];
path.push(this.name);
return path.join(':');
}
isRootNamespace() {
return !this.parentNamespace;
}
}
class RootNamespace extends Namespace {
constructor() {
super(ROOT_NAMESPACE_NAME, null);
Namespace.ROOT_NAMESPACE = this;
}
}
module.exports.Namespace = Namespace;
module.exports.RootNamespace = RootNamespace;