✨ 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
79 lines
2.8 KiB
JavaScript
79 lines
2.8 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
Object.defineProperty(exports, "runCompiler", {
|
|
enumerable: true,
|
|
get: function() {
|
|
return runCompiler;
|
|
}
|
|
});
|
|
const _webpack = require("next/dist/compiled/webpack/webpack");
|
|
function generateStats(result, stat) {
|
|
const { errors, warnings } = stat.toJson({
|
|
preset: "errors-warnings",
|
|
moduleTrace: true
|
|
});
|
|
if (errors && errors.length > 0) {
|
|
result.errors.push(...errors);
|
|
}
|
|
if (warnings && warnings.length > 0) {
|
|
result.warnings.push(...warnings);
|
|
}
|
|
return result;
|
|
}
|
|
// Webpack 5 requires the compiler to be closed (to save caches)
|
|
// Webpack 4 does not have this close method so in order to be backwards compatible we check if it exists
|
|
function closeCompiler(compiler) {
|
|
return new Promise((resolve, reject)=>{
|
|
// @ts-ignore Close only exists on the compiler in webpack 5
|
|
return compiler.close((err)=>err ? reject(err) : resolve());
|
|
});
|
|
}
|
|
function runCompiler(config, { runWebpackSpan, inputFileSystem }) {
|
|
return new Promise((resolve, reject)=>{
|
|
const compiler = (0, _webpack.webpack)(config);
|
|
// Ensure we use the previous inputFileSystem
|
|
if (inputFileSystem) {
|
|
compiler.inputFileSystem = inputFileSystem;
|
|
}
|
|
compiler.fsStartTime = Date.now();
|
|
compiler.run((err, stats)=>{
|
|
const webpackCloseSpan = runWebpackSpan.traceChild("webpack-close", {
|
|
name: config.name || "unknown"
|
|
});
|
|
webpackCloseSpan.traceAsyncFn(()=>closeCompiler(compiler)).then(()=>{
|
|
if (err) {
|
|
const reason = err.stack ?? err.toString();
|
|
if (reason) {
|
|
return resolve([
|
|
{
|
|
errors: [
|
|
{
|
|
message: reason,
|
|
details: err.details
|
|
}
|
|
],
|
|
warnings: [],
|
|
stats
|
|
},
|
|
compiler.inputFileSystem
|
|
]);
|
|
}
|
|
return reject(err);
|
|
} else if (!stats) throw new Error("No Stats from webpack");
|
|
const result = webpackCloseSpan.traceChild("webpack-generate-error-stats").traceFn(()=>generateStats({
|
|
errors: [],
|
|
warnings: [],
|
|
stats
|
|
}, stats));
|
|
return resolve([
|
|
result,
|
|
compiler.inputFileSystem
|
|
]);
|
|
});
|
|
});
|
|
});
|
|
}
|
|
|
|
//# sourceMappingURL=compiler.js.map
|