✨ 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
55 lines
1.4 KiB
JavaScript
55 lines
1.4 KiB
JavaScript
'use strict';
|
|
const { fromEvent } = require('rxjs');
|
|
const { filter, map, share, takeUntil } = require('rxjs/operators');
|
|
|
|
function normalizeKeypressEvents(value, key) {
|
|
return { value, key: key || {} };
|
|
}
|
|
|
|
module.exports = function (rl) {
|
|
const keypress = fromEvent(rl.input, 'keypress', normalizeKeypressEvents)
|
|
.pipe(takeUntil(fromEvent(rl, 'close')))
|
|
// Ignore `enter` key. On the readline, we only care about the `line` event.
|
|
.pipe(filter(({ key }) => key.name !== 'enter' && key.name !== 'return'));
|
|
|
|
return {
|
|
line: fromEvent(rl, 'line'),
|
|
keypress,
|
|
|
|
normalizedUpKey: keypress.pipe(
|
|
filter(
|
|
({ key }) =>
|
|
key.name === 'up' || key.name === 'k' || (key.name === 'p' && key.ctrl)
|
|
),
|
|
share()
|
|
),
|
|
|
|
normalizedDownKey: keypress.pipe(
|
|
filter(
|
|
({ key }) =>
|
|
key.name === 'down' || key.name === 'j' || (key.name === 'n' && key.ctrl)
|
|
),
|
|
share()
|
|
),
|
|
|
|
numberKey: keypress.pipe(
|
|
filter((e) => e.value && '123456789'.indexOf(e.value) >= 0),
|
|
map((e) => Number(e.value)),
|
|
share()
|
|
),
|
|
|
|
spaceKey: keypress.pipe(
|
|
filter(({ key }) => key && key.name === 'space'),
|
|
share()
|
|
),
|
|
aKey: keypress.pipe(
|
|
filter(({ key }) => key && key.name === 'a'),
|
|
share()
|
|
),
|
|
iKey: keypress.pipe(
|
|
filter(({ key }) => key && key.name === 'i'),
|
|
share()
|
|
),
|
|
};
|
|
};
|