✨ 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
70 lines
1.7 KiB
JavaScript
70 lines
1.7 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const binarySearchBounds = require("./binarySearchBounds");
|
|
|
|
/** @typedef {(value: number) => void} Callback */
|
|
|
|
class ParallelismFactorCalculator {
|
|
constructor() {
|
|
/** @type {number[]} */
|
|
this._rangePoints = [];
|
|
/** @type {Callback[]} */
|
|
this._rangeCallbacks = [];
|
|
}
|
|
|
|
/**
|
|
* @param {number} start range start
|
|
* @param {number} end range end
|
|
* @param {Callback} callback callback
|
|
* @returns {void}
|
|
*/
|
|
range(start, end, callback) {
|
|
if (start === end) return callback(1);
|
|
this._rangePoints.push(start);
|
|
this._rangePoints.push(end);
|
|
this._rangeCallbacks.push(callback);
|
|
}
|
|
|
|
calculate() {
|
|
const segments = [...new Set(this._rangePoints)].sort((a, b) =>
|
|
a < b ? -1 : 1
|
|
);
|
|
const parallelism = segments.map(() => 0);
|
|
const rangeStartIndices = [];
|
|
for (let i = 0; i < this._rangePoints.length; i += 2) {
|
|
const start = this._rangePoints[i];
|
|
const end = this._rangePoints[i + 1];
|
|
let idx = binarySearchBounds.eq(segments, start);
|
|
rangeStartIndices.push(idx);
|
|
do {
|
|
parallelism[idx]++;
|
|
idx++;
|
|
} while (segments[idx] < end);
|
|
}
|
|
for (let i = 0; i < this._rangeCallbacks.length; i++) {
|
|
const start = this._rangePoints[i * 2];
|
|
const end = this._rangePoints[i * 2 + 1];
|
|
let idx = rangeStartIndices[i];
|
|
let sum = 0;
|
|
let totalDuration = 0;
|
|
let current = start;
|
|
do {
|
|
const p = parallelism[idx];
|
|
idx++;
|
|
const duration = segments[idx] - current;
|
|
totalDuration += duration;
|
|
current = segments[idx];
|
|
sum += p * duration;
|
|
} while (current < end);
|
|
this._rangeCallbacks[i](sum / totalDuration);
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = ParallelismFactorCalculator;
|