✨ 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
103 lines
4.0 KiB
JavaScript
103 lines
4.0 KiB
JavaScript
"use strict";
|
|
const taskManager = require("./managers/tasks");
|
|
const async_1 = require("./providers/async");
|
|
const stream_1 = require("./providers/stream");
|
|
const sync_1 = require("./providers/sync");
|
|
const settings_1 = require("./settings");
|
|
const utils = require("./utils");
|
|
async function FastGlob(source, options) {
|
|
assertPatternsInput(source);
|
|
const works = getWorks(source, async_1.default, options);
|
|
const result = await Promise.all(works);
|
|
return utils.array.flatten(result);
|
|
}
|
|
// https://github.com/typescript-eslint/typescript-eslint/issues/60
|
|
// eslint-disable-next-line no-redeclare
|
|
(function (FastGlob) {
|
|
FastGlob.glob = FastGlob;
|
|
FastGlob.globSync = sync;
|
|
FastGlob.globStream = stream;
|
|
FastGlob.async = FastGlob;
|
|
function sync(source, options) {
|
|
assertPatternsInput(source);
|
|
const works = getWorks(source, sync_1.default, options);
|
|
return utils.array.flatten(works);
|
|
}
|
|
FastGlob.sync = sync;
|
|
function stream(source, options) {
|
|
assertPatternsInput(source);
|
|
const works = getWorks(source, stream_1.default, options);
|
|
/**
|
|
* The stream returned by the provider cannot work with an asynchronous iterator.
|
|
* To support asynchronous iterators, regardless of the number of tasks, we always multiplex streams.
|
|
* This affects performance (+25%). I don't see best solution right now.
|
|
*/
|
|
return utils.stream.merge(works);
|
|
}
|
|
FastGlob.stream = stream;
|
|
function generateTasks(source, options) {
|
|
assertPatternsInput(source);
|
|
const patterns = [].concat(source);
|
|
const settings = new settings_1.default(options);
|
|
return taskManager.generate(patterns, settings);
|
|
}
|
|
FastGlob.generateTasks = generateTasks;
|
|
function isDynamicPattern(source, options) {
|
|
assertPatternsInput(source);
|
|
const settings = new settings_1.default(options);
|
|
return utils.pattern.isDynamicPattern(source, settings);
|
|
}
|
|
FastGlob.isDynamicPattern = isDynamicPattern;
|
|
function escapePath(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.escape(source);
|
|
}
|
|
FastGlob.escapePath = escapePath;
|
|
function convertPathToPattern(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.convertPathToPattern(source);
|
|
}
|
|
FastGlob.convertPathToPattern = convertPathToPattern;
|
|
let posix;
|
|
(function (posix) {
|
|
function escapePath(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.escapePosixPath(source);
|
|
}
|
|
posix.escapePath = escapePath;
|
|
function convertPathToPattern(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.convertPosixPathToPattern(source);
|
|
}
|
|
posix.convertPathToPattern = convertPathToPattern;
|
|
})(posix = FastGlob.posix || (FastGlob.posix = {}));
|
|
let win32;
|
|
(function (win32) {
|
|
function escapePath(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.escapeWindowsPath(source);
|
|
}
|
|
win32.escapePath = escapePath;
|
|
function convertPathToPattern(source) {
|
|
assertPatternsInput(source);
|
|
return utils.path.convertWindowsPathToPattern(source);
|
|
}
|
|
win32.convertPathToPattern = convertPathToPattern;
|
|
})(win32 = FastGlob.win32 || (FastGlob.win32 = {}));
|
|
})(FastGlob || (FastGlob = {}));
|
|
function getWorks(source, _Provider, options) {
|
|
const patterns = [].concat(source);
|
|
const settings = new settings_1.default(options);
|
|
const tasks = taskManager.generate(patterns, settings);
|
|
const provider = new _Provider(settings);
|
|
return tasks.map(provider.read, provider);
|
|
}
|
|
function assertPatternsInput(input) {
|
|
const source = [].concat(input);
|
|
const isValidSource = source.every((item) => utils.string.isString(item) && !utils.string.isEmpty(item));
|
|
if (!isValidSource) {
|
|
throw new TypeError('Patterns must be a string (non empty) or an array of strings');
|
|
}
|
|
}
|
|
module.exports = FastGlob;
|