✨ 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
53 lines
2.2 KiB
JavaScript
53 lines
2.2 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.isSymbol = exports.isEmpty = exports.isNil = exports.isConstructor = exports.isNumber = exports.isString = exports.isFunction = exports.stripEndSlash = exports.normalizePath = exports.addLeadingSlash = exports.isPlainObject = exports.isObject = exports.isUndefined = void 0;
|
|
/* eslint-disable @typescript-eslint/no-use-before-define */
|
|
const isUndefined = (obj) => typeof obj === 'undefined';
|
|
exports.isUndefined = isUndefined;
|
|
const isObject = (fn) => !(0, exports.isNil)(fn) && typeof fn === 'object';
|
|
exports.isObject = isObject;
|
|
const isPlainObject = (fn) => {
|
|
if (!(0, exports.isObject)(fn)) {
|
|
return false;
|
|
}
|
|
const proto = Object.getPrototypeOf(fn);
|
|
if (proto === null) {
|
|
return true;
|
|
}
|
|
const ctor = Object.prototype.hasOwnProperty.call(proto, 'constructor') &&
|
|
proto.constructor;
|
|
return (typeof ctor === 'function' &&
|
|
ctor instanceof ctor &&
|
|
Function.prototype.toString.call(ctor) ===
|
|
Function.prototype.toString.call(Object));
|
|
};
|
|
exports.isPlainObject = isPlainObject;
|
|
const addLeadingSlash = (path) => path && typeof path === 'string'
|
|
? path.charAt(0) !== '/'
|
|
? '/' + path
|
|
: path
|
|
: '';
|
|
exports.addLeadingSlash = addLeadingSlash;
|
|
const normalizePath = (path) => path
|
|
? path.startsWith('/')
|
|
? ('/' + path.replace(/\/+$/, '')).replace(/\/+/g, '/')
|
|
: '/' + path.replace(/\/+$/, '')
|
|
: '/';
|
|
exports.normalizePath = normalizePath;
|
|
const stripEndSlash = (path) => path[path.length - 1] === '/' ? path.slice(0, path.length - 1) : path;
|
|
exports.stripEndSlash = stripEndSlash;
|
|
const isFunction = (val) => typeof val === 'function';
|
|
exports.isFunction = isFunction;
|
|
const isString = (val) => typeof val === 'string';
|
|
exports.isString = isString;
|
|
const isNumber = (val) => typeof val === 'number';
|
|
exports.isNumber = isNumber;
|
|
const isConstructor = (val) => val === 'constructor';
|
|
exports.isConstructor = isConstructor;
|
|
const isNil = (val) => (0, exports.isUndefined)(val) || val === null;
|
|
exports.isNil = isNil;
|
|
const isEmpty = (array) => !(array && array.length > 0);
|
|
exports.isEmpty = isEmpty;
|
|
const isSymbol = (val) => typeof val === 'symbol';
|
|
exports.isSymbol = isSymbol;
|