✨ 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
51 lines
1.6 KiB
JavaScript
51 lines
1.6 KiB
JavaScript
import { isCSSVariableName } from '../../render/dom/utils/is-css-variable.mjs';
|
|
import { transformProps } from '../../render/html/utils/transform.mjs';
|
|
import { addUniqueItem, removeItem } from '../../utils/array.mjs';
|
|
import { useConstant } from '../../utils/use-constant.mjs';
|
|
import { MotionValue } from '../index.mjs';
|
|
import { camelToDash } from '../../render/dom/utils/camel-to-dash.mjs';
|
|
|
|
class WillChangeMotionValue extends MotionValue {
|
|
constructor() {
|
|
super(...arguments);
|
|
this.members = [];
|
|
this.transforms = new Set();
|
|
}
|
|
add(name) {
|
|
let memberName;
|
|
if (transformProps.has(name)) {
|
|
this.transforms.add(name);
|
|
memberName = "transform";
|
|
}
|
|
else if (!name.startsWith("origin") &&
|
|
!isCSSVariableName(name) &&
|
|
name !== "willChange") {
|
|
memberName = camelToDash(name);
|
|
}
|
|
if (memberName) {
|
|
addUniqueItem(this.members, memberName);
|
|
this.update();
|
|
}
|
|
}
|
|
remove(name) {
|
|
if (transformProps.has(name)) {
|
|
this.transforms.delete(name);
|
|
if (!this.transforms.size) {
|
|
removeItem(this.members, "transform");
|
|
}
|
|
}
|
|
else {
|
|
removeItem(this.members, camelToDash(name));
|
|
}
|
|
this.update();
|
|
}
|
|
update() {
|
|
this.set(this.members.length ? this.members.join(", ") : "auto");
|
|
}
|
|
}
|
|
function useWillChange() {
|
|
return useConstant(() => new WillChangeMotionValue("auto"));
|
|
}
|
|
|
|
export { WillChangeMotionValue, useWillChange };
|