✨ 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
92 lines
1.6 KiB
JavaScript
92 lines
1.6 KiB
JavaScript
var streamify = require('./streamify.js')
|
||
, defer = require('./defer.js')
|
||
;
|
||
|
||
// API
|
||
module.exports = ReadableAsyncKit;
|
||
|
||
/**
|
||
* Base constructor for all streams
|
||
* used to hold properties/methods
|
||
*/
|
||
function ReadableAsyncKit()
|
||
{
|
||
ReadableAsyncKit.super_.apply(this, arguments);
|
||
|
||
// list of active jobs
|
||
this.jobs = {};
|
||
|
||
// add stream methods
|
||
this.destroy = destroy;
|
||
this._start = _start;
|
||
this._read = _read;
|
||
}
|
||
|
||
/**
|
||
* Destroys readable stream,
|
||
* by aborting outstanding jobs
|
||
*
|
||
* @returns {void}
|
||
*/
|
||
function destroy()
|
||
{
|
||
if (this.destroyed)
|
||
{
|
||
return;
|
||
}
|
||
|
||
this.destroyed = true;
|
||
|
||
if (typeof this.terminator == 'function')
|
||
{
|
||
this.terminator();
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Starts provided jobs in async manner
|
||
*
|
||
* @private
|
||
*/
|
||
function _start()
|
||
{
|
||
// first argument – runner function
|
||
var runner = arguments[0]
|
||
// take away first argument
|
||
, args = Array.prototype.slice.call(arguments, 1)
|
||
// second argument - input data
|
||
, input = args[0]
|
||
// last argument - result callback
|
||
, endCb = streamify.callback.call(this, args[args.length - 1])
|
||
;
|
||
|
||
args[args.length - 1] = endCb;
|
||
// third argument - iterator
|
||
args[1] = streamify.iterator.call(this, args[1]);
|
||
|
||
// allow time for proper setup
|
||
defer(function()
|
||
{
|
||
if (!this.destroyed)
|
||
{
|
||
this.terminator = runner.apply(null, args);
|
||
}
|
||
else
|
||
{
|
||
endCb(null, Array.isArray(input) ? [] : {});
|
||
}
|
||
}.bind(this));
|
||
}
|
||
|
||
|
||
/**
|
||
* Implement _read to comply with Readable streams
|
||
* Doesn't really make sense for flowing object mode
|
||
*
|
||
* @private
|
||
*/
|
||
function _read()
|
||
{
|
||
|
||
}
|