Files
Laca-City/backend/node_modules/@nestjs/cli/actions/add.action.js
PhongPham c65cc97a33 🎯 MapView v2.0 - Global Deployment Ready
 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
2025-07-20 19:52:16 +07:00

114 lines
5.2 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.AddAction = void 0;
const chalk = require("chalk");
const get_value_or_default_1 = require("../lib/compiler/helpers/get-value-or-default");
const package_managers_1 = require("../lib/package-managers");
const schematics_1 = require("../lib/schematics");
const ui_1 = require("../lib/ui");
const load_configuration_1 = require("../lib/utils/load-configuration");
const project_utils_1 = require("../lib/utils/project-utils");
const abstract_action_1 = require("./abstract.action");
const schematicName = 'nest-add';
class AddAction extends abstract_action_1.AbstractAction {
async handle(inputs, options, extraFlags) {
const libraryName = this.getLibraryName(inputs);
const packageName = this.getPackageName(libraryName);
const collectionName = this.getCollectionName(libraryName, packageName);
const tagName = this.getTagName(packageName);
const skipInstall = (0, project_utils_1.hasValidOptionFlag)('skip-install', options);
const packageInstallSuccess = skipInstall || (await this.installPackage(collectionName, tagName));
if (packageInstallSuccess) {
const sourceRootOption = await this.getSourceRoot(inputs.concat(options));
options.push(sourceRootOption);
await this.addLibrary(collectionName, options, extraFlags);
}
else {
console.error(chalk.red(ui_1.MESSAGES.LIBRARY_INSTALLATION_FAILED_BAD_PACKAGE(libraryName)));
throw new Error(ui_1.MESSAGES.LIBRARY_INSTALLATION_FAILED_BAD_PACKAGE(libraryName));
}
}
async getSourceRoot(inputs) {
const configuration = await (0, load_configuration_1.loadConfiguration)();
const configurationProjects = configuration.projects;
const appName = inputs.find((option) => option.name === 'project')
.value;
let sourceRoot = appName
? (0, get_value_or_default_1.getValueOrDefault)(configuration, 'sourceRoot', appName)
: configuration.sourceRoot;
const shouldAsk = (0, project_utils_1.shouldAskForProject)(schematicName, configurationProjects, appName);
if (shouldAsk) {
const defaultLabel = ' [ Default ]';
let defaultProjectName = configuration.sourceRoot + defaultLabel;
for (const property in configurationProjects) {
if (configurationProjects[property].sourceRoot ===
configuration.sourceRoot) {
defaultProjectName = property + defaultLabel;
break;
}
}
const projects = (0, project_utils_1.moveDefaultProjectToStart)(configuration, defaultProjectName, defaultLabel);
const answers = await (0, project_utils_1.askForProjectName)(ui_1.MESSAGES.LIBRARY_PROJECT_SELECTION_QUESTION, projects);
const project = answers.appName.replace(defaultLabel, '');
if (project !== configuration.sourceRoot) {
sourceRoot = configurationProjects[project].sourceRoot;
}
}
return { name: 'sourceRoot', value: sourceRoot };
}
async installPackage(collectionName, tagName) {
const manager = await package_managers_1.PackageManagerFactory.find();
tagName = tagName || 'latest';
let installResult = false;
try {
installResult = await manager.addProduction([collectionName], tagName);
}
catch (error) {
if (error && error.message) {
console.error(chalk.red(error.message));
}
}
return installResult;
}
async addLibrary(collectionName, options, extraFlags) {
console.info(ui_1.MESSAGES.LIBRARY_INSTALLATION_STARTS);
const schematicOptions = [];
schematicOptions.push(new schematics_1.SchematicOption('sourceRoot', options.find((option) => option.name === 'sourceRoot').value));
const extraFlagsString = extraFlags ? extraFlags.join(' ') : undefined;
try {
const collection = schematics_1.CollectionFactory.create(collectionName);
await collection.execute(schematicName, schematicOptions, extraFlagsString);
}
catch (error) {
if (error && error.message) {
console.error(chalk.red(error.message));
return Promise.reject();
}
}
}
getLibraryName(inputs) {
const libraryInput = inputs.find((input) => input.name === 'library');
if (!libraryInput) {
throw new Error('No library found in command input');
}
return libraryInput.value;
}
getPackageName(library) {
return library.startsWith('@')
? library.split('/', 2).join('/')
: library.split('/', 1)[0];
}
getCollectionName(library, packageName) {
return ((packageName.startsWith('@')
? packageName.split('@', 2).join('@')
: packageName.split('@', 1).join('@')) +
library.slice(packageName.length));
}
getTagName(packageName) {
return packageName.startsWith('@')
? packageName.split('@', 3)[2]
: packageName.split('@', 2)[1];
}
}
exports.AddAction = AddAction;