✨ 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
42 lines
1.5 KiB
JavaScript
42 lines
1.5 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const DT_SEPARATOR = /t|\s/i;
|
|
const DATE = /^(\d\d\d\d)-(\d\d)-(\d\d)$/;
|
|
const TIME = /^(\d\d):(\d\d):(\d\d)(?:\.\d+)?(?:z|([+-]\d\d)(?::?(\d\d))?)$/i;
|
|
const DAYS = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
|
|
function validTimestamp(str, allowDate) {
|
|
// http://tools.ietf.org/html/rfc3339#section-5.6
|
|
const dt = str.split(DT_SEPARATOR);
|
|
return ((dt.length === 2 && validDate(dt[0]) && validTime(dt[1])) ||
|
|
(allowDate && dt.length === 1 && validDate(dt[0])));
|
|
}
|
|
exports.default = validTimestamp;
|
|
function validDate(str) {
|
|
const matches = DATE.exec(str);
|
|
if (!matches)
|
|
return false;
|
|
const y = +matches[1];
|
|
const m = +matches[2];
|
|
const d = +matches[3];
|
|
return (m >= 1 &&
|
|
m <= 12 &&
|
|
d >= 1 &&
|
|
(d <= DAYS[m] ||
|
|
// leap year: https://tools.ietf.org/html/rfc3339#appendix-C
|
|
(m === 2 && d === 29 && (y % 100 === 0 ? y % 400 === 0 : y % 4 === 0))));
|
|
}
|
|
function validTime(str) {
|
|
const matches = TIME.exec(str);
|
|
if (!matches)
|
|
return false;
|
|
const hr = +matches[1];
|
|
const min = +matches[2];
|
|
const sec = +matches[3];
|
|
const tzH = +(matches[4] || 0);
|
|
const tzM = +(matches[5] || 0);
|
|
return ((hr <= 23 && min <= 59 && sec <= 59) ||
|
|
// leap second
|
|
(hr - tzH === 23 && min - tzM === 59 && sec === 60));
|
|
}
|
|
validTimestamp.code = 'require("ajv/dist/runtime/timestamp").default';
|
|
//# sourceMappingURL=timestamp.js.map
|