✨ 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
40 lines
1.4 KiB
JavaScript
40 lines
1.4 KiB
JavaScript
/**
|
|
* Tracks newlines during parsing in order to provide an efficient API for
|
|
* determining the one-indexed `{ line, col }` position for any offset
|
|
* within the input.
|
|
*/
|
|
class LineCounter {
|
|
constructor() {
|
|
this.lineStarts = [];
|
|
/**
|
|
* Should be called in ascending order. Otherwise, call
|
|
* `lineCounter.lineStarts.sort()` before calling `linePos()`.
|
|
*/
|
|
this.addNewLine = (offset) => this.lineStarts.push(offset);
|
|
/**
|
|
* Performs a binary search and returns the 1-indexed { line, col }
|
|
* position of `offset`. If `line === 0`, `addNewLine` has never been
|
|
* called or `offset` is before the first known newline.
|
|
*/
|
|
this.linePos = (offset) => {
|
|
let low = 0;
|
|
let high = this.lineStarts.length;
|
|
while (low < high) {
|
|
const mid = (low + high) >> 1; // Math.floor((low + high) / 2)
|
|
if (this.lineStarts[mid] < offset)
|
|
low = mid + 1;
|
|
else
|
|
high = mid;
|
|
}
|
|
if (this.lineStarts[low] === offset)
|
|
return { line: low + 1, col: 1 };
|
|
if (low === 0)
|
|
return { line: 0, col: offset };
|
|
const start = this.lineStarts[low - 1];
|
|
return { line: low, col: offset - start + 1 };
|
|
};
|
|
}
|
|
}
|
|
|
|
export { LineCounter };
|